[
    {
        "tags": [
            "python",
            "linux",
            "ubuntu",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2609565,
                    "reputation": 10007,
                    "user_id": 2259934,
                    "user_type": "registered",
                    "accept_rate": 64,
                    "profile_image": "https://i.sstatic.net/lqiMo.jpg?s=256",
                    "display_name": "Paul Becotte",
                    "link": "https://stackoverflow.com/users/2259934/paul-becotte"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1466708632,
                "post_id": 37870814,
                "comment_id": 63443751,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1466708598,
                "creation_date": 1466708598,
                "answer_id": 37999780,
                "question_id": 37870814,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "This gets compiled, you need to install the build dependencies.\r\n\r\n`apt-get install autoconf automake build-essential libtool python-dev`\r\n\r\nSee the Pypi page for more info ... https://pypi.python.org/pypi/jq/0.1.6",
                "title": "Having trouble installing Python bindings of jq on ubuntu linux"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1703068445,
                "creation_date": 1703068445,
                "answer_id": 77690871,
                "question_id": 37870814,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Stacked with this problem too. Hence rolled out another binging for others who do not want to compile anything and install irrelevant build toolchains.\r\n\r\n**Alternative JQ Python binding is called [JQpy][1].**\r\n\r\nInstallation\r\n------------\r\n\r\n```bash\r\nsudo apt-get update &amp;&amp; sudo apt-get install jq\r\npip install jqpy\r\n```\r\n\r\nExample\r\n-------\r\n\r\n```ipython\r\n&gt;&gt;&gt; from jqpy import jq\r\n&gt;&gt;&gt; jq(&#39;.results[] | {age, city}&#39;, {\r\n                &quot;timestamp&quot;: 1234567890,\r\n                &quot;report&quot;: &quot;Age Report&quot;,\r\n                &quot;results&quot;: [\r\n                        { &quot;name&quot;: &quot;John&quot;, &quot;age&quot;: 43, &quot;city&quot;: &quot;TownA&quot; },\r\n                        { &quot;name&quot;: &quot;Joe&quot;,  &quot;age&quot;: 10, &quot;city&quot;: &quot;TownB&quot; }\r\n                ]\r\n        })\r\n[{&#39;age&#39;: 43, &#39;city&#39;: &#39;TownA&#39;}, {&#39;age&#39;: 10, &#39;city&#39;: &#39;TownB&#39;}]\r\n```\r\n\r\n  [1]: https://baterflyrity.github.io/jqpy/",
                "title": "Having trouble installing Python bindings of jq on ubuntu linux"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1703068445,
        "creation_date": 1466118581,
        "last_edit_date": 1466134846,
        "question_id": 37870814,
        "body_markdown": "I have been trying to install the Python bindings of jq on ubuntu using pip.\r\n\r\nHowever, when I run the following command, it fails.\r\n\r\n`sudo pip install jq`\r\n\r\nThis is the error message it get.\r\n\r\n    Command &quot;/usr/bin/python -u -c &quot;import setuptools, tokenize;__file__=&#39;/tmp/pip-build-EmO25q/jq/setup.py&#39;;exec(compile(getattr(tokenize, &#39;open&#39;, open)\r\n    (__file__).read().replace(&#39;\\r\\n&#39;, &#39;\\n&#39;), __file__, &#39;exec&#39;))&quot; install --record /tmp/pip-RBT2h7-record/install-record.txt --single-version-externally-m\r\n    anaged --compile&quot; failed with error code 1 in /tmp/pip-build-EmO25q/jq/",
        "link": "https://stackoverflow.com/questions/37870814/having-trouble-installing-python-bindings-of-jq-on-ubuntu-linux",
        "title": "Having trouble installing Python bindings of jq on ubuntu linux"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 8655073,
                    "reputation": 29,
                    "user_id": 6479616,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/4a5e6040e91d70601eb3c8688345dfb0?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "john zhao",
                    "link": "https://stackoverflow.com/users/6479616/john-zhao"
                },
                "reply_to_user": {
                    "account_id": 888714,
                    "reputation": 36311,
                    "user_id": 927493,
                    "user_type": "registered",
                    "accept_rate": 61,
                    "profile_image": "https://i.sstatic.net/sxsnm.png?s=256",
                    "display_name": "J Fabian Meier",
                    "link": "https://stackoverflow.com/users/927493/j-fabian-meier"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1466195725,
                "post_id": 37883370,
                "comment_id": 63234420,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": false,
                "score": 5,
                "last_activity_date": 1466175433,
                "creation_date": 1466175433,
                "answer_id": 37884701,
                "question_id": 37883370,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Collect the fields you want in an array and use `@csv` to convert to a CSV row.  Make sure you get the raw output.\r\n\r\n    jq -r &#39;.[] | [ .commit.author.name, .commit.url, .commit.author.date ] | @csv&#39; input.json",
                "title": "JQ filter and output format"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1476861610,
        "creation_date": 1466171484,
        "last_edit_date": 1466175189,
        "question_id": 37883370,
        "body_markdown": "For an input below:\r\n\r\n    [{\r\n      &quot;commit&quot;: {\r\n        &quot;author&quot;: {\r\n          &quot;name&quot;: &quot;Stephen Dolan&quot;,\r\n          &quot;email&quot;: &quot;mu@netsoc.tcd.ie&quot;,\r\n          &quot;date&quot;: &quot;2013-06-22T16:30:59Z&quot;\r\n        },\r\n        &quot;committer&quot;: {\r\n          &quot;name&quot;: &quot;Stephen Dolan&quot;,\r\n          &quot;email&quot;: &quot;mu@netsoc.tcd.ie&quot;,\r\n          &quot;date&quot;: &quot;2013-06-22T16:30:59Z&quot;\r\n        },\r\n        &quot;message&quot;: &quot;Merge pull request #162 from stedolan/utf8-fixes\\n\\nUtf8 fixes. Closes #161&quot;\r\n        &quot;url&quot;:&quot;https://api.github.com/repos/stedolan/jq/commits/d25341478381063d1c76e81b3a52e0592a7c997f&quot;    \r\n      },\r\n      {\r\n        ...\r\n      }\r\n    }]\r\n\r\nHow can JQ generate a delimited string from different objects as shown below?\r\n\r\n    &quot;Stephen Dolan&quot;,  &quot;https://api.github.com/repos/stedolan/jq/commits/d25341478381063d1c76e81b3a52e0592a7c997f&quot;,  &quot;2013-06-22T16:30:59Z&quot;",
        "link": "https://stackoverflow.com/questions/37883370/jq-filter-and-output-format",
        "title": "JQ filter and output format"
    },
    {
        "tags": [
            "bash",
            "sparql",
            "jq",
            "wikidata-api",
            "wikidata-query-service"
        ],
        "comments": [
            {
                "owner": {
                    "user_type": "does_not_exist",
                    "display_name": "user3899165"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1466267471,
                "post_id": 37897475,
                "comment_id": 63251466,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 435835,
                    "reputation": 923,
                    "user_id": 822644,
                    "user_type": "registered",
                    "accept_rate": 83,
                    "profile_image": "https://www.gravatar.com/avatar/73af50ba95965c0fb12f41751cfcb51b?s=256&d=identicon&r=PG",
                    "display_name": "smihael",
                    "link": "https://stackoverflow.com/users/822644/smihael"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1466267942,
                "post_id": 37897475,
                "comment_id": 63251609,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1466310232,
                "last_edit_date": 1466310232,
                "creation_date": 1466276442,
                "answer_id": 37900597,
                "question_id": 37897475,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The following collects all the relevant version numbers, and determines the &quot;maximum&quot; value using the filter defined here as &quot;lexmax&quot;:\r\n\r\n    jq --arg QID &quot;$QID&quot; --arg PID &quot;$PID&quot; &#39;\r\n      def lexmax:\r\n        map( split(&quot;.&quot;)\r\n             | map(if test(&quot;^[0-9]*$&quot;) then tonumber else . end) )\r\n      | max | map(tostring) | join(&quot;.&quot;);\r\n\r\n      .entities | .[$QID] | .claims | .[$PID]\r\n      | map(.mainsnak.datavalue.value)\r\n      | lexmax&#39;\r\n\r\nThe result with QID=Q13166 PID=P348 is\r\n\r\n    &quot;4.5.2&quot;\r\n\r\n\r\nIf you want to use `.rank == &quot;preferred&quot;` as a selection criterion, you could use the following:\r\n\r\n    def lexmax:\r\n      map( split(&quot;.&quot;)\r\n           | map(if test(&quot;^[0-9]*$&quot;) then tonumber else . end) )\r\n      | max | map(tostring) | join(&quot;.&quot;);\r\n    \r\n    def when(condition; action):\r\n      if condition? // null then action else . end;\r\n    \r\n    .entities | .[$QID] | .claims | .[ $PID ]\r\n    | map( select(when(has(&quot;rank&quot;); .rank == &quot;preferred&quot;))\r\n           | .mainsnak.datavalue.value)\r\n    | lexmax\r\n\r\nOr perhaps you won&#39;t need to use lexmax ...\r\n\r\n\r\n\r\n",
                "title": "How to get latest version of certain software using Wikidata?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1646647556,
        "creation_date": 1466256286,
        "last_edit_date": 1646647556,
        "question_id": 37897475,
        "body_markdown": "I use following command to get (latest) version of certain software from Wikidata from the command line using `jq` as JSON parser.\r\n\r\n    curl -sL &quot;http://www.wikidata.org/w/api.php?action=wbgetentities&amp;ids=$QID&amp;languages=en&amp;format=json&quot; |\r\n    jq &quot;.entities.$QID.claims.$PID&quot;&quot;[0].mainsnak.datavalue.value&quot; \r\n\r\nwhere `$QID` is the ID of a Wikidata entry, and `$PID` the ID of the property we want to print (in this case software version [&quot;P348&quot;][1]).\r\n\r\nThat usually works fine, since usually the first claim (`[0]`) for `P348` is the newest version, but for example for &quot;[Q13166][2]&quot; (WordPress), we have several claims about software version. How to get the newest stable one instead of the first claim? \r\n\r\nI probably should (in the case we have more than one claim), find the ith claim, where version type &quot;[P548][3]&quot; equals to stable version &quot;[Q12355314][4]&quot;. Or find out the clam that has preferred rank. How to do that with jq? Is there an easier way, such as for example sending an SPARQL query to [query.wikidata.org][5]?\r\n\r\n  [1]: https://www.wikidata.org/wiki/Property:P348\r\n  [2]: https://www.wikidata.org/wiki/Q13166\r\n  [3]: https://www.wikidata.org/wiki/Property:P548\r\n  [4]: https://www.wikidata.org/wiki/Q12355314\r\n  [5]: https://query.wikidata.org",
        "link": "https://stackoverflow.com/questions/37897475/how-to-get-latest-version-of-certain-software-using-wikidata",
        "title": "How to get latest version of certain software using Wikidata?"
    },
    {
        "tags": [
            "arrays",
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1466280056,
                "last_edit_date": 1466280056,
                "creation_date": 1466267345,
                "answer_id": 37899200,
                "question_id": 37898311,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Select only the values in `a` that are different from all values in `b`.\r\n\r\n    jq -n --argfile a file0.json --argfile b file1.json &#39;\r\n      $a.d.aaData[].a as $a \r\n      | select([$b[].b]\r\n      | all(. != $a))\r\n      | {key: $a}&#39;",
                "title": "Using jq, how to subtract 2 arrays with different keys and values from two JSON files?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1503876053,
                "creation_date": 1503876053,
                "answer_id": 45910165,
                "question_id": 37898311,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a solution which uses the jq `-` array difference operator:\r\n\r\n\r\n        [ $file0.d.aaData[] | {key:.a} ]\r\n      - [ $file1[]          | {key:.b} ]\r\n    | .[]    \r\n\r\n\r\nAssuming `filter.json` contains this filter then\r\n\r\n    jq -M -n --argfile file0 file0.json --argfile file1 file1.json -f filter.json\r\n\r\nproduces\r\n\r\n    {\r\n      &quot;key&quot;: 3\r\n    }\r\n    {\r\n      &quot;key&quot;: 4\r\n    }\r\n",
                "title": "Using jq, how to subtract 2 arrays with different keys and values from two JSON files?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1503876053,
        "creation_date": 1466261756,
        "question_id": 37898311,
        "body_markdown": "This sounds like a basic question but I have been searching for a better solution for some time already...\r\n\r\nI have the following files:\r\n\r\n**`file0.json:`**\r\n\r\n    { \r\n       &quot;d&quot;: {\r\n       &quot;aaData&quot;: [ \r\n                  {&quot;a&quot;:1}, \r\n                  {&quot;a&quot;:2},\r\n                  {&quot;a&quot;:3},\r\n                  {&quot;a&quot;:4}\r\n                 ]\r\n            }\r\n    }\r\n\r\nand\r\n\r\n**`file1.json:`**\r\n\r\n    [ \r\n        {&quot;b&quot;:1},\r\n        {&quot;b&quot;:2},\r\n        {&quot;b&quot;:7}\r\n    ]\r\n\r\nand I want a subtraction between then with the expected result:\r\n\r\n    {\r\n      &quot;key&quot;: 3\r\n    }\r\n    {\r\n      &quot;key&quot;: 4\r\n    }\r\n\r\nI thought of the following command would do the job:\r\n\r\n`bash$ jq -s &#39;[.d.aaData[].a] - [.[].b] | { key: .}&#39; file0.json file1.json`\r\n\r\nbut it gives me the following error:\r\n\r\n`Cannot index array with string &quot;b&quot;`\r\n\r\nWhat makes sense, since `[.[1].b]` would&#39;t create an array, but something like `[1][2][7]` \r\n\r\n\r\nthe only way I managed to get the expected result was coding in my bash script the dirty solution:\r\n\r\n    bash$ a=$(jq &#39;[.d.aaData[].a] | {key1: .}&#39; file0.json)\r\n    bash$ b=$(jq &#39;[.[].b] | {key2: . }&#39; file1.json)\r\n    bash$ c=$(echo -n $a,$b)\r\n    bash$ echo $c\r\n    { &quot;key1&quot;: [ 1, 2, 3, 4 ] },{ &quot;key2&quot;: [ 1, 2, 7 ] }\r\n    bash$ d=${c//&quot;},{&quot;/&quot;,&quot;}\r\n    bash$ echo $d\r\n    { &quot;key1&quot;: [ 1, 2, 3, 4 ] , &quot;key2&quot;: [ 1, 2, 7 ] }\r\n    bash$ echo -n $d | jq &#39;.key1 - .key2 | { key: .[] }&#39;\r\n    {\r\n      &quot;key&quot;: 3\r\n    }\r\n    {\r\n      &quot;key&quot;: 4\r\n    }\r\n\r\nI&#39;m quite sure there is a better way to do it with jq.... just can&#39;t find how...\r\n\r\n",
        "link": "https://stackoverflow.com/questions/37898311/using-jq-how-to-subtract-2-arrays-with-different-keys-and-values-from-two-json",
        "title": "Using jq, how to subtract 2 arrays with different keys and values from two JSON files?"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 57200,
                    "reputation": 158728,
                    "user_id": 171318,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/ePRKy.jpg?s=256",
                    "display_name": "hek2mgl",
                    "link": "https://stackoverflow.com/users/171318/hek2mgl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1466328072,
                "post_id": 37904796,
                "comment_id": 63263780,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 236116,
                    "reputation": 1272,
                    "user_id": 503397,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://www.gravatar.com/avatar/8617dad2d39cab1d939a0557e0b1ec51?s=256&d=identicon&r=PG",
                    "display_name": "apines",
                    "link": "https://stackoverflow.com/users/503397/apines"
                },
                "reply_to_user": {
                    "account_id": 57200,
                    "reputation": 158728,
                    "user_id": 171318,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/ePRKy.jpg?s=256",
                    "display_name": "hek2mgl",
                    "link": "https://stackoverflow.com/users/171318/hek2mgl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1466328157,
                "post_id": 37904796,
                "comment_id": 63263792,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 57200,
                    "reputation": 158728,
                    "user_id": 171318,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/ePRKy.jpg?s=256",
                    "display_name": "hek2mgl",
                    "link": "https://stackoverflow.com/users/171318/hek2mgl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1466328226,
                "post_id": 37904796,
                "comment_id": 63263808,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 236116,
                    "reputation": 1272,
                    "user_id": 503397,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://www.gravatar.com/avatar/8617dad2d39cab1d939a0557e0b1ec51?s=256&d=identicon&r=PG",
                    "display_name": "apines",
                    "link": "https://stackoverflow.com/users/503397/apines"
                },
                "reply_to_user": {
                    "account_id": 57200,
                    "reputation": 158728,
                    "user_id": 171318,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/ePRKy.jpg?s=256",
                    "display_name": "hek2mgl",
                    "link": "https://stackoverflow.com/users/171318/hek2mgl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1466328269,
                "post_id": 37904796,
                "comment_id": 63263818,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 57200,
                    "reputation": 158728,
                    "user_id": 171318,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/ePRKy.jpg?s=256",
                    "display_name": "hek2mgl",
                    "link": "https://stackoverflow.com/users/171318/hek2mgl"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1466328318,
                "post_id": 37904796,
                "comment_id": 63263837,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 57200,
                    "reputation": 158728,
                    "user_id": 171318,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/ePRKy.jpg?s=256",
                    "display_name": "hek2mgl",
                    "link": "https://stackoverflow.com/users/171318/hek2mgl"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1466330049,
                "post_id": 37904796,
                "comment_id": 63264244,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 6,
                "is_accepted": true,
                "score": 6,
                "last_activity_date": 1466330477,
                "creation_date": 1466330477,
                "answer_id": 37906010,
                "question_id": 37904796,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Use parenthesis around dynamic keys:\r\n\r\n    jq --arg p &quot;$PROFILE&quot; --arg u &quot;$U&quot; --arg c &quot;$C&quot; --arg w &quot;$WH&quot; \\\r\n    &#39;. + {($p): {&quot;user&quot;: $u, &quot;channel&quot;: $c, &quot;hook&quot;: $w}}&#39; &quot;$CONF_FILE&quot;",
                "title": "jq: adding nested object to a JSON"
            },
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1504060257,
                "creation_date": 1504060257,
                "answer_id": 45950986,
                "question_id": 37904796,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a script that demonstrates a solution using [env](https://stedolan.github.io/jq/manual/#$ENV,env) to access variables passed via the environment: \r\n\r\n    #!/bin/bash\r\n    \r\n    CONF_FILE=data.json\r\n\r\n    export P=test\r\n    export U=user3\r\n    export C=channel3\r\n    export W=hook3\r\n    \r\n    jq &#39;\r\n        .[env.P] = {\r\n           user:    env.U, \r\n           channel: env.C, \r\n           hook:    env.W\r\n        }\r\n    &#39; &quot;$CONF_FILE&quot;\r\n    \r\nIf `data.json` contains the sample data this script should produce the output\r\n\r\n    {\r\n      &quot;profile1&quot;: {\r\n        &quot;user&quot;: &quot;user1&quot;,\r\n        &quot;channel&quot;: &quot;channel1&quot;,\r\n        &quot;hook&quot;: &quot;hook1&quot;\r\n      },\r\n      &quot;default&quot;: {\r\n        &quot;user&quot;: &quot;user1&quot;,\r\n        &quot;channel&quot;: &quot;channel1&quot;,\r\n        &quot;hook&quot;: &quot;hook2&quot;\r\n      },\r\n      &quot;test&quot;: {\r\n        &quot;user&quot;: &quot;user3&quot;,\r\n        &quot;channel&quot;: &quot;channel3&quot;,\r\n        &quot;hook&quot;: &quot;hook3&quot;\r\n      }\r\n    }\r\n",
                "title": "jq: adding nested object to a JSON"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1743647342,
                "creation_date": 1743647342,
                "answer_id": 79551882,
                "question_id": 37904796,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you happen on this like I did and you need to place Bash variables into JQ, I always wrap my variables with `&quot;&#39;&quot;` .\r\n\r\nLike so:\r\n\r\n\r\n```bash\r\nvarjson=&#39;{[&quot;key1&quot;:&quot;val1&quot;,&quot;key2&quot;:&quot;val2&quot;]}&#39;\r\nfilt=&#39;key2&#39;\r\njq -r &#39;&quot;&#39;&quot;$filt&quot;&#39;&quot;&#39; &lt;&lt;&lt; &quot;$varjson&quot; # here doc \r\n```\r\n\r\n\r\nReturns:\r\n\r\n```\r\n&quot;val2&quot;\r\n```\r\n\r\nNote the variable is wrapped in **`&quot;&#39;&quot;`**, which is double-quote single-quote double-quote on both sides.\r\n\r\nThis works because the outer double quote escapes JQ&#39;s first pass and then the single quotes escape JQ to let Bash do it&#39;s expansion and then the final double quotes are for the JQ string interpreter.\r\n\r\nAlso works for more complex filters like this:  \r\n`jq -rc &#39;.[] | select(.name == &quot;&#39;&quot;$username&quot;&#39;&quot;)&#39; &lt;&lt;&lt; &quot;$json&quot;`\r\n\r\nYou can substitute keys as well, by omitting the inner double quotes which gives you strict literal:\r\n\r\n\r\n```bash\r\nkey=.name # NOTE: JQ still requires the &#39;.&#39; in front of your filter key \r\nparam=&#39;John Smith&#39; \r\njq -rc &#39;[] | select(&quot;&#39;$key&#39;&quot; == &quot;&#39;&quot;$param&quot;&#39;&quot;)&#39; &lt;&lt;&lt; &quot;$json&quot; \r\n```\r\n\r\n\r\nWill return the object selected by the variable key &quot;.name&quot; IF it matches &quot;John Smith&quot;.",
                "title": "jq: adding nested object to a JSON"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 2,
        "last_activity_date": 1743647342,
        "creation_date": 1466320159,
        "last_edit_date": 1466324080,
        "question_id": 37904796,
        "body_markdown": "I have a json file containing several profiles:\r\n\r\n    {\r\n      &quot;profile1&quot;: {\r\n        &quot;user&quot;: &quot;user1&quot;,\r\n        &quot;channel&quot;: &quot;channel1&quot;,\r\n        &quot;hook&quot;: &quot;hook1&quot;\r\n      },\r\n      &quot;default&quot;: {\r\n        &quot;user&quot;: &quot;user1&quot;,\r\n        &quot;channel&quot;: &quot;channel1&quot;,\r\n        &quot;hook&quot;: &quot;hook2&quot;\r\n      }\r\n    }\r\n\r\nI want to use jq to insert another profile, &quot;test&quot;, so that the end result will be\r\n\r\n    {\r\n      &quot;profile1&quot;: {\r\n        &quot;user&quot;: &quot;user1&quot;,\r\n        &quot;channel&quot;: &quot;channel1&quot;,\r\n        &quot;hook&quot;: &quot;hook1&quot;\r\n      },\r\n      &quot;default&quot;: {\r\n        &quot;user&quot;: &quot;user1&quot;,\r\n        &quot;channel&quot;: &quot;channel1&quot;,\r\n        &quot;hook&quot;: &quot;hook2&quot;\r\n      },\r\n      &quot;test&quot;: {\r\n        &quot;user&quot;: &quot;user3&quot;,\r\n        &quot;channel&quot;: &quot;channel3&quot;,\r\n        &quot;hook&quot;: &quot;hook3&quot;\r\n      }\r\n    }\r\n\r\nDirectly in the command line I can do it with:\r\n\r\n    cat filename | \r\n        jq  &#39;.+  { &quot;test&quot;: { &quot;user&quot;: &quot;u3&quot;, &quot;channel&quot; : &quot;c3&quot;, &quot;hook&quot;: &quot;w3&quot; } }&#39;\r\n\r\nBut when I try it in my bash script:\r\n\r\n    cat &quot;$CONF_FILE&quot; | \r\n        jq --arg p &quot;$PROFILE&quot; --arg u &quot;$U&quot; --arg c &quot;$C&quot; --arg w &quot;$WH&quot; \\\r\n        &#39;.+ { $p: { &quot;user&quot;: $u, &quot;channel&quot;: $c, &quot;hook&quot;: $w } }&#39; `\r\n\r\nI&#39;m getting the following error:\r\n\r\n    jq: error: syntax error, unexpected &#39;:&#39;, expecting &#39;}&#39; (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n    .+ { $p: { &quot;user&quot;: $u, &quot;channel&quot;: $c, &quot;hook&quot;: $w } }\r\n    jq: error: syntax error, unexpected &#39;}&#39;, expecting $end (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n    .+ { $p: { &quot;user&quot;: $u, &quot;channel&quot;: $c, &quot;hook&quot;: $w } }\r\n    jq: 2 compile errors\r\n\r\n\r\nI&#39;ve tried surrounding the variable with quotes but then I get just the string $p:\r\n\r\n    cat &quot;$CONF_FILE&quot; | \r\n        jq --arg p &quot;$PROFILE&quot; --arg u &quot;$U&quot; --arg c &quot;$C&quot; --arg w &quot;$WH&quot; \\\r\n        &#39;.+ { &quot;$p&quot;: { &quot;user&quot;: $u, &quot;channel&quot;: $c, &quot;hook&quot;: $w } }&#39; \r\n\r\nresult:\r\n\r\n    {\r\n      &quot;profile1&quot;: {\r\n        &quot;user&quot;: &quot;user1&quot;,\r\n        &quot;channel&quot;: &quot;channel1&quot;,\r\n        &quot;hook&quot;: &quot;hook1&quot;\r\n      },\r\n      &quot;default&quot;: {\r\n        &quot;user&quot;: &quot;user1&quot;,\r\n        &quot;channel&quot;: &quot;channel1&quot;,\r\n        &quot;hook&quot;: &quot;hook2&quot;\r\n      },\r\n      &quot;$p&quot;: {\r\n        &quot;user&quot;: &quot;user3&quot;,\r\n        &quot;channel&quot;: &quot;channel3&quot;,\r\n        &quot;hook&quot;: &quot;hook3&quot;\r\n      }\r\n    }\r\n\r\n&lt;br&gt;&lt;br&gt;\r\n\r\n**EDIT:** I have found what seems a temporary solution, converting the object to an array, editing the value (now the profile name is a value and not a key) and converting the array back to an object:\r\n\r\n    cat &quot;$CONF_FILE&quot; | \r\n        jq --arg p &quot;$PROFILE&quot; --arg u &quot;$U&quot; --arg c &quot;$C&quot; --arg w &quot;$WH&quot; \\\r\n        &#39;to_entries | .+ [ { &quot;key&quot;: $p, &quot;value&quot;: { &quot;user&quot;: $u, &quot;channel&quot;: $c, &quot;hook&quot;: $w } } ] | from_entries&#39;\r\n\r\nIt seems crude, but it works. I am still hoping for a better solution...",
        "link": "https://stackoverflow.com/questions/37904796/jq-adding-nested-object-to-a-json",
        "title": "jq: adding nested object to a JSON"
    },
    {
        "tags": [
            "elasticsearch",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 8660316,
                    "reputation": 108,
                    "user_id": 6483024,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/91a1f7cf816d4cb3607d69fefe0c9113?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "FJunqueira",
                    "link": "https://stackoverflow.com/users/6483024/fjunqueira"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1466636625,
                "post_id": 37958233,
                "comment_id": 63405015,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1466637066,
                "last_edit_date": 1495535645,
                "creation_date": 1466637066,
                "answer_id": 37979689,
                "question_id": 37958233,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "This sounds like an issue with the document sent to jq. ElasticSearch requires the outermost document to be a JSON object and not a JSON array or scalar value. Just make sure it is...\r\n\r\nCheck this out: https://stackoverflow.com/questions/35213472/elasticsearch-error-while-sending-data",
                "title": "Elasticsearch bulk index &quot;mapper_parsing_exception&quot;"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1466637066,
        "creation_date": 1466567413,
        "question_id": 37958233,
        "body_markdown": "I am trying to bulk index using jq, and having trouble.\r\n\r\nI enter the following using the terminal (I&#39;m using Ubuntu 16.04)\r\n\r\n    cat practice.json | jq -c &#39;.[] | {&quot;index&quot;: {&quot;_index&quot;: &quot;text&quot;, &quot;_type&quot;: &quot;text&quot;, &quot;_id&quot;: &quot;text&quot;}}, .&#39; | curl -XPOST localhost:9200/_bulk --data-binary @-\r\n This is the error that I get:\r\n\r\n    {&quot;type&quot;:&quot;mapper_parsing_exception&quot;,&quot;reason&quot;:&quot;failed to parse&quot;,&quot;caused_by&quot;:{&quot;type&quot;:&quot;not_x_content_exception&quot;,&quot;reason&quot;:&quot;not_x_content_exception: Compressor detection can only be called on some xcontent bytes or compressed xcontent bytes&quot;}}}}\r\n\r\nOddly, I was able to get similar code (I forgot to save what I did, but I think it is the same as this) to work. I couldn&#39;t find anyone with the same problem here or elsewhere. Any idea on how to fix this?",
        "link": "https://stackoverflow.com/questions/37958233/elasticsearch-bulk-index-mapper-parsing-exception",
        "title": "Elasticsearch bulk index &quot;mapper_parsing_exception&quot;"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1466765184,
                "last_edit_date": 1466765184,
                "creation_date": 1466760741,
                "answer_id": 38010100,
                "question_id": 38007722,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "So you want to produce this output?\r\n\r\n    [\r\n      {\r\n        &quot;key&quot;: 1465974236000,\r\n        &quot;value&quot;: 14\r\n      },\r\n      {\r\n        &quot;key&quot;: 1465975137000,\r\n        &quot;value&quot;: 16\r\n      }\r\n    ]\r\n\r\nThe following will do just that:\r\n\r\n    .aggregations[].buckets \r\n      | map({key: .key, value: .search.value})\r\n\r\nAnd from a terminal:\r\n\r\n    jq &#39;.aggregations[].buckets \r\n       | map({key: .key, value: .search.value})&#39; input.json\r\n",
                "title": "Create an object with specified indexes"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1503877449,
                "creation_date": 1503877449,
                "answer_id": 45910275,
                "question_id": 38007722,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a slightly simpler solution\r\n\r\n    [ .aggregations[].buckets[] | {key, value:.search.value} ]",
                "title": "Create an object with specified indexes"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1503877449,
        "creation_date": 1466752672,
        "last_edit_date": 1466779499,
        "question_id": 38007722,
        "body_markdown": "I am trying to use for loop for every object using jq. \r\nSample Input generated by Elasticsearch\r\n\r\n    {\r\n      &quot;took&quot;: 202,\r\n      &quot;timed_out&quot;: false,\r\n      &quot;aggregations&quot;: {\r\n        &quot;aggsDateHistogram&quot;: {\r\n          &quot;buckets&quot;: [\r\n            {\r\n              &quot;key&quot;: 1465974236000,\r\n              &quot;search&quot;: {\r\n                &quot;value&quot;: 14\r\n              }\r\n            },\r\n            {\r\n              &quot;key&quot;: 1465975137000,\r\n              &quot;search&quot;: {\r\n                &quot;value&quot;: 16\r\n              }\r\n            }\r\n          ]\r\n        }\r\n      }\r\n    }\r\n\r\nI want to have an object that has a key value and corresponding value of value index from search.\r\n\r\n    { &quot;date&quot;: .aggregations.aggsDateHistogram.buckets[].key, &quot;value&quot;: .aggregations.aggsDateHistogram.buckets[].search.value }\r\n\r\nThis gives me an object but with cartesian product, but I only want to have values like\r\n\r\n    key[1] : search[1].value\r\n    key[2] : search[2].value\r\n",
        "link": "https://stackoverflow.com/questions/38007722/create-an-object-with-specified-indexes",
        "title": "Create an object with specified indexes"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 155638,
                    "reputation": 479,
                    "user_id": 372429,
                    "user_type": "registered",
                    "accept_rate": 8,
                    "profile_image": "https://www.gravatar.com/avatar/416c63cb7f6e15b4a11680121dff3e84?s=256&d=identicon&r=PG",
                    "display_name": "archcutbank",
                    "link": "https://stackoverflow.com/users/372429/archcutbank"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1485275608,
                "post_id": 38061346,
                "comment_id": 70853584,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 4699984,
                    "reputation": 2947,
                    "user_id": 3803800,
                    "user_type": "registered",
                    "accept_rate": 50,
                    "profile_image": "https://www.gravatar.com/avatar/98e13329d13358906f7c82b3c8a29da4?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Mauricio Trajano",
                    "link": "https://stackoverflow.com/users/3803800/mauricio-trajano"
                },
                "reply_to_user": {
                    "account_id": 155638,
                    "reputation": 479,
                    "user_id": 372429,
                    "user_type": "registered",
                    "accept_rate": 8,
                    "profile_image": "https://www.gravatar.com/avatar/416c63cb7f6e15b4a11680121dff3e84?s=256&d=identicon&r=PG",
                    "display_name": "archcutbank",
                    "link": "https://stackoverflow.com/users/372429/archcutbank"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1485444671,
                "post_id": 38061346,
                "comment_id": 70935955,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 459032,
                    "reputation": 696,
                    "user_id": 859269,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/a0993fb19c9da5dbb8cfcadcb4af3e77?s=256&d=identicon&r=PG",
                    "display_name": "Sagar Kulkarni",
                    "link": "https://stackoverflow.com/users/859269/sagar-kulkarni"
                },
                "edited": false,
                "score": 25,
                "creation_date": 1637775450,
                "post_id": 38061346,
                "comment_id": 123918271,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 183,
                "is_accepted": true,
                "score": 183,
                "last_activity_date": 1467054418,
                "creation_date": 1467054418,
                "answer_id": 38061430,
                "question_id": 38061346,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Use slurp mode:\r\n\r\n&gt;       o   --slurp/-s:\r\n&gt;\r\n&gt;           Instead of running the filter for each JSON object\r\n&gt;           in the input, read the entire input stream into a large\r\n&gt;           array and run the filter just once.\r\n\r\n\r\n    $ jq -s &#39;.&#39; &lt; tmp.json\r\n    [\r\n      {\r\n        &quot;name&quot;: &quot;John&quot;,\r\n        &quot;email&quot;: &quot;john@company.com&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;Brad&quot;,\r\n        &quot;email&quot;: &quot;brad@company.com&quot;\r\n      }\r\n    ]",
                "title": "jq: output array of json objects"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 128,
        "last_activity_date": 1467062644,
        "creation_date": 1467054063,
        "last_edit_date": 1467062644,
        "question_id": 38061346,
        "body_markdown": "Say I have the input:\r\n\r\n    {\r\n        &quot;name&quot;: &quot;John&quot;,\r\n        &quot;email&quot;: &quot;john@company.com&quot;\r\n    }\r\n    {\r\n        &quot;name&quot;: &quot;Brad&quot;,\r\n        &quot;email&quot;: &quot;brad@company.com&quot;\r\n    }\r\n\r\nHow do I get the output:\r\n\r\n    [\r\n        {\r\n            &quot;name&quot;: &quot;John&quot;,\r\n            &quot;email&quot;: &quot;john@company.com&quot;\r\n        },\r\n        {\r\n            &quot;name&quot;: &quot;Brad&quot;,\r\n            &quot;email&quot;: &quot;brad@company.com&quot;\r\n        }\r\n    ]\r\n\r\nI tried both:\r\n\r\n    jq &#39;[. | {name, email}]&#39;\r\n\r\nand \r\n\r\n    jq &#39;. | [{name, email}]&#39;\r\n\r\nwhich both gave me the output\r\n\r\n    [\r\n        {\r\n            &quot;name&quot;: &quot;John&quot;,\r\n            &quot;email&quot;: &quot;john@company.com&quot;\r\n        }\r\n    ]\r\n    [\r\n        {\r\n            &quot;name&quot;: &quot;Brad&quot;,\r\n            &quot;email&quot;: &quot;brad@company.com&quot;\r\n        }\r\n    ]\r\n\r\nI also saw no options for an array output in the documentations, any help appreciated",
        "link": "https://stackoverflow.com/questions/38061346/jq-output-array-of-json-objects",
        "title": "jq: output array of json objects"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1467140082,
                "creation_date": 1467140082,
                "answer_id": 38084161,
                "question_id": 38081648,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You could do this:\r\n\r\n    $ jq -r &#39;.[] | [.AAA] + (.images[] | [.BBB]) | @csv&#39; EXAMPLE.json",
                "title": "jq Filter: extracting parent values + unique values of array"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1503878245,
                "creation_date": 1503878245,
                "answer_id": 45910337,
                "question_id": 38081648,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "A slight modification of [fkrents](https://stackoverflow.com/users/6524361/fkrents) initial attempt:\r\n\r\n    .[] | [.AAA, .images[].BBB] | @csv\r\n\r\nleads to this solution:\r\n\r\n    .[] | .AAA as $a | .images[].BBB | [$a, .] | @csv",
                "title": "jq Filter: extracting parent values + unique values of array"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1504606090,
        "creation_date": 1467131542,
        "last_edit_date": 1504606090,
        "question_id": 38081648,
        "body_markdown": "Here is a JSON example:\r\n\r\n    [\r\n      {\r\n        &quot;AAA&quot;: &quot;111&quot;,\r\n        &quot;images&quot;: [\r\n          {\r\n            &quot;BBB&quot;: &quot;some_value1&quot;\r\n          },\r\n          {\r\n            &quot;BBB&quot;: &quot;some_value2&quot;\r\n          },\r\n          {\r\n            &quot;BBB&quot;: &quot;some_value3&quot;\r\n          }\r\n        ]\r\n      },\r\n      {\r\n        &quot;AAA&quot;: &quot;222&quot;,\r\n        &quot;images&quot;: [\r\n          {\r\n            &quot;BBB&quot;: &quot;some_value4&quot;\r\n          },\r\n          {\r\n            &quot;BBB&quot;: &quot;some_value5&quot;\r\n          },\r\n          {\r\n            &quot;BBB&quot;: &quot;some_value6&quot;\r\n          }\r\n        ]\r\n      }\r\n    ]\r\n\r\nThe following filter almost solves the required task:\r\n\r\n    cat EXAMPLE.json | jq -r &quot;.[] | [.AAA, .images[].BBB] | @csv&quot;\r\n\r\nStill, it only gives the result like this:\r\n\r\n    &quot;111&quot;,&quot;some_value1&quot;,&quot;some_value2&quot;,&quot;some_value3&quot;\r\n    &quot;222&quot;,&quot;some_value4&quot;,&quot;some_value5&quot;,&quot;some_value6&quot;\r\n\r\nThe question is: **how** to change my jq filter to receive following result:\r\n\r\n    &quot;111&quot;,&quot;some_value1&quot;\r\n    &quot;111&quot;,&quot;some_value2&quot;\r\n    &quot;111&quot;,&quot;some_value3&quot;\r\n    &quot;222&quot;,&quot;some_value4&quot;\r\n    &quot;222&quot;,&quot;some_value5&quot;\r\n    &quot;222&quot;,&quot;some_value6&quot;\r\n\r\nAppreciate any help.",
        "link": "https://stackoverflow.com/questions/38081648/jq-filter-extracting-parent-values-unique-values-of-array",
        "title": "jq Filter: extracting parent values + unique values of array"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1467248117,
                "creation_date": 1467248117,
                "answer_id": 38112326,
                "question_id": 38111625,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The reason your script provides the wrong output is that JSON objects do not have a specific order by their keys, and `jq` built-ins are not stable with regards to what this ordering is. This means that when you do `(.pricing | keys)` and `[.pricing[].linux.ondemand | .]`, the order of the keys in the former does not match the order of the values in the latter.\r\n\r\nA simplified and working version of your jq program goes as follows:\r\n\r\n    jq &#39;.[] | .instance_type as $it | .pricing | with_entries(.key |= &quot;\\(.)|\\($it)&quot; | .value |= .linux.ondemand)&#39;\r\n\r\nThis jq program uses `with_entries` to transform a JSON object into a JSON array of `{key, value}` objects and perform a transformation on the key-value pairs before reassembling the original object.",
                "title": "Parsing EC2 on-demand pricing from ec2instances.info"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1503879153,
                "creation_date": 1503879153,
                "answer_id": 45910404,
                "question_id": 38111625,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a solution which uses **keys_unsorted** to preserve the ordering of the keys in the original `.pricing` object.\r\n\r\n\r\n        .[]\r\n      | .instance_type as $instance_type\r\n      | .pricing\r\n      | [\r\n            keys_unsorted[] as $k\r\n          | .[$k].linux.ondemand\r\n          | {(&quot;\\($k)|\\($instance_type)&quot;): .}\r\n        ]\r\n      | add\r\n",
                "title": "Parsing EC2 on-demand pricing from ec2instances.info"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1503879153,
        "creation_date": 1467242434,
        "last_edit_date": 1467263054,
        "question_id": 38111625,
        "body_markdown": "I am trying to use `curl` and `jq` to parse the AWS EC2 on-demand pricing and construct a JSON map suitable for use in a Terraform module.\r\n\r\nThe script that I came up with looks like this, but it doesn&#39;t seem to be correct:\r\n\r\n    curl --silent --show-error &#39;https://raw.githubusercontent.com/powdahound/ec2instances.info/master/www/instances.json&#39; |\r\n    jq &#39;.[]\r\n        | .instance_type as $instance_type\r\n        | (.pricing | keys) as $keys \r\n        | [.pricing[].linux.ondemand | .] as $values\r\n        | reduce range(0; $keys|length) as $i \r\n            ({}; . + { ($keys[$i] + &quot;|&quot; + $instance_type): $values[$i] })&#39;\r\n\r\nWhat am I doing wrong? Here is a smaller code sample to illustrate the problem:\r\n\r\n    curl --silent --show-error &#39;https://gist.githubusercontent.com/joshuaspence/0904a6ce25f8830d9ae2eac8fc44fc7a/raw/b24600ab2e536556a74f4dbb45e2ddaa432d430e/sample.json&#39; |\r\n    jq &#39;.[]\r\n        | .instance_type as $instance_type\r\n        | (.pricing | keys) as $keys\r\n        | [.pricing[].linux.ondemand | .] as $values\r\n        | reduce range(0; $keys|length) as $i\r\n            ({}; . + { ($keys[$i] + &quot;|&quot; + $instance_type): $values[$i] })&#39;\r\n\r\nThe expected output from the above command is:\r\n\r\n    {\r\n      &quot;ap-south-1|m1.small&quot;: &quot;N/A&quot;,\r\n      &quot;us-east-1|m1.small&quot;: &quot;0.061&quot;,\r\n      &quot;sa-east-1|m1.small&quot;: &quot;0.058&quot;,\r\n      &quot;ap-northeast-2|m1.small&quot;: &quot;0.058&quot;,\r\n      &quot;ap-southeast-2|m1.small&quot;: &quot;0.058&quot;,\r\n      &quot;us-west-2|m1.small&quot;: &quot;0.044&quot;,\r\n      &quot;us-gov-west-1|m1.small&quot;: &quot;0.053&quot;,\r\n      &quot;us-west-1|m1.small&quot;: &quot;0.047&quot;,\r\n      &quot;eu-central-1|m1.small&quot;: &quot;N/A&quot;,\r\n      &quot;eu-west-1|m1.small&quot;: &quot;0.047&quot;\r\n    }\r\n    {\r\n      &quot;ap-south-1|m1.medium&quot;: &quot;N/A&quot;,\r\n      &quot;us-east-1|m1.medium&quot;: &quot;0.087&quot;,\r\n      &quot;ap-northeast-1|m1.medium&quot;: &quot;0.122&quot;,\r\n      &quot;sa-east-1|m1.medium&quot;: &quot;0.117&quot;,\r\n      &quot;ap-northeast-2|m1.medium&quot;: &quot;N/A&quot;,\r\n      &quot;ap-southeast-1|m1.medium&quot;: &quot;0.117&quot;,\r\n      &quot;ap-southeast-2|m1.medium&quot;: &quot;0.117&quot;,\r\n      &quot;us-west-2|m1.medium&quot;: &quot;0.087&quot;,\r\n      &quot;us-gov-west-1|m1.medium&quot;: &quot;0.106&quot;,\r\n      &quot;us-west-1|m1.medium&quot;: &quot;0.095&quot;,\r\n      &quot;us-central-1|m1.medium&quot;: &quot;N/A&quot;,\r\n      &quot;us-west-1|m1.medium&quot;: &quot;0.095&quot;\r\n    }\r\n\r\nThe actual output is:\r\n\r\n    {\r\n      &quot;ap-northeast-2|m1.small&quot;: &quot;N/A&quot;,\r\n      &quot;ap-south-1|m1.small&quot;: &quot;0.061&quot;,\r\n      &quot;ap-southeast-2|m1.small&quot;: &quot;0.058&quot;,\r\n      &quot;eu-central-1|m1.small&quot;: &quot;0.058&quot;,\r\n      &quot;eu-west-1|m1.small&quot;: &quot;0.058&quot;,\r\n      &quot;sa-east-1|m1.small&quot;: &quot;0.044&quot;,\r\n      &quot;us-east-1|m1.small&quot;: &quot;0.053&quot;,\r\n      &quot;us-gov-west-1|m1.small&quot;: &quot;0.047&quot;,\r\n      &quot;us-west-1|m1.small&quot;: &quot;N/A&quot;,\r\n      &quot;us-west-2|m1.small&quot;: &quot;0.047&quot;\r\n    }\r\n    {\r\n      &quot;ap-northeast-1|m1.medium&quot;: &quot;N/A&quot;,\r\n      &quot;ap-northeast-2|m1.medium&quot;: &quot;0.087&quot;,\r\n      &quot;ap-south-1|m1.medium&quot;: &quot;0.122&quot;,\r\n      &quot;ap-southeast-1|m1.medium&quot;: &quot;0.117&quot;,\r\n      &quot;ap-southeast-2|m1.medium&quot;: &quot;N/A&quot;,\r\n      &quot;eu-central-1|m1.medium&quot;: &quot;0.117&quot;,\r\n      &quot;eu-west-1|m1.medium&quot;: &quot;0.117&quot;,\r\n      &quot;sa-east-1|m1.medium&quot;: &quot;0.087&quot;,\r\n      &quot;us-east-1|m1.medium&quot;: &quot;0.106&quot;,\r\n      &quot;us-gov-west-1|m1.medium&quot;: &quot;0.095&quot;,\r\n      &quot;us-west-1|m1.medium&quot;: &quot;N/A&quot;,\r\n      &quot;us-west-2|m1.medium&quot;: &quot;0.095&quot;\r\n    }",
        "link": "https://stackoverflow.com/questions/38111625/parsing-ec2-on-demand-pricing-from-ec2instances-info",
        "title": "Parsing EC2 on-demand pricing from ec2instances.info"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 52616,
                    "reputation": 1079223,
                    "user_id": 157247,
                    "user_type": "registered",
                    "accept_rate": 91,
                    "profile_image": "https://i.sstatic.net/lUM5Z.jpg?s=256",
                    "display_name": "T.J. Crowder",
                    "link": "https://stackoverflow.com/users/157247/t-j-crowder"
                },
                "edited": false,
                "score": 22,
                "creation_date": 1467286114,
                "post_id": 38121740,
                "comment_id": 63675173,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 207422,
                    "reputation": 67485,
                    "user_id": 457268,
                    "user_type": "registered",
                    "accept_rate": 62,
                    "profile_image": "https://i.sstatic.net/Htrwe.jpg?s=256",
                    "display_name": "k0pernikus",
                    "link": "https://stackoverflow.com/users/457268/k0pernikus"
                },
                "reply_to_user": {
                    "account_id": 52616,
                    "reputation": 1079223,
                    "user_id": 157247,
                    "user_type": "registered",
                    "accept_rate": 91,
                    "profile_image": "https://i.sstatic.net/lUM5Z.jpg?s=256",
                    "display_name": "T.J. Crowder",
                    "link": "https://stackoverflow.com/users/157247/t-j-crowder"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1467286312,
                "post_id": 38121740,
                "comment_id": 63675317,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 174,
                "is_accepted": true,
                "score": 174,
                "last_activity_date": 1467296360,
                "last_edit_date": 1467296360,
                "creation_date": 1467286748,
                "answer_id": 38122029,
                "question_id": 38121740,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "**From the docs:**\r\n\r\n&gt;     jq &#39;.[] | select(.id == &quot;second&quot;)&#39; \r\n&gt; \r\n&gt; **Input** `[{&quot;id&quot;: &quot;first&quot;, &quot;val&quot;: 1}, {&quot;id&quot;: &quot;second&quot;, &quot;val&quot;: 2}]` \r\n&gt; \r\n&gt; **Output** `{&quot;id&quot;: &quot;second&quot;, &quot;val&quot;: 2}`\r\n\r\nI think you can do something like this:\r\n\r\n    jq &#39;.theList[] | select(.id == 2 or .id == 4)&#39; array.json",
                "title": "How to filter array of objects by element property values using jq?"
            },
            {
                "up_vote_count": 29,
                "is_accepted": false,
                "score": 29,
                "last_activity_date": 1507864078,
                "last_edit_date": 1507864078,
                "creation_date": 1467298661,
                "answer_id": 38126806,
                "question_id": 38121740,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You could use `select` within `map`.\r\n\r\n    .theList | map(select(.id == (2, 4)))\r\n\r\nOr more compact:\r\n\r\n    [ .theList[] | select(.id == (2, 4)) ]\r\n\r\nThough written that way is a little inefficient since the expression is duplicated for every value being compared. It&#39;ll be more efficient and possibly more readable written this way:\r\n\r\n    [ .theList[] | select(any(2, 4; . == .id)) ]",
                "title": "How to filter array of objects by element property values using jq?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1504081984,
                "creation_date": 1504081984,
                "answer_id": 45955609,
                "question_id": 38121740,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a solution using [indices](https://stedolan.github.io/jq/manual/#indices\\(s\\)):\r\n\r\n    .theList | [ .[map(.id)|indices(2,4)[]] ]",
                "title": "How to filter array of objects by element property values using jq?"
            },
            {
                "up_vote_count": 10,
                "is_accepted": false,
                "score": 10,
                "last_activity_date": 1507067923,
                "last_edit_date": 1507067923,
                "creation_date": 1507056020,
                "answer_id": 46551318,
                "question_id": 38121740,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Using `select(.id == (2, 4))` here is generally inefficient (see below).\r\n\r\nIf your jq has `IN/1`, then it can be used to achieve a more efficient solution:\r\n\r\n    .theList[] | select( .id | IN(2,3))\r\n\r\nIf your jq does not have `IN/1`, then you can define it as follows: \r\n\r\n    def IN(s): first(select(s == .)) // false;\r\n\r\n**Efficiency**\r\n\r\nOne way to see the inefficiency is to use `debug`.  The following expression, for example, results in 10 calls to `debug`, whereas only 9 checks for equality are actually needed:\r\n\r\n    .theList[] | select( (.id == (2,3)) | debug )\r\n\r\n    [&quot;DEBUG:&quot;,false]\r\n    [&quot;DEBUG:&quot;,false]\r\n    [&quot;DEBUG:&quot;,true]\r\n    {\r\n      &quot;id&quot;: 2,\r\n      &quot;name&quot;: &quot;Fritz&quot;\r\n    }\r\n    [&quot;DEBUG:&quot;,false]\r\n    [&quot;DEBUG:&quot;,false]\r\n    [&quot;DEBUG:&quot;,true]\r\n    {\r\n      &quot;id&quot;: 3,\r\n      &quot;name&quot;: &quot;Walter&quot;\r\n    }\r\n    [&quot;DEBUG:&quot;,false]\r\n    [&quot;DEBUG:&quot;,false]\r\n    [&quot;DEBUG:&quot;,false]\r\n    [&quot;DEBUG:&quot;,false]\r\n\r\n**index/1**\r\n\r\nIn principle, using `index/1` should be efficient, but as of this writing (October 2017), its implementation, though fast (it is written in C), is inefficient.\r\n",
                "title": "How to filter array of objects by element property values using jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": 117,
        "last_activity_date": 1507864078,
        "creation_date": 1467285925,
        "last_edit_date": 1467294642,
        "question_id": 38121740,
        "body_markdown": "I like to filter json files using [jq](https://stedolan.github.io/jq/):\r\n\r\n    jq . some.json\r\n\r\nGiven the json containing an array of objects:\r\n\r\n    {\r\n      &quot;theList&quot;: [\r\n        {\r\n          &quot;id&quot;: 1,\r\n          &quot;name&quot;: &quot;Horst&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 2,\r\n          &quot;name&quot;: &quot;Fritz&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 3,\r\n          &quot;name&quot;: &quot;Walter&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 4,\r\n          &quot;name&quot;: &quot;Gerhart&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 5,\r\n          &quot;name&quot;: &quot;Harmut&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\nI want to filter that list to only show the elements with id having the value 2 and 4, so the expected output is:\r\n\r\n    {\r\n      &quot;id&quot;: 2,\r\n      &quot;name&quot;: &quot;Fritz&quot;\r\n    },\r\n    {\r\n      &quot;id&quot;: 4,\r\n      &quot;name&quot;: &quot;Gerhart&quot;\r\n    }\r\n\r\nHow do I filter the json using jq? I have played around with select and map, yet didn&#39;t got any of those to work, e.g.:\r\n\r\n    $ jq &#39;.theList[] | select(.id == 2) or select(.id == 4)&#39; array.json\r\n    true",
        "link": "https://stackoverflow.com/questions/38121740/how-to-filter-array-of-objects-by-element-property-values-using-jq",
        "title": "How to filter array of objects by element property values using jq?"
    },
    {
        "tags": [
            "boolean",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 30,
                "is_accepted": true,
                "score": 30,
                "last_activity_date": 1674307849,
                "last_edit_date": 1674307849,
                "creation_date": 1467643948,
                "answer_id": 38187498,
                "question_id": 38186594,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The JSON boolean values are `true` and `false`, so just drop the quotation marks, e.g. `select(.test == false)`.  \r\n\r\nIf indeed the values of .test are known beforehand to be strictly boolean, then you could simplify your filter to just:\r\n\r\n    .[] | select(.test|not)\r\n\r\n",
                "title": "jq - How to select objects where a field is &#39;false&#39;?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1504082375,
                "creation_date": 1504082375,
                "answer_id": 45955746,
                "question_id": 38186594,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is another solution\r\n\r\n    map(select(.test))",
                "title": "jq - How to select objects where a field is &#39;false&#39;?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 19,
        "last_activity_date": 1674453924,
        "creation_date": 1467640917,
        "last_edit_date": 1467693715,
        "question_id": 38186594,
        "body_markdown": "I&#39;m having trouble implementing boolean checks into jq.\r\nIf I have a field &quot;test&quot; which can be a boolean true or false, how do I use select to find this?\r\n\r\nInitially I tried the following:\r\n\r\n    jq &#39;.[] | select(.test==&quot;false&quot;)&#39;\r\n\r\nBut I think I am comparing strings here so this will not work.\r\n",
        "link": "https://stackoverflow.com/questions/38186594/jq-how-to-select-objects-where-a-field-is-false",
        "title": "jq - How to select objects where a field is &#39;false&#39;?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 56,
                "is_accepted": true,
                "score": 56,
                "last_activity_date": 1701690848,
                "last_edit_date": 1701690848,
                "creation_date": 1467743757,
                "answer_id": 38210345,
                "question_id": 38210288,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "As per the [manual][1], use the `-S` flag to format the output like that:\r\n\r\n&gt; --sort-keys / -S:\r\n&gt; \r\n&gt; Output the fields of each object with the keys in sorted order.\r\n\r\n\r\n  [1]: https://manpages.ubuntu.com/manpages/focal/en/man1/jq.1.html",
                "title": "How can I get jq to pretty print json ordering keys alphabetically"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 33,
        "last_activity_date": 1701690848,
        "creation_date": 1467743548,
        "last_edit_date": 1504667768,
        "question_id": 38210288,
        "body_markdown": "I use jq to pretty print very complicated json. then use diff to compare different version. Is there a way I can get jq to order the output alphabetically by keys? \r\n\r\nfaster xml object mappers have support for this\r\n\r\n    prettyPrintObjectMapper = new ObjectMapper();\r\n    prettyPrintObjectMapper.configure(SerializationFeature.INDENT_OUTPUT, true); //turn on\r\n    prettyPrintObjectMapper.configure(SerializationFeature.ORDER_MAP_ENTRIES_BY_KEYS, true);\r\n\r\n    String tmp1 = prettyPrintObjectMapper.writeValueAsString(myObject);\r\n\r\nKind regards\r\n\r\nAndy",
        "link": "https://stackoverflow.com/questions/38210288/how-can-i-get-jq-to-pretty-print-json-ordering-keys-alphabetically",
        "title": "How can I get jq to pretty print json ordering keys alphabetically"
    },
    {
        "tags": [
            "python",
            "arrays",
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3021,
                    "reputation": 416311,
                    "user_id": 4279,
                    "user_type": "registered",
                    "accept_rate": 94,
                    "profile_image": "https://www.gravatar.com/avatar/d92ce60d3a4cbe03598e27c2e8dee69d?s=256&d=identicon&r=PG",
                    "display_name": "jfs",
                    "link": "https://stackoverflow.com/users/4279/jfs"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1467797713,
                "post_id": 38220370,
                "comment_id": 63863897,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "user_type": "does_not_exist",
                    "display_name": "user3899165"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1467824322,
                "post_id": 38220370,
                "comment_id": 63880910,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 20,
                "is_accepted": false,
                "score": 20,
                "last_activity_date": 1467805487,
                "creation_date": 1467805487,
                "answer_id": 38223211,
                "question_id": 38220370,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "From the jq [FAQ][1]:\r\n\r\n&gt; Q: What bindings are available for Python?\r\n&gt; \r\n&gt; A:\r\n&gt; \r\n&gt; pip install jq # For details, see https://pypi.python.org/pypi/jq\r\n&gt; \r\n&gt; pip install pyjq # For details, see https://pypi.python.org/pypi/pyjq \r\n\r\n[1]: https://github.com/stedolan/jq/wiki/FAQ\r\n\r\nAs for your nested array, looping through it sounds like something that can (and maybe should) be done within jq.  ",
                "title": "Is there a way to execute jq from python"
            },
            {
                "up_vote_count": 9,
                "is_accepted": false,
                "score": 9,
                "last_activity_date": 1467824292,
                "creation_date": 1467824292,
                "answer_id": 38229564,
                "question_id": 38220370,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Well, I&#39;m a big fan of jq, but it doesn&#39;t seem like you&#39;re doing something that can&#39;t be easily done in Python too. Consider:\r\n\r\n    import json\r\n\r\n    with open(&quot;filename.json&quot;, &quot;r&quot;) as f:\r\n        data = json.load(f)\r\n\r\n    {&quot;Name&quot;: data[&quot;name&quot;], &quot;address&quot;: data[&quot;address&quot;][0][1][&quot;street&quot;]}",
                "title": "Is there a way to execute jq from python"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1469909405,
                "last_edit_date": 1469909405,
                "creation_date": 1469909032,
                "answer_id": 38678013,
                "question_id": 38220370,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "1.  Can I execute this command from a python script\r\n\r\nYes, using subprocess.  Example:\r\n\r\n    jsonFile = &#39;/path/to/your/filename.json&#39;\r\n    jq_cmd = &quot;/bin/jq &#39;{Name:.name, address:.address[0][1].street}&#39; &quot; + jsonFile\r\n    jq_proc = subprocess.Popen(jq_cmd, stdout=subprocess.PIPE, stderr=subprocess.PIPE, shell=True)\r\n    \r\n    # read JSON object, convert to string, store as a dictionary\r\n    \r\n    jDict = json.loads(jq_proc.stdout.read())\r\n    jq_proc.stdout.close()\r\n\r\n\r\n2. If it can be done, then how would I loop through for the nested array\r\nelements in the sample data give above (address[][].street)\r\n\r\nIt would help to see a JSON data set with a few records.  For looping through JSON sets in python with jq, it is easy to get a count of the objects and then iterate.  A slight bit of overhead but it makes the code easy to understand.\r\n\r\n    # count number of JSON records from the root level\r\n    \r\n    jq_cmd = &quot;/bin/jq &#39;. | length&#39; &quot; + jsonFile\r\n    jq_proc = subprocess.Popen(jq_cmd, stdout=subprocess.PIPE, stderr=subprocess.PIPE, shell=True)\r\n    \r\n    jObjCount = int(jq_proc.stdout.read())\r\n    jq_proc.stdout.close()\r\n    \r\n    # iterate over each root level JSON record\r\n    \r\n    for ix in range(jObjCount):\r\n    \r\n      jq_cmd = &quot;jq &#39;. | .[&quot; + str(ix) + &quot;]&#39; &quot; + jsonFile \r\n      jq_proc = subprocess.Popen(jq_cmd, stdout=subprocess.PIPE, stderr=subprocess.PIPE, shell=True)\r\n    \r\n      # read object, convert to string, store as a python dictionary\r\n    \r\n      jDict = json.loads(jq_proc.stdout.read())\r\n    \r\n      # iterate over nested objects within a root level object    \r\n      # as before, count number items but here for each root level JSON object\r\n    \r\n      jq_cmd = &quot;/bin/jq &#39;. | .[&quot; + str(ix) + &quot;].sub_Item_Key | length&#39; &quot; + jsonFile\r\n      jq_proc = subprocess.Popen(jq_cmd, stdout=subprocess.PIPE, stderr=subprocess.PIPE, shell=True)\r\n      jItemCount = int(jq_proc.stdout.read())\r\n      jq_proc.stdout.close()\r\n    \r\n      for jx in range(jItemCount):\r\n    \r\n         jq_cmd = &quot;/bin/jq &#39;. | .[&quot; + str(ix) + &quot;].sub_Item_Key[&quot; + str(jx) + &quot;]&#39; &quot; + jsonFile\r\n         jq_proc = subprocess.Popen(jq_cmd, stdout=subprocess.PIPE, stderr=subprocess.PIPE, shell=True)\r\n    \r\n         # read JSON item, convert to string, store as a python dictionary\r\n    \r\n         jItemDict = json.loads(jq_proc.stdout.read())\r\n\r\nEnjoy!",
                "title": "Is there a way to execute jq from python"
            },
            {
                "up_vote_count": 5,
                "is_accepted": false,
                "score": 5,
                "last_activity_date": 1503890054,
                "creation_date": 1503890054,
                "answer_id": 45911334,
                "question_id": 38220370,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The [`sh`](http://amoffat.github.io/sh/) module makes it easy invoke a jq subprocess from python.  e.g.\r\n\r\n    import sh\r\n    cmd = sh.jq(&#39;-M&#39;, &#39;{Name:.name, address:.address[0][1].street}&#39;, &#39;filename.json&#39;)\r\n    print &quot;cmd returned &gt;&gt;%s&lt;&lt;&quot; % cmd.stdout\r\n",
                "title": "Is there a way to execute jq from python"
            },
            {
                "up_vote_count": 13,
                "is_accepted": false,
                "score": 13,
                "last_activity_date": 1551855083,
                "creation_date": 1551855083,
                "answer_id": 55017219,
                "question_id": 38220370,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I believe the accepted answer should be peak&#39;s one, as the proper way to use a C api in python is via a python binding lib, and both https://pypi.python.org/pypi/jq and https://pypi.python.org/pypi/pyjq should work as expected.\r\n\r\n\r\n----------\r\n\r\n\r\nThat being said, since we are talking about python, I would like to bring an alternative that is much more pythonic: **glom** (`pip install glom`, https://glom.readthedocs.io/)\r\n\r\nInstead of using a DSL like in `jq`, with `glom` you just declare the output in the format you want, using pure python (this output format is called `spec`). In this case, you want a simple `dict`:\r\n\r\n    spec = {&#39;Name&#39;: &#39;name&#39;,\r\n            &#39;street&#39;: &#39;address.0.1.street&#39;}\r\n\r\nand then just call glom on your data:\r\n\r\n    output_data = glom(input_data, spec)\r\n\r\nJust like `jq`, you can also use `glom` on command line:\r\n\r\n    cat filename.json | glom &quot;{&#39;Name&#39;: &#39;name&#39;, &#39;street&#39;: &#39;address.0.1.street&#39;}&quot;\r\n\r\nA complete python example:\r\n\r\n    import json\r\n    from pprint import pprint\r\n    from glom import glom\r\n\r\n\r\n    with open(&#39;filename.json&#39;, &#39;rt&#39;) as f:\r\n        input_data = json.load(f)\r\n\r\n    spec = {&#39;Name&#39;: &#39;name&#39;,\r\n            &#39;street&#39;: &#39;address.0.1.street&#39;}\r\n\r\n    output_data = glom(input_data, spec)\r\n\r\n    pprint(output_data)\r\n",
                "title": "Is there a way to execute jq from python"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1604056780,
                "creation_date": 1604056780,
                "answer_id": 64607382,
                "question_id": 38220370,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Yes. Using [plumbum](https://plumbum.readthedocs.io/en/latest/).\r\n\r\n```py\r\nfrom plumbum.cmd import jq, cat\r\n\r\n(cat[&quot;filename.json&quot;] | jq [&quot;{Name:.name, address:.address[0][1].street}&quot;])()\r\n```\r\n\r\nThe result of the above command is a JSON object, that can be parsed to a Python object using `json.loads`.\r\n\r\nYou might also be interested in [jello](https://github.com/kellyjonbrazil/jello), which is like `jq` but uses Python as query language.",
                "title": "Is there a way to execute jq from python"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1703083649,
                "creation_date": 1703083649,
                "answer_id": 77692436,
                "question_id": 38220370,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "**There is a JQ Python binding called [JQpy][1].** This one does not require user to compile anything hence simply works on Linux/Windows/e.t.c.\r\n\r\nInstallation\r\n------------\r\nLinux:\r\n```bash\r\nsudo apt-get update &amp;&amp; sudo apt-get install jq\r\npip install jqpy\r\n```\r\n\r\n[Windows][2]:\r\n```shell\r\nchoco install jq\r\npip install jqpy\r\n```\r\n\r\nExample\r\n-------\r\n\r\n```ipython\r\n&gt;&gt;&gt; from jqpy import jq\r\n&gt;&gt;&gt; jq(&#39;.results[] | {age, city}&#39;, {\r\n                &quot;timestamp&quot;: 1234567890,\r\n                &quot;report&quot;: &quot;Age Report&quot;,\r\n                &quot;results&quot;: [\r\n                        { &quot;name&quot;: &quot;John&quot;, &quot;age&quot;: 43, &quot;city&quot;: &quot;TownA&quot; },\r\n                        { &quot;name&quot;: &quot;Joe&quot;,  &quot;age&quot;: 10, &quot;city&quot;: &quot;TownB&quot; }\r\n                ]\r\n        })\r\n[{&#39;age&#39;: 43, &#39;city&#39;: &#39;TownA&#39;}, {&#39;age&#39;: 10, &#39;city&#39;: &#39;TownB&#39;}]\r\n```\r\n\r\nOriginal question\r\n----\r\n\r\n```python\r\nimport json, jqpy\r\n\r\n# 1. Load JSON data\r\nwith open(&#39;filename.json&#39;,&#39;r&#39;,encoding=&#39;utf8&#39;) as f:\r\n    data = json.loads(f)\r\n\r\n# 2. Process with JQpy\r\nprocessed = jqpy.jq(&#39;{Name:.name, address:.address[0][1].street}&#39;, data)[0]\r\n\r\n# 3. Do stuff with outcome\r\nprint(f&#39;{processed[&#39;Name&#39;]=}&#39;)\r\n\r\n```\r\n\r\n  [1]: https://baterflyrity.github.io/jqpy/\r\n  [2]: https://baterflyrity.github.io/jqpy/installation.html#installation",
                "title": "Is there a way to execute jq from python"
            }
        ],
        "is_answered": true,
        "answer_count": 7,
        "score": 22,
        "last_activity_date": 1703083649,
        "creation_date": 1467796614,
        "last_edit_date": 1467826017,
        "question_id": 38220370,
        "body_markdown": "I&#39;m trying to execute a jq command from my python script. Currently the jq command is working fine when I execute from the terminal (MacOs).\r\n\r\n    cat filename.json |jq &#39;{Name:.name, address:.address[0][1].street}&#39;\r\n\r\nBasically I&#39;m trying to extract data from a JSON using jq. As the JSON contains nested arrays, I would have to loop using a variable.\r\n\r\nMy questions is - \r\n\r\n - Can I execute this command from a python script\r\n - If it can be done, then how would I loop through for the nested array \r\n - elements in the sample data give above (address[][].street)\r\n\r\nI don&#39;t want to use any language other than python, as it would cause compatibility issues.",
        "link": "https://stackoverflow.com/questions/38220370/is-there-a-way-to-execute-jq-from-python",
        "title": "Is there a way to execute jq from python"
    },
    {
        "tags": [
            "python",
            "json",
            "regex",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2268336,
                    "reputation": 11072,
                    "user_id": 1996394,
                    "user_type": "registered",
                    "accept_rate": 80,
                    "profile_image": "https://www.gravatar.com/avatar/bb7cf5d8bf03c5335a0ece8f6673541d?s=256&d=identicon&r=PG",
                    "display_name": "rock321987",
                    "link": "https://stackoverflow.com/users/1996394/rock321987"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1467881789,
                "post_id": 38241211,
                "comment_id": 63903568,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1467882087,
                "creation_date": 1467882087,
                "answer_id": 38241389,
                "question_id": 38241211,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Test Source: https://regex101.com/r/wT6uU2/1\r\n\r\n    import re\r\n    p = re.compile(ur&#39;},&#39;)\r\n    test_str = u&quot;{\\n\\&quot;Key1\\&quot;:\\&quot;value1\\&quot;,\\n\\&quot;Key2\\&quot;:\\&quot;value2\\&quot;\\n},\\n\\n{\\n\\&quot;Key1\\&quot;:\\&quot;value3\\&quot;,\\n\\&quot;Key2\\&quot;:\\&quot;value4\\&quot;\\n},\\n\\n{\\n\\&quot;Key1\\&quot;:\\&quot;value5\\&quot;,\\n\\&quot;Key2\\&quot;:\\&quot;value6\\&quot;\\n}&quot;\r\n     \r\n    re.findall(p, test_str)\r\n\r\nBut use replace instead \r\n\r\n&gt; replace }, -&gt; }\r\n\r\n",
                "title": "Regular expression in python replace"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1467882261,
                "creation_date": 1467882261,
                "answer_id": 38241443,
                "question_id": 38241211,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "This works:\r\n\r\n    import re\r\n    \r\n    s=&quot;&quot;&quot;{\r\n    &quot;Key1&quot;:&quot;value1&quot;,\r\n    &quot;Key2&quot;:&quot;value2&quot;\r\n    },\r\n    \r\n    {\r\n    &quot;Key1&quot;:&quot;value3&quot;,\r\n    &quot;Key2&quot;:&quot;value4&quot;\r\n    },\r\n    \r\n    {\r\n    &quot;Key1&quot;:&quot;value5&quot;,\r\n    &quot;Key2&quot;:&quot;value6&quot;\r\n    }&quot;&quot;&quot;\r\n    \r\n    pattern=re.compile(r&#39;(?P&lt;data&gt;{.*?}),&#39;, re.S)\r\n    \r\n    print pattern.findall(s)\r\n    \r\n    s1=pattern.sub(r&#39;\\g&lt;data&gt;&#39;, s)\r\n    print s1",
                "title": "Regular expression in python replace"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1467907437,
                "last_edit_date": 1467907437,
                "creation_date": 1467890104,
                "answer_id": 38244067,
                "question_id": 38241211,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "If you intend to process the resulting JSON in jq, it&#39;s probably easier to wrap it in brackets `[{...}, {...}]` to make it a JSON array. Then, you can use `.[]` in jq to unwrap the array.",
                "title": "Regular expression in python replace"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1467908352,
                "creation_date": 1467908352,
                "answer_id": 38250586,
                "question_id": 38241211,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Before you even consider other options, you really should go back to the source that generated that file and make sure it actually outputs _valid_ json.\r\n\r\nThat said, you could use JQ to manipulate the contents as a raw string to add brackets, then parse it as an array to them spit out the contents.\r\n\r\n    $ jq -Rs &#39;&quot;[\\(.)]&quot; | fromjson[]&#39; abc.json",
                "title": "Regular expression in python replace"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": 0,
        "last_activity_date": 1467908352,
        "creation_date": 1467881538,
        "last_edit_date": 1467896045,
        "question_id": 38241211,
        "body_markdown": "Is there any way using regular expression in python to replace all the occurrences of `,` (comma) after the flower braces `{`\r\n\r\nData is of the following format in a file - `abc.json`\r\n\r\n    {\r\n    &quot;Key1&quot;:&quot;value1&quot;,\r\n    &quot;Key2&quot;:&quot;value2&quot;\r\n    },\r\n    \r\n    {\r\n    &quot;Key1&quot;:&quot;value3&quot;,\r\n    &quot;Key2&quot;:&quot;value4&quot;\r\n    },\r\n    \r\n    {\r\n    &quot;Key1&quot;:&quot;value5&quot;,\r\n    &quot;Key2&quot;:&quot;value6&quot;\r\n    }\r\n\r\nThis should result in following - \r\n\r\n    {\r\n    &quot;Key1&quot;:&quot;value1&quot;,\r\n    &quot;Key2&quot;:&quot;value2&quot;\r\n    }\r\n    \r\n    {\r\n    &quot;Key1&quot;:&quot;value3&quot;,\r\n    &quot;Key2&quot;:&quot;value4&quot;\r\n    }\r\n    \r\n    {\r\n    &quot;Key1&quot;:&quot;value5&quot;,\r\n    &quot;Key2&quot;:&quot;value6&quot;\r\n    }\r\n\r\nAs you can see the `,`(comma) has been removed after every braces `}`.\r\n\r\nWould be helpful if this can be achieved via jq as well, apart from python REGEX\r\n",
        "link": "https://stackoverflow.com/questions/38241211/regular-expression-in-python-replace",
        "title": "Regular expression in python replace"
    },
    {
        "tags": [
            "json",
            "sorting",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2915863,
                    "reputation": 6877,
                    "user_id": 2499076,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/72dcd37bc8460b1645d72f7a8248156e?s=256&d=identicon&r=PG",
                    "display_name": "Ewan Mellor",
                    "link": "https://stackoverflow.com/users/2499076/ewan-mellor"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1467943941,
                "post_id": 38257725,
                "comment_id": 63936748,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 23,
                "is_accepted": false,
                "score": 23,
                "last_activity_date": 1508316254,
                "last_edit_date": 1508316254,
                "creation_date": 1467981029,
                "answer_id": 38266731,
                "question_id": 38257725,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a solution using a generic function *sorted_walk/1* (so named for the reason described in the postscript below).\r\n\r\n&gt; normalize.jq:\r\n\r\n    # Apply f to composite entities recursively using keys[], and to atoms\r\n    def sorted_walk(f):\r\n      . as $in\r\n      | if type == &quot;object&quot; then\r\n          reduce keys[] as $key\r\n            ( {}; . + { ($key):  ($in[$key] | sorted_walk(f)) } ) | f\r\n      elif type == &quot;array&quot; then map( sorted_walk(f) ) | f\r\n      else f\r\n      end;\r\n\r\n    def normalize: sorted_walk(if type == &quot;array&quot; then sort else . end);\r\n\r\n    normalize\r\n\r\nExample using bash:\r\n\r\n    diff &lt;(jq -S -f normalize.jq FILE1) &lt;(jq -S -f normalize.jq FILE2)\r\n\r\nPOSTSCRIPT: The builtin definition of `walk/1` was revised after this response was first posted: it now uses `keys_unsorted` rather than `keys`.",
                "title": "How can I completely sort arbitrary JSON using jq?"
            },
            {
                "up_vote_count": 19,
                "is_accepted": false,
                "score": 18,
                "last_activity_date": 1480996375,
                "creation_date": 1480996375,
                "answer_id": 40987535,
                "question_id": 38257725,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "&gt; I want to diff two JSON text files.\r\n\r\nUse [`jd`](https://github.com/josephburnett/jd#command-line-usage) with the `-set` option:\r\n\r\nNo output means no difference.\r\n\r\n    $ jd -set A.json B.json\r\n\r\nDifferences are shown as an @ path and + or -.\r\n\r\n    $ jd -set A.json C.json\r\n    \r\n    @ [&quot;People&quot;,{}]\r\n    + &quot;Carla&quot;\r\n\r\nThe output diffs can also be used as patch files with the `-p` option.\r\n\r\n    $ jd -set -o patch A.json C.json; jd -set -p patch B.json\r\n    \r\n    {&quot;City&quot;:&quot;Boston&quot;,&quot;People&quot;:[&quot;John&quot;,&quot;Carla&quot;,&quot;Bryan&quot;],&quot;State&quot;:&quot;MA&quot;}\r\n\r\nhttps://github.com/josephburnett/jd#command-line-usage",
                "title": "How can I completely sort arbitrary JSON using jq?"
            },
            {
                "up_vote_count": 5,
                "is_accepted": false,
                "score": 5,
                "last_activity_date": 1639069960,
                "last_edit_date": 1639069960,
                "creation_date": 1636664526,
                "answer_id": 69934876,
                "question_id": 38257725,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I&#39;m surprised this isn&#39;t a more popular question/answer. I haven&#39;t seen any other json deep sort solutions. Maybe everyone likes solving the same problem over and over.\r\n\r\nHere&#39;s an wrapper for [@peak&#39;s excellent solution above](https://stackoverflow.com/a/38266731/839369) that wraps it into a shell script that works in a pipe or with file args. \r\n\r\n```\r\n#!/usr/bin/env bash\r\n\r\n# json normalizer function\r\n# Recursively sort an entire json file, keys and arrays\r\n# jq  --sort-keys is top level only\r\n# Alphabetize a json file&#39;s dict&#39;s such that they are always in the same order\r\n# Makes json diff&#39;able and should be run on any json data that&#39;s in source control to prevent excessive diffs from dict reordering.\r\n\r\n[ &quot;${DEBUG}&quot; ] &amp;&amp; set -x\r\nTMP_FILE=&quot;$(mktemp)&quot;\r\ntrap &#39;rm -f -- &quot;${TMP_FILE}&quot;&#39; EXIT\r\n\r\ncat &gt; &quot;${TMP_FILE}&quot; &lt;&lt;-EOT\r\n# Apply f to composite entities recursively using keys[], and to atoms\r\ndef sorted_walk(f):\r\n  . as \\$in\r\n  | if type == &quot;object&quot; then\r\n      reduce keys[] as \\$key\r\n        ( {}; . + { (\\$key):  (\\$in[\\$key] | sorted_walk(f)) } ) | f\r\n  elif type == &quot;array&quot; then map( sorted_walk(f) ) | f\r\n  else f\r\n  end;\r\n\r\ndef normalize: sorted_walk(if type == &quot;array&quot; then sort else . end);\r\n\r\nnormalize\r\nEOT\r\n\r\n# Don&#39;t pollute stdout with debug output\r\n[ &quot;${DEBUG}&quot; ] &amp;&amp; cat $TMP_FILE &gt; /dev/stderr\r\n\r\nif [ &quot;$1&quot; ] ; then\r\n    jq -S -f ${TMP_FILE}  $1\r\nelse\r\n    jq -S -f ${TMP_FILE} &lt; /dev/stdin\r\nfi\r\n```\r\n",
                "title": "How can I completely sort arbitrary JSON using jq?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": -2,
                "last_activity_date": 1683531987,
                "last_edit_date": 1683531987,
                "creation_date": 1683527590,
                "answer_id": 76198005,
                "question_id": 38257725,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`jq` has a `--sort-keys` option you can use.\r\n\r\nSee the [`jq` manpage](https://manpages.ubuntu.com/manpages/bionic/man1/jq.1.html) for reference.",
                "title": "How can I completely sort arbitrary JSON using jq?"
            },
            {
                "up_vote_count": 9,
                "is_accepted": true,
                "score": 8,
                "last_activity_date": 1707320995,
                "last_edit_date": 1707320995,
                "creation_date": 1698870475,
                "answer_id": 77405422,
                "question_id": 38257725,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I&#39;ve just had a need for this and didn&#39;t want to have to define a bunch of functions since I&#39;d like this to be a simple one liner. Fortunately the following worked out:\r\n\r\n```\r\njq -S &#39;walk(if type == &quot;array&quot; then sort else . end)&#39;\r\n```\r\n\r\nHere&#39;s an example:\r\n\r\n```ShellSession\r\n$ echo &#39;{&quot;foo&quot;:&quot;bar&quot;,&quot;zzz&quot;:true,&quot;list&quot;:[&quot;a&quot;,&quot;c&quot;,&quot;b&quot;,{&quot;nested&quot;:[1,3,2]}]}&#39; |\r\n  jq -S &#39;walk(if type == &quot;array&quot; then sort else . end)&#39;\r\n{\r\n  &quot;foo&quot;: &quot;bar&quot;,\r\n  &quot;list&quot;: [\r\n    &quot;a&quot;,\r\n    &quot;b&quot;,\r\n    &quot;c&quot;,\r\n    {\r\n      &quot;nested&quot;: [\r\n        1,\r\n        2,\r\n        3\r\n      ]\r\n    }\r\n  ],\r\n  &quot;zzz&quot;: true\r\n}\r\n```",
                "title": "How can I completely sort arbitrary JSON using jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 5,
        "score": 25,
        "last_activity_date": 1707320995,
        "creation_date": 1467941676,
        "last_edit_date": 1495541408,
        "question_id": 38257725,
        "body_markdown": "I want to diff two JSON text files.  Unfortunately they&#39;re constructed in arbitrary order, so I get diffs when they&#39;re semantically identical.  I&#39;d like to use jq (or whatever) to sort them in any kind of full order, to eliminate differences due only to element ordering.\r\n\r\n--sort-keys solves half the problem, but it doesn&#39;t sort arrays.\r\n\r\nI&#39;m pretty ignorant of jq and don&#39;t know how to write a jq recursive filter that preserves all data; any help would be appreciated.\r\n\r\nI realize that line-by-line &#39;diff&#39; output isn&#39;t necessarily the best way to compare two complex objects, but in this case I know the two files are very similar (nearly identical) and line-by-line diffs are fine for my purposes.\r\n\r\nhttps://stackoverflow.com/questions/31930041 answers a very similar question, but doesn&#39;t print the differences.  Also, I want to save the sorted results, so what I really want is just a filter program to sort JSON.",
        "link": "https://stackoverflow.com/questions/38257725/how-can-i-completely-sort-arbitrary-json-using-jq",
        "title": "How can I completely sort arbitrary JSON using jq?"
    },
    {
        "tags": [
            "indexing",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6805413,
                    "reputation": 257,
                    "user_id": 5237317,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/V24Tt.jpg?s=256",
                    "display_name": "cerebrotecnologico",
                    "link": "https://stackoverflow.com/users/5237317/cerebrotecnologico"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1468020214,
                "post_id": 38276071,
                "comment_id": 63972621,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1468084742,
                "last_edit_date": 1468084742,
                "creation_date": 1468026400,
                "answer_id": 38277268,
                "question_id": 38276071,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You could do it like this:\r\n\r\n    [ keys[] as $i | .[$i] | .p=$i ]\r\n\r\nAlternatively, you could make it work using `to_entries` like this:\r\n\r\n    [ to_entries[] | (.value.p=.key).value ]\r\n\r\nBoth of which yields:\r\n\r\n    [\r\n      {\r\n        &quot;w&quot;: &quot;Hello&quot;,\r\n        &quot;p&quot;: 0\r\n      },\r\n      {\r\n        &quot;w&quot;: &quot;World&quot;,\r\n        &quot;p&quot;: 1\r\n      }\r\n    ]\r\n\r\n",
                "title": "How to inject the array indices of objects in an array into the objects, using jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1503880880,
                "creation_date": 1503880880,
                "answer_id": 45910539,
                "question_id": 38276071,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a solution which uses `reduce`\r\n\r\n    reduce keys[] as $i (.; .[$i].p = $i)",
                "title": "How to inject the array indices of objects in an array into the objects, using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 3,
        "last_activity_date": 1503880880,
        "creation_date": 1468015818,
        "last_edit_date": 1468128718,
        "question_id": 38276071,
        "body_markdown": "Given an array of objects, I would like to inject a property with its position in the array. \r\nFor example:\r\n\r\n    [ { &quot;w&quot; : &quot;Hello&quot; }, { &quot;w&quot; : &quot;World } ]\r\n\r\nI would like to produce:\r\n\r\n    [ { &quot;w&quot; : &quot;Hello&quot;, p: 0 }, { &quot;w&quot; : &quot;World, p:1 } ]\r\n\r\nwhere p is the zero-based position in the array. \r\n\r\nIs there a way to get the index of the element?\r\nI tried this but it is not working:\r\n\r\n        keys[] as $i | [ .[] | .p= $i ] \r\nI get:\r\n\r\n     [ { &quot;w&quot; : &quot;Hello&quot;, p: 0 }, { &quot;w&quot; : &quot;World, p:0 } ]\r\n\r\n",
        "link": "https://stackoverflow.com/questions/38276071/how-to-inject-the-array-indices-of-objects-in-an-array-into-the-objects-using-j",
        "title": "How to inject the array indices of objects in an array into the objects, using jq"
    },
    {
        "tags": [
            "arrays",
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1468269204,
                "last_edit_date": 1468269204,
                "creation_date": 1468267970,
                "answer_id": 38315427,
                "question_id": 38314400,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a solution that will remove all objects with the specified name, wherever they occur.  It uses the generic function *walk/1*,\r\nwhich is a built-in in versions of jq &gt; 1.5, and can therefore be omitted if your jq includes it, but there is no harm in including it redundantly, e.g. in a jq script.  \r\n\r\n\r\n    # Apply f to composite entities recursively, and to atoms\r\n    def walk(f):\r\n      . as $in\r\n      | if type == &quot;object&quot; then\r\n          reduce keys[] as $key\r\n            ( {}; . + { ($key):  ($in[$key] | walk(f)) } ) | f\r\n      elif type == &quot;array&quot; then map( walk(f) ) | f\r\n      else f\r\n      end;\r\n\r\n    walk(if type == &quot;object&quot; and .name == &quot;Name1&quot; then empty else . end)\r\n\r\nIf you really only want to remove objects from arrays, then you could use:\r\n\r\n    walk(if type == &quot;array&quot; then map(select( type != &quot;object&quot; or .name != &quot;Name1&quot;)) else . end)\r\n",
                "title": "JQ: Remove object from multiple arrays"
            },
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1468275586,
                "creation_date": 1468275586,
                "answer_id": 38317104,
                "question_id": 38314400,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "If the structure of your input JSON is always as seen on your example, try this:\r\n\r\n    map_values(map(select(.name != &quot;Name1&quot;)))",
                "title": "JQ: Remove object from multiple arrays"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1503881331,
                "creation_date": 1503881331,
                "answer_id": 45910572,
                "question_id": 38314400,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a solution which uses **reduce** and **del**\r\n\r\n    reduce keys[] as $k (\r\n      .\r\n    ; del(.[$k][] | select(.name == &quot;Name1&quot;))\r\n    )",
                "title": "JQ: Remove object from multiple arrays"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1504609294,
        "creation_date": 1468264148,
        "last_edit_date": 1504609294,
        "question_id": 38314400,
        "body_markdown": "I want to use jq to remove all objects with a given name from all arrays in the input data. For example deleting &quot;Name1&quot; from this:\r\n\r\n    {\r\n      &quot;Category1&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;Name1&quot;,\r\n          &quot;desc&quot;: &quot;Desc1&quot;\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;Name2&quot;,\r\n          &quot;desc&quot;: &quot;Desc2&quot;\r\n        }\r\n      ],\r\n      &quot;Category2&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;Name1&quot;,\r\n          &quot;desc&quot;: &quot;Desc1&quot;\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;Name3&quot;,\r\n          &quot;desc&quot;: &quot;Desc3&quot;\r\n        }\r\n      ],\r\n      &quot;Category3&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;Name4&quot;,\r\n          &quot;desc&quot;: &quot;Desc4&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\nShould yield this:\r\n\r\n    {\r\n      &quot;Category1&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;Name2&quot;,\r\n          &quot;desc&quot;: &quot;Desc2&quot;\r\n        }\r\n      ],\r\n      &quot;Category2&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;Name3&quot;,\r\n          &quot;desc&quot;: &quot;Desc3&quot;\r\n        }\r\n      ],\r\n      &quot;Category3&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;Name4&quot;,\r\n          &quot;desc&quot;: &quot;Desc4&quot;\r\n        }\r\n      ]\r\n    }\r\nI haven&#39;t worked with jq, or indeed JSON, much and after several hours of googling and experimenting I haven&#39;t been able to figure it out. How would I do this?\r\n\r\nThe closest I managed was this:\r\n\r\n    cat input | jq &#39;keys[] as $k | .[$k] |= map( select( .name != &quot;Name1&quot;))&#39;\r\nThis does filter each of the arrays but returns the result as three separate objects and this is not what I want.",
        "link": "https://stackoverflow.com/questions/38314400/jq-remove-object-from-multiple-arrays",
        "title": "JQ: Remove object from multiple arrays"
    },
    {
        "tags": [
            "arrays",
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1468337235,
                "creation_date": 1468337235,
                "answer_id": 38333123,
                "question_id": 38332971,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "    $ jq -r &#39;[.StackSummaries[] | .StackName] | unique[]&#39; input.json\r\n    foo-bar-testing\r\n    foo-control-eu-west-1\r\n    foo-ldap-eu-west-1\r\n\r\nThe -r option strips the quotation marks from the output.  You might not want the call to &#39;unique&#39;.\r\n\r\nFor reference, if you wanted all the key names:\r\n\r\n    $ jq &#39;[.StackSummaries[] | keys[]] | unique&#39; input.json\r\n    [\r\n      &quot;CreationTime&quot;,\r\n      &quot;LastUpdatedTime&quot;,\r\n      &quot;StackName&quot;,\r\n      &quot;StackStatus&quot;\r\n    ]",
                "title": "Given a json array, how do I extract a list of key values by key, using jq?"
            },
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1468355421,
                "last_edit_date": 1468355421,
                "creation_date": 1468337577,
                "answer_id": 38333242,
                "question_id": 38332971,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "    jq --raw-output &#39;.StackSummaries[].StackName&#39;",
                "title": "Given a json array, how do I extract a list of key values by key, using jq?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1504082877,
                "creation_date": 1504082877,
                "answer_id": 45955911,
                "question_id": 38332971,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is another solution\r\n\r\n    jq -M -r &#39;..|.StackName?|values&#39; input.json",
                "title": "Given a json array, how do I extract a list of key values by key, using jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 2,
        "last_activity_date": 1504082877,
        "creation_date": 1468336793,
        "last_edit_date": 1468337959,
        "question_id": 38332971,
        "body_markdown": "I have a json array that looks like this:\r\n\r\n    {\r\n      &quot;StackSummaries&quot;: [\r\n        {\r\n          &quot;CreationTime&quot;: &quot;2016-06-01T22:22:49.890Z&quot;,\r\n          &quot;StackName&quot;: &quot;foo-control-eu-west-1&quot;,\r\n          &quot;StackStatus&quot;: &quot;UPDATE_COMPLETE&quot;,\r\n          &quot;LastUpdatedTime&quot;: &quot;2016-06-01T22:47:58.433Z&quot;\r\n        },\r\n        {\r\n          &quot;CreationTime&quot;: &quot;2016-04-13T11:22:04.250Z&quot;,\r\n          &quot;StackName&quot;: &quot;foo-bar-testing&quot;,\r\n          &quot;StackStatus&quot;: &quot;UPDATE_COMPLETE&quot;,\r\n          &quot;LastUpdatedTime&quot;: &quot;2016-04-26T16:17:07.570Z&quot;\r\n        },\r\n        {\r\n          &quot;CreationTime&quot;: &quot;2016-04-10T01:09:49.428Z&quot;,\r\n          &quot;StackName&quot;: &quot;foo-ldap-eu-west-1&quot;,\r\n          &quot;StackStatus&quot;: &quot;UPDATE_COMPLETE&quot;,\r\n          &quot;LastUpdatedTime&quot;: &quot;2016-04-17T13:44:04.758Z&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\nI am looking to create text output that looks like this:\r\n\r\n    foo-control-eu-west-1\r\n    foo-bar-testing\r\n    foo-ldap-eu-west-1\r\n\r\nIs jq able to do this? Specifically, what would the jq command line be that would select each StackName in the array and output each key one per line?\r\n",
        "link": "https://stackoverflow.com/questions/38332971/given-a-json-array-how-do-i-extract-a-list-of-key-values-by-key-using-jq",
        "title": "Given a json array, how do I extract a list of key values by key, using jq?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1468355920,
                "last_edit_date": 1468355920,
                "creation_date": 1468352377,
                "answer_id": 38337572,
                "question_id": 38335869,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here&#39;s the correct way to write your &quot;exist&quot; definition:\r\n\r\n    def exist(element):\r\n      if has( element )\r\n      then { (element): .[element] }\r\n      else { (element): &quot;NA&quot; }\r\n      end;\r\n\r\nThis has been tested with jq 1.3 but please try to upgrade to a more recent version.\r\n\r\nIn practice, one is more likely to use an idiom such as this:\r\n\r\n    if has(element) then . else .[element] = &quot;NA&quot; end",
                "title": "Acting on the existence or non-existence of a key using JQ"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1504083875,
                "creation_date": 1504083875,
                "answer_id": 45956223,
                "question_id": 38335869,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is another solution which uses [update assignment |=](https://stedolan.github.io/jq/manual/#Update-assignment:|=)\r\n\r\n       .DBInstances[] | .bar |= if .==null then &quot;NA&quot; else . end\r\n",
                "title": "Acting on the existence or non-existence of a key using JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 6,
        "last_activity_date": 1504600352,
        "creation_date": 1468346003,
        "last_edit_date": 1504600352,
        "question_id": 38335869,
        "body_markdown": "I have a JSON file containing objects that are similar to each other, but not identical.  All objects have a main identifier, but other keys may or may not exist within an object.\r\n\r\nMy question:  for a given key in an object, how do I print out the value if it exists, and something like &quot;NA&quot; if it does not, printing the original name of the key either way?\r\n\r\nSample input:\r\n\r\n      {\r\n          &quot;DBInstances&quot;: [\r\n              {\r\n                  &quot;Identifier&quot;: 101,\r\n                  &quot;foo&quot;: &quot;some_value&quot;,\r\n                  &quot;bar&quot;: 60,\r\n                  &quot;Model&quot;: &quot;A&quot;\r\n              },\r\n              {\r\n                  &quot;Identifier&quot;: 102,\r\n                  &quot;foo&quot;: &quot;some_value&quot;,\r\n                  &quot;Model&quot;: &quot;B&quot;\r\n              }\r\n          ]\r\n      }\r\n\r\nDesired output:\r\n\r\n              {\r\n                  &quot;Identifier&quot;: 101,\r\n                  &quot;foo&quot;: &quot;some_value&quot;,\r\n                  &quot;bar&quot;: 60,\r\n                  &quot;Model&quot;: &quot;A&quot;\r\n              },\r\n              {\r\n                  &quot;Identifier&quot;: 102,\r\n                  &quot;foo&quot;: &quot;some_value&quot;,\r\n                  &quot;bar&quot;: &quot;NA&quot;,\r\n                  &quot;Model&quot;: &quot;B&quot;\r\n              }\r\n\r\nI created a function that works (partly) for non-existence, but not at all for existence:\r\n\r\n      def exist(element):\r\n         if (has( element ) == true)\r\n         then { element: &quot;true&quot; }\r\n         else { element: &quot;NA&quot; }\r\n         end;\r\n\r\nwhen I call it with:\r\n\r\n     exist( &quot;bar&quot; )\r\n\r\nThe &quot;existence&quot; part is completely wrong in that JQ prints &quot;element&quot; and &quot;true&quot; rather than the original key name and value.\r\n\r\nFor the &quot;non-existence&quot; part, JQ prints &quot;NA&quot; just fine, but &quot;element&quot; instead of the original key name.\r\n\r\nI&#39;m working with JQ 1.3.\r\n",
        "link": "https://stackoverflow.com/questions/38335869/acting-on-the-existence-or-non-existence-of-a-key-using-jq",
        "title": "Acting on the existence or non-existence of a key using JQ"
    },
    {
        "tags": [
            "arrays",
            "json",
            "linux",
            "sorting",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3964519,
                    "reputation": 1364,
                    "user_id": 3270866,
                    "user_type": "registered",
                    "accept_rate": 29,
                    "profile_image": "https://www.gravatar.com/avatar/1a6cbd782adc2d3fc0a6e5e5b25a0177?s=256&d=identicon&r=PG",
                    "display_name": "Bhavin Solanki",
                    "link": "https://stackoverflow.com/users/3270866/bhavin-solanki"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1468427610,
                "post_id": 38357075,
                "comment_id": 64126640,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 2645018,
                    "reputation": 61,
                    "user_id": 2287913,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d1c5087bde050ed3520c806747965f9c?s=256&d=identicon&r=PG",
                    "display_name": "hedda",
                    "link": "https://stackoverflow.com/users/2287913/hedda"
                },
                "reply_to_user": {
                    "account_id": 3964519,
                    "reputation": 1364,
                    "user_id": 3270866,
                    "user_type": "registered",
                    "accept_rate": 29,
                    "profile_image": "https://www.gravatar.com/avatar/1a6cbd782adc2d3fc0a6e5e5b25a0177?s=256&d=identicon&r=PG",
                    "display_name": "Bhavin Solanki",
                    "link": "https://stackoverflow.com/users/3270866/bhavin-solanki"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1468427926,
                "post_id": 38357075,
                "comment_id": 64126806,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1468431429,
                "creation_date": 1468431429,
                "answer_id": 38358332,
                "question_id": 38357075,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The text shown as JSON is invalid as JSON.  Assuming it is fixed to have\r\nthe structure `{&quot;version&quot;: _, &quot;controls&quot;: _}`, the following filter\r\nwould yield the result shown below:\r\n\r\n    .controls[] | select(.status == &quot;failed&quot;)\r\n\r\n\r\nOutput:\r\n\r\n    {\r\n      &quot;id&quot;: &quot;os-1.0&quot;,\r\n      &quot;status&quot;: &quot;failed&quot;,\r\n      &quot;code_desc&quot;: &quot;File /etc/csh.cshrc content should match /umask\\\\s*022/&quot;,\r\n      &quot;profile_id&quot;: &quot;test&quot;,\r\n      &quot;message&quot;: &quot;\\nexpected: \\&quot;/sbin/sulogin\\&quot;\\n     got: \\n\\n(compared using `cmp` matcher)\\n&quot;\r\n    }\r\n\r\nNote: For robustness you might want to use `.status?` instead of `.status`.\r\n",
                "title": "Return entire object from Array based on key value in object using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1468431429,
        "creation_date": 1468427197,
        "question_id": 38357075,
        "body_markdown": "I have a .json file that I would like to filter through jq to return the entire object in the array if the key value in that object equals &#39;failed&#39;. How would I do this  ?\r\n\r\nExample json: \r\n\r\n    \r\n\r\n\t&quot;version&quot;: &quot;0.26.0&quot;,\r\n\t&quot;controls&quot;: [{\r\n\t\t&quot;id&quot;: &quot;os-1.0&quot;,\r\n\t\t&quot;status&quot;: &quot;passed&quot;,\r\n\t\t&quot;code_desc&quot;: &quot;File /etc/profile content should match /umask\\\\s*022/&quot;,\r\n\t\t&quot;profile_id&quot;: &quot;test&quot;\r\n\t}, {\r\n\t\t&quot;id&quot;: &quot;os-1.0&quot;,\r\n\t\t&quot;status&quot;: &quot;passed&quot;,\r\n\t\t&quot;code_desc&quot;: &quot;File /etc/bashrc content should match /umask\\\\s*022/&quot;,\r\n\t\t&quot;profile_id&quot;: &quot;test&quot;\r\n\t}, {\r\n\t\t&quot;id&quot;: &quot;os-1.0&quot;,\r\n\t\t&quot;status&quot;: &quot;failed&quot;,\r\n\t\t&quot;code_desc&quot;: &quot;File /etc/csh.cshrc content should match /umask\\\\s*022/&quot;,\r\n\t\t&quot;profile_id&quot;: &quot;test&quot;\r\n       &quot;message&quot;: &quot;\\nexpected: \\&quot;/sbin/sulogin\\&quot;\\n     got: \\n\\n(compared using `cmp` matcher)\\n&quot;\r\n\t}]\r\n\r\n\r\nOutput to a new file : \r\n\r\n    {\r\n\t\t&quot;id&quot;: &quot;os-1.0&quot;,\r\n\t\t&quot;status&quot;: &quot;failed&quot;,\r\n\t\t&quot;code_desc&quot;: &quot;File /etc/csh.cshrc content should match /umask\\\\s*022/&quot;,\r\n\t\t&quot;profile_id&quot;: &quot;test&quot;\r\n        &quot;message&quot;: &quot;\\nexpected: \\&quot;/sbin/sulogin\\&quot;\\n     got: \\n\\n(compared using  `cmp` matcher)\\n&quot;\r\n\t}\r\n",
        "link": "https://stackoverflow.com/questions/38357075/return-entire-object-from-array-based-on-key-value-in-object-using-jq",
        "title": "Return entire object from Array based on key value in object using jq"
    },
    {
        "tags": [
            "arrays",
            "json",
            "intersection",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1608408925,
                "last_edit_date": 1608408925,
                "creation_date": 1468468243,
                "answer_id": 38365155,
                "question_id": 38364458,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "A simple and quite fast (but somewhat naive) filter that probably does essentially what you want can be defined as follows:\r\n```\r\n   # x and y are arrays\r\n   def intersection(x;y):\r\n     ( (x|unique) + (y|unique) | sort) as $sorted\r\n     | reduce range(1; $sorted|length) as $i\r\n         ([]; if $sorted[$i] == $sorted[$i-1] then . + [$sorted[$i]] else . end) ;\r\n```\r\n\r\nIf x is provided as input on STDIN, and y is provided in some other way (e.g. `def y: ...`), then you could use this as: `intersection(.;y)`\r\n\r\nOther ways to provide two distinct arrays as input include: \r\n\r\n* using the `--slurp` option\r\n* using `--arg a v` (or `--argjson a v` if available in your jq)\r\n\r\nHere&#39;s a simpler but slower def that&#39;s nevertheless quite fast in practice:\r\n```\r\n    def i(x;y):\r\n       if (y|length) == 0 then []\r\n       else (x|unique) as $x\r\n       | $x - ($x - y)\r\n       end ;\r\n```\r\n\r\nHere&#39;s a standalone filter for finding the intersection of arbitrarily many arrays:\r\n\r\n    # Input: an array of arrays\r\n    def intersection:\r\n      def i(y): ((unique + (y|unique)) | sort) as $sorted\r\n      | reduce range(1; $sorted|length) as $i\r\n           ([]; if $sorted[$i] == $sorted[$i-1] then . + [$sorted[$i]] else . end) ;\r\n      reduce .[1:][] as $a (.[0]; i($a)) ;\r\n\r\nExamples:\r\n\r\n    [ [1,2,4], [2,4,5], [4,5,6]] #=&gt; [4]\r\n    [[]]                         #=&gt; []\r\n    []                           #=&gt; null\r\n\r\n\r\n\r\nOf course if `x` and `y` are already known to be sorted and/or unique, more efficient solutions are possible.  See in particular [Finite Sets of JSON Entities](https://rosettacode.org/wiki/Set#Finite_Sets_of_JSON_Entities)\r\n\r\n\r\n",
                "title": "how to get the intersection of two JSON arrays using jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1503883110,
                "last_edit_date": 1503883110,
                "creation_date": 1503882696,
                "answer_id": 45910676,
                "question_id": 38364458,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a solution which works by counting occurrences of elements in the arrays using **foreach**\r\n\r\n    [\r\n      foreach ($X[], $Y[]) as $r (\r\n        {}\r\n      ; .[$r|tostring] += 1\r\n      ; if .[$r|tostring] == 2 then $r else empty end\r\n      )\r\n    ]\r\n    \r\nIf this filter is in `filter.jq` then \r\n\r\n    jq -M -n -c --argjson X &#39;[1,2,3,4]&#39; --argjson Y &#39;[2,4,6,8,10]&#39; -f filter.jq\r\n\r\nwill produce\r\n\r\n    [2,4]\r\n\r\nIt assumes there are no duplicates in the initial arrays.  If that&#39;s not the case then it is easy to compensate with **unique**.  E.g.\r\n\r\n    [\r\n      foreach (($X|unique)[], ($Y|unique)[]) as $r (\r\n        {}\r\n      ; .[$r|tostring] += 1\r\n      ; if .[$r|tostring] == 2 then $r else empty end\r\n      )\r\n    ]",
                "title": "how to get the intersection of two JSON arrays using jq"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1527499502,
                "creation_date": 1527499502,
                "answer_id": 50563063,
                "question_id": 38364458,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "\r\n    $ echo &#39;[1,2,3,4] [2,4,6,8,10]&#39; | jq --slurp &#39;[.[0][] as $x | .[1][] | select($x == .)]&#39;\r\n    [\r\n      2,\r\n      4\r\n    ]",
                "title": "how to get the intersection of two JSON arrays using jq"
            },
            {
                "up_vote_count": 15,
                "is_accepted": false,
                "score": 14,
                "last_activity_date": 1690470631,
                "last_edit_date": 1690470631,
                "creation_date": 1608681974,
                "answer_id": 65417432,
                "question_id": 38364458,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "NOTE: This solution assumes array1 has no duplicates.\r\n\r\n## Simple Explanation\r\n\r\nThe complexity of all these answers obscures understanding the principle. That&#39;s unfortunate because the principle is simple:\r\n\r\n&gt; - array1 minus array2 returns:\r\n&gt; - everything that&#39;s left in array1\r\n&gt; - after removing everything that is in array2\r\n&gt; - (and discarding the rest of array2)\r\n\r\n## Simple Demo\r\n\r\n```bash\r\n# From array1, subtract array2, leaving the remainder\r\n$ jq --null-input &#39;[1,2,3,4] - [2,4,6,8]&#39;\r\n[\r\n  1,\r\n  3\r\n]\r\n\r\n# Subtract the remainder from the original\r\n$ jq --null-input &#39;[1,2,3,4] - [1,3]&#39;\r\n[\r\n  2,\r\n  4\r\n]\r\n\r\n# Put it all together\r\n$ jq --null-input &#39;[1,2,3,4] - ([1,2,3,4] - [2,4,6,8])&#39;\r\n[\r\n  2,\r\n  4\r\n]\r\n\r\n```\r\n\r\n## `comm` Demo\r\n\r\n```javascript\r\ndef comm:\r\n  (.[0] - (.[0] - .[1])) as $d |\r\n    [.[0]-$d, .[1]-$d, $d]\r\n;\r\n```\r\n\r\nWith that understanding, I was able to imitate the behavior of [the *nix `comm` command][1]\r\n\r\n&gt; With no options, produce three-column output.  Column one\r\n&gt; contains lines unique to FILE1, column two contains lines unique\r\n&gt; to FILE2, and column three contains lines common to both files.\r\n\r\n```bash\r\n$ echo &#39;def comm: (.[0]-(.[0]-.[1])) as $d | [.[0]-$d,.[1]-$d, $d];&#39; &gt; comm.jq\r\n$ echo &#39;{&quot;a&quot;:101, &quot;b&quot;:102, &quot;c&quot;:103, &quot;d&quot;:104}&#39;                        &gt; 1.json\r\n$ echo &#39;{         &quot;b&quot;:202,          &quot;d&quot;:204, &quot;f&quot;:206, &quot;h&quot;:208}&#39;      &gt; 2.json\r\n\r\n$ jq --slurp &#39;.&#39; 1.json 2.json\r\n[\r\n  {\r\n    &quot;a&quot;: 101,\r\n    &quot;b&quot;: 102,\r\n    &quot;c&quot;: 103,\r\n    &quot;d&quot;: 104\r\n  },\r\n  {\r\n    &quot;b&quot;: 202,\r\n    &quot;d&quot;: 204,\r\n    &quot;f&quot;: 206,\r\n    &quot;h&quot;: 208\r\n  }\r\n]\r\n\r\n$ jq --slurp &#39;[.[] | keys | sort]&#39; 1.json 2.json\r\n[\r\n  [\r\n    &quot;a&quot;,\r\n    &quot;b&quot;,\r\n    &quot;c&quot;,\r\n    &quot;d&quot;\r\n  ],\r\n  [\r\n    &quot;b&quot;,\r\n    &quot;d&quot;,\r\n    &quot;f&quot;,\r\n    &quot;h&quot;\r\n  ]\r\n]\r\n\r\n$ jq --slurp &#39;include &quot;comm&quot;; [.[] | keys | sort] | comm&#39; 1.json 2.json\r\n[\r\n  [\r\n    &quot;a&quot;,\r\n    &quot;c&quot;\r\n  ],\r\n  [\r\n    &quot;f&quot;,\r\n    &quot;h&quot;\r\n  ],\r\n  [\r\n    &quot;b&quot;,\r\n    &quot;d&quot;\r\n  ]\r\n]\r\n\r\n$ jq --slurp &#39;include &quot;comm&quot;; [.[] | keys | sort] | comm[2]&#39; 1.json 2.json\r\n[\r\n  &quot;b&quot;,\r\n  &quot;d&quot;\r\n]\r\n```\r\n\r\n  [1]: https://man7.org/linux/man-pages/man1/comm.1.html",
                "title": "how to get the intersection of two JSON arrays using jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1743615891,
                "creation_date": 1743615891,
                "answer_id": 79551239,
                "question_id": 38364458,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I defined function **intersection/0** that calculates intersection of any number of arrays (expects array of arrays as an input).\\\r\nThen used it to define **intersection/2** that calculates intersection of two arrays.\r\n\r\n```\r\n#!/usr/bin/env -S jq -fn\r\n\r\ndef intersection:\r\n    # get number of input arrays\r\n    length as $number_of_arrays\r\n    # get unique elements from each array and combine them into single array\r\n    |map(unique[])\r\n    # length of each group is the number of input arrays containing given value\r\n    |group_by(.)\r\n    |map(\r\n        # this will be not null only for the values that are present in each array\r\n        .[$number_of_arrays-1]\r\n        # select only values present in each array\r\n        |select(.)\r\n    )\r\n;\r\n\r\ndef intersection($array1;$array2): [$array1,$array2]|intersection;\r\n\r\n{\r\n    &quot;intersection of two arrays&quot;: intersection([range(10000)];[range(10000)+9997]),\r\n    &quot;intersection of four arrays&quot;: [[0,1,2,3,4],[1,2,3,4,5],[2,3,4,5,6],[3,4,5,6,7]]|intersection\r\n}\r\n```\r\nresult:\r\n```json\r\n{\r\n  &quot;intersection of two arrays&quot;: [\r\n    9997,\r\n    9998,\r\n    9999\r\n  ],\r\n  &quot;intersection of four arrays&quot;: [\r\n    3,\r\n    4\r\n  ]\r\n}\r\n```\r\n\r\n",
                "title": "how to get the intersection of two JSON arrays using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 5,
        "score": 12,
        "last_activity_date": 1744708960,
        "creation_date": 1468462483,
        "question_id": 38364458,
        "body_markdown": "Given arrays X and Y (preferably both as inputs, but otherwise, with one as input and the other hardcoded), how can I use jq to output the array containing all elements common to both? e.g. what is a value of f such that\r\n\r\n    echo &#39;[1,2,3,4]&#39; | jq &#39;f([2,4,6,8,10])&#39;\r\n\r\nwould output\r\n\r\n    [2,4]\r\n\r\n?\r\n\r\nI&#39;ve tried the following:\r\n\r\n    map(select(in([2,4,6,8,10])))  --&gt; outputs [1,2,3,4]\r\n    select(map(in([2,4,6,8,10])))  --&gt; outputs [1,2,3,4,5]",
        "link": "https://stackoverflow.com/questions/38364458/how-to-get-the-intersection-of-two-json-arrays-using-jq",
        "title": "how to get the intersection of two JSON arrays using jq"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 7,
                "is_accepted": true,
                "score": 7,
                "last_activity_date": 1468605888,
                "creation_date": 1468605888,
                "answer_id": 38402559,
                "question_id": 38396689,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "`$reg_exp` is a variable referring to your regular expression, `&quot;$reg_exp&quot;` is just a literal string.  Remove the quotes.  (and that extra map/select is redundant)\r\n\r\n    jq --arg reg_exp &quot;[a-z0-9]-[0-9]&quot; &#39;.imageIds | map(select(.imageTag | test($reg_exp)))&#39;",
                "title": "Passing regular expression from variable in jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 4,
        "last_activity_date": 1468605888,
        "creation_date": 1468587306,
        "last_edit_date": 1468588039,
        "question_id": 38396689,
        "body_markdown": "I&#39;m trying to filter [AWS ECR image list](https://docs.aws.amazon.com/cli/latest/reference/ecr/list-images.html) returned as JSON with [jq](https://stedolan.github.io/jq/) and regular expressions.\r\n\r\nFollowing command work as expected and return filtered list:\r\n\r\n    aws ecr list-images --registry-id 123456789012 --repository-name repo | jq &#39;.imageIds | map(select(.imageTag)) | map(select(.imageTag | test(&quot;[a-z0-9]-[0-9]&quot;)))&#39;\r\n\r\n    [\r\n      {\r\n        &quot;imageTag&quot;: &quot;bbe3d9-2&quot;,\r\n        &quot;imageDigest&quot;: &quot;sha256:4c0e92098010fd26e07962eb6e9c7d23315bd8f53885a0651d06c2e2e051317d&quot;\r\n      },\r\n      {\r\n        &quot;imageTag&quot;: &quot;3c840a-1&quot;,\r\n        &quot;imageDigest&quot;: &quot;sha256:9d05e04ccd18f2795121118bf0407b0636b9567c022908550c54e3c77534f8c1&quot;\r\n      },\r\n      {\r\n        &quot;imageTag&quot;: &quot;1c0d05-141&quot;,\r\n        &quot;imageDigest&quot;: &quot;sha256:a62faabb9199bfc449f0e0a6d3cdc9be57b688a0890f43684d6d89abcf909ada&quot;\r\n      }\r\n    ]\r\n\r\nBut when I try to pass regular expression as an argument to jq it return an empty array.\r\n\r\n    aws ecr list-images --registry-id 123456789012 --repository-name repo | jq --arg reg_exp &quot;[a-z0-9]-[0-9]&quot; &#39;.imageIds | map(select(.imageTag)) | map(select(.imageTag | test(&quot;$reg_exp&quot;)))&#39;\r\n    \r\n    []\r\n\r\nI have tried multiple ways to pass that variable, but just can&#39;t get it work. Other relevant information may be that I&#39;m using zsh on mac and my jq version is jq-1.5. Any help is appreciated.\r\n",
        "link": "https://stackoverflow.com/questions/38396689/passing-regular-expression-from-variable-in-jq",
        "title": "Passing regular expression from variable in jq"
    },
    {
        "tags": [
            "json",
            "csv",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3070043,
                    "reputation": 149,
                    "user_id": 2600945,
                    "user_type": "registered",
                    "accept_rate": 56,
                    "profile_image": "https://i.sstatic.net/L8Fhj.png?s=256",
                    "display_name": "hutanrimba",
                    "link": "https://stackoverflow.com/users/2600945/hutanrimba"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1468614399,
                "post_id": 38396925,
                "comment_id": 64217575,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1666129603,
                "post_id": 38396925,
                "comment_id": 130861824,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1468614660,
                "creation_date": 1468614660,
                "answer_id": 38404586,
                "question_id": 38396925,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Instead of using `select/1`, use `filter/1`, where:\r\n\r\n    def filter(f): if f then . else &quot;&quot; end;",
                "title": "jq filter to include unfound select"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1503883886,
                "creation_date": 1503883886,
                "answer_id": 45910774,
                "question_id": 38396925,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a solution which uses **from_entries** to handle the `.Tags`\r\n\r\n      .Reservations[]\r\n    | .OwnerId as $owner\r\n    | .Instances[]\r\n    | .InstanceId as $id    \r\n    | .Placement.AvailabilityZone as $az\r\n    | .Tags\r\n    | from_entries\r\n    | &quot;\\($owner),\\($id),\\($az),\\(.OtherTag//&quot;&quot;),\\(.Name//&quot;&quot;)&quot;",
                "title": "jq filter to include unfound select"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1666129576,
                "creation_date": 1666129576,
                "answer_id": 74117781,
                "question_id": 38396925,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use the [alternative operator `//`](https://stedolan.github.io/jq/manual/v1.6/#Alternativeoperator://):\r\n\r\n```\r\njq -r &#39;.Reservations[]\r\n | [.OwnerId,\r\n    .Instances[].InstanceId,\r\n    .Instances[].Placement.AvailabilityZone,\r\n    (.Instances[].Tags[]?|select(.Key==&quot;OtherTag&quot;)|.Value)//&quot;&quot;,\r\n    (.Instances[].Tags[]?|select(.Key==&quot;Name&quot;)|.Value)//&quot;&quot; ]\r\n| @csv&#39;\r\n```\r\n\r\nOutput:\r\n\r\n```\r\n&quot;683100487279&quot;,&quot;i-d414ce0b&quot;,&quot;ap-southeast-2b&quot;,&quot;&quot;,&quot;webserver2&quot;\r\n```",
                "title": "jq filter to include unfound select"
            }
        ],
        "is_answered": false,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1666129576,
        "creation_date": 1468588034,
        "last_edit_date": 1504606557,
        "question_id": 38396925,
        "body_markdown": "I am trying to filter through tags of this [JSON output](http://pastebin.com/RjjBH7g4) \r\n\r\nSelecting through the Tags[] and display the selected values if the key exist.\r\n\r\nMy jq filter looks like this :\r\n\r\n    jq -r &quot;.Reservations[]\r\n     | [.OwnerId,\r\n        .Instances[].InstanceId,\r\n        .Instances[].Placement.AvailabilityZone,\r\n        (.Instances[].Tags[]?|select(.Key==OtherTag)|.Value),\r\n        (.Instances[].Tags[]?|select(.Key==Name)|.Value) ]\r\n     | @csv&quot;\r\n\r\nThe output looks like this \r\n\r\n    &quot;xxxxxxxxxx9,i-d414ce0b,ap-southeast-2b,webserver2&quot;\r\n\r\nI would like it to include the unfounded select tags and fill it in as empty field in the csv \r\nlike below :\r\n\r\n    &quot;xxxxxxxxxx9,i-d414ce0b,ap-southeast-2b,,webserver2&quot;\r\n\r\nWhat should I do in jq to achieve that? Can someone give me an example?\r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/38396925/jq-filter-to-include-unfound-select",
        "title": "jq filter to include unfound select"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1468846801,
                "creation_date": 1468846801,
                "answer_id": 38437373,
                "question_id": 38437046,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "It should be:\r\n\r\n    jq &#39;(.file1[].environment[]|select(.name==&quot;DEBUG&quot;).value) |= 5&#39; file.json\r\n\r\nOutput:\r\n\r\n    {\r\n      &quot;file1&quot;: [\r\n        {\r\n          &quot;username&quot;: &quot;myname&quot;,\r\n          &quot;groupname&quot;: &quot;mypassword&quot;,\r\n          &quot;environment&quot;: [\r\n            {\r\n              &quot;name&quot;: &quot;UMASK&quot;,\r\n              &quot;value&quot;: &quot;022&quot;\r\n            },\r\n            {\r\n              &quot;name&quot;: &quot;DEBUG&quot;,\r\n              &quot;value&quot;: 5\r\n            }\r\n          ]\r\n        }\r\n      ]\r\n    }\r\n\r\n",
                "title": "Json file editing through jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1468848852,
        "creation_date": 1468845770,
        "last_edit_date": 1468848852,
        "question_id": 38437046,
        "body_markdown": "I have json\r\n\r\n    {\r\n    \t&quot;file1&quot;: [{\r\n    \t\t&quot;username&quot;: &quot;myname&quot;,\r\n    \t\t&quot;groupname&quot;: &quot;mypassword&quot;,\r\n    \t\t&quot;environment&quot;: [{\r\n    \t\t\t&quot;name&quot;: &quot;UMASK&quot;,\r\n    \t\t\t&quot;value&quot;: &quot;022&quot;\r\n    \t\t},\r\n    \t\t{\r\n    \t\t\t&quot;name&quot;: &quot;DEBUG&quot;,\r\n    \t\t\t&quot;value&quot;: &quot;2&quot;\r\n    \t\t}]\r\n    \t}]\r\n    }\r\n\r\nand want to change the value of DEBUG to 5. \r\n\r\nTried with below command\r\n\r\n&gt; jq .file1[0].environment sandeep.json |jq &#39;(.[] |select(.name ==\r\n&gt; &quot;DEBUG&quot;) | .value) |= &quot;5&quot;&#39;\r\n\r\nthis will return me specific portion of json like \r\n\r\n    [\r\n      {\r\n        &quot;name&quot;: &quot;UMASK&quot;,\r\n        &quot;value&quot;: &quot;022&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;DEBUG&quot;,\r\n        &quot;value&quot;: &quot;5&quot;\r\n      }\r\n    ]\r\n\r\nbut I want to see full json with changed value\r\n\r\n    {\r\n        &quot;file1&quot;: [{\r\n            &quot;username&quot;: &quot;myname&quot;,\r\n            &quot;groupname&quot;: &quot;mypassword&quot;,\r\n            &quot;environment&quot;: [{\r\n                &quot;name&quot;: &quot;UMASK&quot;,\r\n                &quot;value&quot;: &quot;022&quot;\r\n            },\r\n            {\r\n                &quot;name&quot;: &quot;DEBUG&quot;,\r\n                &quot;value&quot;: &quot;5&quot;\r\n            }]\r\n        }]\r\n    }\r\n\r\nPlease suggest me",
        "link": "https://stackoverflow.com/questions/38437046/json-file-editing-through-jq",
        "title": "Json file editing through jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1468872650,
                "last_edit_date": 1468872650,
                "creation_date": 1468871892,
                "answer_id": 38445020,
                "question_id": 38443179,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "**TL:DR;** Over an array of these objects, do `. as $dot | reduce ([$dot[] | paths(numbers)] | unique)[] as $path ({}; setpath($path; [$dot[] | getpath($path)] | add))`\r\n\r\n----\r\n\r\nSince your example input is not valid JSON, here&#39;s the JSON I used for testing this. Let me know if this doesn&#39;t match with yours:\r\n\r\n    [\r\n        {&quot;a&quot;: {&quot;b&quot;: 1, &quot;c&quot;: 2},         &quot;e&quot;: 3},\r\n        {&quot;a&quot;: {        &quot;c&quot;: 2, &quot;d&quot;: 3},         &quot;f&quot;: 4}\r\n    ]\r\n\r\n\r\nFirst, we&#39;ll look at how to perform this &quot;additive merge&quot; operation between two objects; afterwards, it should be easy to perform it over an array of objects.\r\n\r\nWe&#39;ll define our function as `additive_merge($xs; $ys)`. First, we&#39;ll get a list of all the paths on each of these objects in which there are numbers, with duplicates removed:\r\n\r\n    ([$xs, $ys | paths(numbers)] | unique) as $paths\r\n\r\nThen, we&#39;ll reduce this list of paths, with an empty object as the initial state, using `setpath` to set each path in the empty object to the sum of the values of those paths on `$xs` and `$ys`:\r\n\r\n    reduce $paths[] as $path ({}; setpath($path; [$xs, $ys | getpath($path)] | add))\r\n\r\nNow, all together, we have our `additive_merge` function:\r\n\r\n    def additive_merge($xs;$ys): reduce ([$xs, $ys | paths(numbers)] | unique)[] as $path ({}; setpath($path; [$xs, $ys | getpath($path)] | add));\r\n\r\nIf we want to run this function over an array, we can either reduce the array over this function:\r\n\r\n    reduce .[] as $x ({}; additive_merge(.; $x))\r\n\r\nOr modify the function so that it works over an array of objects, which is actually really easy; just use the dot input, save it to a variable and decompress it wherever `$xs, $ys` was used on the previous function:\r\n\r\n    def additive_merge: . as $dot | reduce ([$dot[] | paths(numbers)] | unique)[] as $path ({}; setpath($path; [$dot[] | getpath($path)] | add));\r\n\r\nHope this helps!",
                "title": "General recursive jq for summing all object values found at any level"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1501981669,
                "creation_date": 1501981669,
                "answer_id": 45527725,
                "question_id": 38443179,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a solution that uses **tostream**, **select**, **reduce**, **setpath** and **getpath**.\r\n\r\n    reduce (tostream|select(length==2)|.[0] = .[0][1:]) as [$p,$v] (\r\n       {};\r\n       setpath($p; getpath($p) + $v)\r\n    )\r\n",
                "title": "General recursive jq for summing all object values found at any level"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1501981669,
        "creation_date": 1468864816,
        "last_edit_date": 1495541298,
        "question_id": 38443179,
        "body_markdown": "I see [summing value in an array of maps][1] and wonder if there is an elegant way in jq to perform a general recursion over a set of objects and sum all values they contain to produce a single output object as the sum of all the other objects.\r\n\r\nIf it is easier to do this over a single input object which wraps all the other objects (to avoid slurping), that is fine too.\r\n\r\n - recurse over a slurped series of independent objects which have a lot of arbitrary nesting (arbitrary in the sense that I don&#39;t want to have to code jq for the specifics of the hierarchy of objects if general recursion can do what I want), and\r\n - sum every numeric value of a key:value pair found at any level\r\n\r\nEach object can have be sparse, but all coincident object key paths should sum their values to the same location in the single output object hierarchy.\r\n\r\nFor example (wrap an array around these 3 objects if that makes it easier):\r\n\r\n    { A { B { x:1, y:4      }, C { x:3,      z:6 }, t:2 }, s:5 }\r\n    { A { B { x:2     , z:3 },                      t:1 }      }\r\n    { A {                    , C {      y:3, z:2 }      }, s:3 }\r\n\r\nwould produce\r\n\r\n    { A { B { x:3, y:4, z:3 }, C { x:3, y:3, z:8 }, t:3 }, s:8 }\r\n\r\n  [1]: https://stackoverflow.com/questions/28484534/how-do-i-sum-the-values-in-an-array-of-maps-in-jq",
        "link": "https://stackoverflow.com/questions/38443179/general-recursive-jq-for-summing-all-object-values-found-at-any-level",
        "title": "General recursive jq for summing all object values found at any level"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 7983874,
                    "reputation": 7352,
                    "user_id": 6024122,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/wMjOLY8t.jpg?s=256",
                    "display_name": "Patrick Trentin",
                    "link": "https://stackoverflow.com/users/6024122/patrick-trentin"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1468933746,
                "post_id": 38459429,
                "comment_id": 64323261,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 3918083,
                    "reputation": 353,
                    "user_id": 3241408,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/6b51f5232f95f24df12fe0f5cd03abd7?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Ardling",
                    "link": "https://stackoverflow.com/users/3241408/ardling"
                },
                "reply_to_user": {
                    "account_id": 7983874,
                    "reputation": 7352,
                    "user_id": 6024122,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/wMjOLY8t.jpg?s=256",
                    "display_name": "Patrick Trentin",
                    "link": "https://stackoverflow.com/users/6024122/patrick-trentin"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1468934093,
                "post_id": 38459429,
                "comment_id": 64323542,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 4203120,
                    "reputation": 11256,
                    "user_id": 4923629,
                    "user_type": "registered",
                    "accept_rate": 92,
                    "profile_image": "https://i.sstatic.net/2abZO.png?s=256",
                    "display_name": "123",
                    "link": "https://stackoverflow.com/users/4923629/123"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1468934781,
                "post_id": 38459429,
                "comment_id": 64324076,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 3918083,
                    "reputation": 353,
                    "user_id": 3241408,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/6b51f5232f95f24df12fe0f5cd03abd7?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Ardling",
                    "link": "https://stackoverflow.com/users/3241408/ardling"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1468935057,
                "post_id": 38459429,
                "comment_id": 64324303,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 257842,
                    "reputation": 10719,
                    "user_id": 539599,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://i.sstatic.net/6iB0U.jpg?s=256",
                    "display_name": "Raphael",
                    "link": "https://stackoverflow.com/users/539599/raphael"
                },
                "reply_to_user": {
                    "account_id": 4203120,
                    "reputation": 11256,
                    "user_id": 4923629,
                    "user_type": "registered",
                    "accept_rate": 92,
                    "profile_image": "https://i.sstatic.net/2abZO.png?s=256",
                    "display_name": "123",
                    "link": "https://stackoverflow.com/users/4923629/123"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1572353943,
                "post_id": 38459429,
                "comment_id": 103526610,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 48,
                "is_accepted": true,
                "score": 48,
                "last_activity_date": 1468937387,
                "creation_date": 1468937387,
                "answer_id": 38460947,
                "question_id": 38459429,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Use `..` to iterate recursively, and get all the `.error` values. If they&#39;re `null`, remove them:\r\n\r\n    jq &#39;.. | .error? // empty&#39;\r\n\r\nAlternatively, instead of using `empty` you can select the elements that are strings with `strings`:\r\n\r\n    jq &#39;.. | .error? | strings&#39;",
                "title": "Recursive search values by key"
            },
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1501981997,
                "creation_date": 1501981997,
                "answer_id": 45527749,
                "question_id": 38459429,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a solution that uses **tostream** and **select**\r\n\r\n      tostream\r\n    | select(length==2 and .[0][-1]==&quot;error&quot; and .[1]!=null) as [$p,$v]\r\n    | $v",
                "title": "Recursive search values by key"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 20,
        "last_activity_date": 1501981997,
        "creation_date": 1468933362,
        "last_edit_date": 1468935227,
        "question_id": 38459429,
        "body_markdown": "I have a JSON like this:\r\n\r\n    { \r\n      &quot;A&quot;: { &quot;error&quot;: null },\r\n      &quot;B&quot;: { &quot;C&quot;: {&quot;error&quot;: &quot;error string&quot;}},\r\n      &quot;C&quot;: { &quot;D&quot;: {&quot;error&quot;: null}},\r\n      &quot;D&quot;: { &quot;error&quot;: &quot;err str&quot;}\r\n    }\r\n\r\nend I want to find all values of **error** keys which are not **null**.\r\n\r\nFor my example it should return \r\n\r\n    &quot;error string&quot;\r\n    &quot;err str&quot;\r\n\r\n \r\nHow can I do it? Is it possible with **jq**?",
        "link": "https://stackoverflow.com/questions/38459429/recursive-search-values-by-key",
        "title": "Recursive search values by key"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1469107567,
                "last_edit_date": 1469107567,
                "creation_date": 1468958828,
                "answer_id": 38467571,
                "question_id": 38466960,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The key is to select the documents that have the `_attachments` key, then replace them with the `|=` operator.\r\n\r\n    jq --argjson new &quot;$doc&quot; &#39;(.docs[]| select(has(&quot;_attachments&quot;))) |= $new&#39; docs.json\r\n\r\n`--argjson` is used to pass the value of `$doc` into the filter as a raw JSON value.",
                "title": "Find and replace json in a file using jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1503885748,
                "creation_date": 1503885748,
                "answer_id": 45910941,
                "question_id": 38466960,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "If you cannot use `--argjson` you could use the `-s` slurp option along with a filter such as\r\n\r\n      .[0] as $new\r\n    | .[1]\r\n    | ( .docs[] | select(has(&quot;_attachments&quot;)) ) = $new\r\n\r\nif the above is in `filter.jq`, your new document in `new.json` and your data contains a single object as you describe in `docs.json` then\r\n\r\n    jq -M -s -f filter.jq new.json docs.json\r\n\r\nwill produce\r\n\r\n    {\r\n      &quot;number_of_docs&quot;: &quot;1000&quot;,\r\n      &quot;docs&quot;: [\r\n        {\r\n          &quot;_id&quot;: &quot;000001&quot;,\r\n          &quot;_rev&quot;: &quot;0&quot;,\r\n          &quot;_content&quot;: &quot;abcdefg&quot;\r\n        },\r\n        {\r\n          &quot;_id&quot;: &quot;000002_masked&quot;,\r\n          &quot;_rev&quot;: &quot;0&quot;,\r\n          &quot;_content&quot;: &quot;[Document content has been masked for confidentiality.]&quot;,\r\n          &quot;_attachments&quot;: {\r\n            &quot;confidential.png&quot;: {\r\n              &quot;content_type&quot;: &quot;image/png&quot;\r\n            }\r\n          }\r\n        },\r\n        {\r\n          &quot;_id&quot;: &quot;000003&quot;,\r\n          &quot;_rev&quot;: &quot;0&quot;,\r\n          &quot;_content&quot;: &quot;opqrstuv&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\nNote - I don&#39;t have jq-1.3 so I&#39;m only able to verify this with jq-1.5 but I believe this should work with jq-1.3",
                "title": "Find and replace json in a file using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1503885748,
        "creation_date": 1468956555,
        "question_id": 38466960,
        "body_markdown": "I am new at using jq and could use help with the following...\r\n\r\nIn essence, I am trying to &quot;find and replace&quot; a block of json in a file using a bash script.\r\n\r\nI have a file called docs.json to where I retrieved a set of doc entries:\r\n\r\n    {\r\n    \t&quot;number_of_docs&quot;: &quot;1000&quot;,\r\n    \t&quot;docs&quot;: [{\r\n    \t{\r\n    \t\t&quot;_id&quot;: &quot;000001&quot;,\r\n    \t\t&quot;_rev&quot;: &quot;0&quot;,\r\n    \t\t&quot;_content&quot;: &quot;abcdefg&quot;\r\n    \t},\r\n    \t{\r\n    \t\t&quot;_id&quot;: &quot;000002&quot;,\r\n    \t\t&quot;_rev&quot;: &quot;0&quot;,\r\n    \t\t&quot;_content&quot;: &quot;hijklmn&quot;,\r\n    \t\t&quot;_attachments&quot;: {\r\n    \t\t\t&quot;image1.png&quot;: {\r\n    \t\t\t\t&quot;content_type&quot;: &quot;image/png&quot;\r\n    \t\t\t\t...\r\n    \t\t\t}\r\n    \t\t}\r\n    \t},\r\n    \t{\r\n    \t\t&quot;_id&quot;: &quot;000003&quot;,\r\n    \t\t&quot;_rev&quot;: &quot;0&quot;,\r\n    \t\t&quot;_content&quot;: &quot;opqrstuv&quot;\r\n    \t}]\r\n    }\r\n\r\nAnd I&#39;m trying to replace all the doc entries (the entire block, not just the value of the keys) that have &quot;_attachments&quot; with a new block of json that is stored in a variable named &quot;doc&quot;:\r\n\r\n\t{\r\n\t\t&quot;_id&quot;: &quot;000002_masked&quot;,\r\n\t\t&quot;_rev&quot;: &quot;0&quot;,\r\n\t\t&quot;_content&quot;: &quot;[Document content has been masked for confidentiality.]&quot;,\r\n\t\t&quot;_attachments&quot;: {\r\n\t\t\t&quot;confidential.png&quot;: {\r\n\t\t\t\t&quot;content_type&quot;: &quot;image/png&quot;\r\n\t\t\t\t...\r\n\t\t\t}\r\n\t\t}\r\n\t}\r\n\r\nIs what I&#39;m trying to do possible with jq and running from within a bash script?\r\n\r\nThank you for the help and tips, in advance.",
        "link": "https://stackoverflow.com/questions/38466960/find-and-replace-json-in-a-file-using-jq",
        "title": "Find and replace json in a file using jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 10,
                "is_accepted": false,
                "score": 10,
                "last_activity_date": 1468990733,
                "creation_date": 1468990733,
                "answer_id": 38472634,
                "question_id": 38471393,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Assuming your input is actually an array of those objects, you could do this:\r\n\r\n    $ jq --arg name &quot;ansible&quot; &#39;.[] | select(.name == $name).id&#39; input.json",
                "title": "Extract element based on where clause in jq json"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1501982733,
                "creation_date": 1501982733,
                "answer_id": 45527800,
                "question_id": 38471393,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Since you indicate the input is very big you may want to use **first**.  This solution will return the id of the first match found and then stop.\r\n\r\n     first(.[] | if .name == &quot;ansible&quot; then .id else empty end)",
                "title": "Extract element based on where clause in jq json"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 4,
        "last_activity_date": 1504642768,
        "creation_date": 1468982111,
        "last_edit_date": 1504642768,
        "question_id": 38471393,
        "body_markdown": "My Json structure is like below.\r\n\r\nHow can i extract id of project whose name is ansible using jq?\r\n\r\nThe json file is very big\r\n\r\nhttps://stedolan.github.io/jq/manual/\r\n\r\n      {\r\n        &quot;id&quot;: 38,\r\n        &quot;name&quot;: &quot;ansible&quot;,\r\n        &quot;path&quot;: &quot;ansible&quot;,\r\n        &quot;description&quot;: &quot;Ansible playbooks, roles, and supporting tools repos&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: 18,\r\n        &quot;name&quot;: &quot;Analytics&quot;,\r\n        &quot;path&quot;: &quot;analytics&quot;,\r\n        &quot;description&quot;: &quot;Big Data Analytics projects&quot;\r\n      }",
        "link": "https://stackoverflow.com/questions/38471393/extract-element-based-on-where-clause-in-jq-json",
        "title": "Extract element based on where clause in jq json"
    },
    {
        "tags": [
            "json",
            "linux",
            "bash",
            "ubuntu",
            "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": 1469030195,
                "post_id": 38484511,
                "comment_id": 64372621,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1469028838,
                "last_edit_date": 1495541686,
                "creation_date": 1469028838,
                "answer_id": 38484829,
                "question_id": 38484511,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You are interchanging bash arrays and JSON arrays. When you are creating `accounts` array, bash splits the elements per each whitespace. That&#39;s why you don&#39;t get what you expect. You can try the following:\r\n\r\n    declare -A accounts\r\n\r\n    while IFS=&quot;=&quot; read -r key value\r\n    do\r\n        accounts[$key]=&quot;$value&quot;\r\n    done &lt; &lt;(jq -r &quot;to_entries|map(\\&quot;\\(.key)=\\(.value)\\&quot;)|.[]&quot; &lt;&lt;&lt; $system_user)\r\n\r\n    for account in &quot;${accounts[@]}&quot;\r\n    do\r\n        printf &quot;$account\\n&quot;\r\n    done\r\n\r\n(stolen from here: https://stackoverflow.com/a/26717401/328977)\r\n\r\nto get the following output: \r\n\r\n    {&quot;username&quot;:&quot;user1&quot;,&quot;password&quot;:&quot;pwd1&quot;,&quot;group&quot;:&quot;usergroup1&quot;}\r\n    {&quot;username&quot;:&quot;user2&quot;,&quot;password&quot;:&quot;pwd2&quot;,&quot;group&quot;:&quot;usergroup2&quot;}\r\n    {&quot;username&quot;:&quot;user3&quot;,&quot;password&quot;:&quot;pwd3&quot;,&quot;group&quot;:&quot;usergroup3&quot;}",
                "title": "Bash Jq parse json string"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1469030691,
                "creation_date": 1469030691,
                "answer_id": 38485514,
                "question_id": 38484511,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "With the `-c` option, you can print each JSON object on a single line, making it easier to populate the array you want.\r\n\r\n    $ readarray -t arr &lt; &lt;(jq -c &#39;.[]&#39; &lt;&lt;&lt; &quot;[{\\&quot;username\\&quot;:\\&quot;user1\\&quot;,\\&quot;password\\&quot;:\\&quot;pwd1\\&quot;,\\&quot;group\\&quot;:\\&quot;usergroup1\\&quot;},{\\&quot;username\\&quot;:\\&quot;user2\\&quot;,\\&quot;password\\&quot;:\\&quot;pwd2\\&quot;,\\&quot;group\\&quot;:\\&quot;usergroup2\\&quot;},{\\&quot;username\\&quot;:\\&quot;user3\\&quot;,\\&quot;password\\&quot;:\\&quot;pwd3\\&quot;,\\&quot;group\\&quot;:\\&quot;usergroup3\\&quot;}]&quot;) \r\n    $ printf &quot;Object: %s\\n&quot; &quot;${arr[@]}&quot;\r\n    Object: {&quot;username&quot;:&quot;user1&quot;,&quot;password&quot;:&quot;pwd1&quot;,&quot;group&quot;:&quot;usergroup1&quot;}\r\n    Object: {&quot;username&quot;:&quot;user2&quot;,&quot;password&quot;:&quot;pwd2&quot;,&quot;group&quot;:&quot;usergroup2&quot;}\r\n    Object: {&quot;username&quot;:&quot;user3&quot;,&quot;password&quot;:&quot;pwd3&quot;,&quot;group&quot;:&quot;usergroup3&quot;}",
                "title": "Bash Jq parse json string"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1469030691,
        "creation_date": 1469026023,
        "question_id": 38484511,
        "body_markdown": "I&#39;ve to call a file and pass a json as parameters in this way\r\n(suppose that my file is called test.sh), from bash I need to do something like this:\r\n\r\n    ./test.sh &quot;[{\\&quot;username\\&quot;:\\&quot;user1\\&quot;,\\&quot;password\\&quot;:\\&quot;pwd1\\&quot;,\\&quot;group\\&quot;:\\&quot;usergroup1\\&quot;},{\\&quot;username\\&quot;:\\&quot;user2\\&quot;,\\&quot;password\\&quot;:\\&quot;pwd2\\&quot;,\\&quot;group\\&quot;:\\&quot;usergroup2\\&quot;},{\\&quot;username\\&quot;:\\&quot;user3\\&quot;,\\&quot;password\\&quot;:\\&quot;pwd3\\&quot;,\\&quot;group\\&quot;:\\&quot;usergroup3\\&quot;}]&quot;\r\n\r\n\r\nand the content of test.sh is the following\r\n\r\n    #!/bin/bash\r\n\r\n    #read the json\r\n    system_user=&quot;$1&quot;\r\n\r\n    printf &quot;$system_user&quot;\r\n\r\n    accounts=($(jq -s &quot;.[]&quot; &lt;&lt;&lt; $system_user))\r\n\r\n    printf &quot;$accounts&quot;\r\n\r\n    for account in &quot;${accounts[@]}&quot;\r\n    do\r\n      printf &quot;\\n\\n$account\\n\\n&quot;\r\n    done \r\n\r\nthe output of -&gt; printf &quot;$system_user&quot;  is\r\n  \r\n    [{&quot;username&quot;:&quot;user1&quot;,&quot;password&quot;:&quot;pwd1&quot;,&quot;group&quot;:&quot;usergroup1&quot;},{&quot;username&quot;:&quot;user2&quot;,&quot;password&quot;:&quot;pwd2&quot;,&quot;group&quot;:&quot;usergroup2&quot;},{&quot;username&quot;:&quot;user3&quot;,&quot;password&quot;:&quot;pwd3&quot;,&quot;group&quot;:&quot;usergroup3&quot;}]\r\n\r\nbut the output of -&gt; printf &quot;$accounts&quot; is something like this\r\n\r\n[&lt;br/&gt;\r\n[&lt;br/&gt;\r\n{&lt;br/&gt;\r\n&quot;username&quot;:&lt;br/&gt;\r\n&quot;user1&quot;&lt;br/&gt;\r\netc. etc. one object for each token :-( &lt;br/&gt;&lt;br/&gt;\r\n\r\nand so on, but what I was expecting is an array of three object (like you can test on jqplay.org)\r\n\r\n     {\r\n       &quot;username&quot;: &quot;user1&quot;,\r\n       &quot;password&quot;: &quot;pwd1&quot;,\r\n       &quot;group&quot;: &quot;usergroup1&quot;\r\n     }\r\n     {\r\n       &quot;username&quot;: &quot;user2&quot;,\r\n       &quot;password&quot;: &quot;pwd2&quot;,\r\n       &quot;group&quot;: &quot;usergroup2&quot;\r\n     }\r\n     {\r\n       &quot;username&quot;: &quot;user3&quot;,\r\n       &quot;password&quot;: &quot;pwd3&quot;,\r\n       &quot;group&quot;: &quot;usergroup3&quot;\r\n     }\r\n\r\n\r\nIn this way I can make a foreach on ${accounts[@]}\r\n\r\nWhat I&#39;m doing wrong?\r\nThank you\r\n\r\n\r\n\r\n\r\n    \r\n",
        "link": "https://stackoverflow.com/questions/38484511/bash-jq-parse-json-string",
        "title": "Bash Jq parse json string"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 250095,
                    "reputation": 442,
                    "user_id": 526601,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/5758e6d7b70e29dc1301744bc6b812c6?s=256&d=identicon&r=PG",
                    "display_name": "deltaray",
                    "link": "https://stackoverflow.com/users/526601/deltaray"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1670502740,
                "post_id": 38495941,
                "comment_id": 131892797,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 8,
                "is_accepted": true,
                "score": 8,
                "last_activity_date": 1469083619,
                "last_edit_date": 1469083619,
                "creation_date": 1469083269,
                "answer_id": 38496753,
                "question_id": 38495941,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Unfortunately, only basic mathematical operations are available on numbers.  However, you should have access to [C Math](https://stedolan.github.io/jq/manual/#Math) functions available on your platform. So a lot of what&#39;s in the cstdlib should be fair game, such as the [pow()](http://www.cplusplus.com/reference/cmath/pow/) function.\r\n\r\n    (.value | tonumber) / pow(1024; 4)\r\n\r\nOtherwise, I&#39;m not aware of any other approach, other than passing that in as an argument.\r\n\r\n    $ jq --argjson div &quot;$((1024**4))&quot; &#39;(.value | tonumber) / $div&#39; input.json",
                "title": "Using exponential powers in jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 5,
        "last_activity_date": 1469083619,
        "creation_date": 1469080580,
        "question_id": 38495941,
        "body_markdown": "I get JSON objects containing a byte and I&#39;m converting over to TB. Generally the way I prefer to do this is divide by 1024 to the 4th power. \r\n\r\nI&#39;m using `jq &#39;.value|tonumber|(./(1024*1024*1024*1024))&#39;`, but I&#39;d prefer to replace the `1024*1024*1024*1024` with something like `1024**4` or `1024^4` is there anyway to do this in `jq`?  Is there another way I&#39;m missing?\r\n\r\nData is simple and looks like this:\r\n\r\n    {\r\n      &quot;value&quot;: &quot;43165913081459&quot;,\r\n      &quot;name&quot;: &quot;AvailableStorage&quot;\r\n    }\r\n",
        "link": "https://stackoverflow.com/questions/38495941/using-exponential-powers-in-jq",
        "title": "Using exponential powers in jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 715193,
                    "reputation": 2774,
                    "user_id": 639580,
                    "user_type": "registered",
                    "accept_rate": 62,
                    "profile_image": "https://www.gravatar.com/avatar/21b3041d664dd92d697bd3e0bca40fb7?s=256&d=identicon&r=PG",
                    "display_name": "Tony",
                    "link": "https://stackoverflow.com/users/639580/tony"
                },
                "edited": false,
                "score": 27,
                "creation_date": 1542228869,
                "post_id": 38500363,
                "comment_id": 93497873,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 8,
                "is_accepted": false,
                "score": 6,
                "last_activity_date": 1658444162,
                "last_edit_date": 1658444162,
                "creation_date": 1469094120,
                "answer_id": 38500589,
                "question_id": 38500363,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "use `map`\r\n\r\n    cat raw.json|jq -r -c &#39;map(select(.a==&quot;x&quot;))|.[1]&#39;\r\n\r\n`map` receives a **filter** to filter an array. \r\n\r\nthis command\r\n\r\n    cat raw.json|jq -r -c &#39;map(select(.a==&quot;x&quot;))&#39;\r\n\r\ngive the middle result \r\n\r\n&gt;     [{&quot;a&quot;:&quot;x&quot;,&quot;b&quot;:true},{&quot;a&quot;:&quot;x&quot;,&quot;b&quot;:false}]\r\n\r\n`.[1]` take the first element\r\n\r\n",
                "title": "get the first (or n&#39;th) element in a jq json parsing"
            },
            {
                "up_vote_count": 148,
                "is_accepted": true,
                "score": 148,
                "last_activity_date": 1563980308,
                "last_edit_date": 1563980308,
                "creation_date": 1469094167,
                "answer_id": 38500610,
                "question_id": 38500363,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can wrap the results from `select` in an array:\r\n\r\n    jq &#39;[.[]|select(.a==&quot;x&quot;)][0]&#39; your.json\r\n\r\nOutput:\r\n\r\n    {\r\n      &quot;a&quot;: &quot;x&quot;,\r\n      &quot;b&quot;: false\r\n    }\r\n\r\n",
                "title": "get the first (or n&#39;th) element in a jq json parsing"
            },
            {
                "up_vote_count": 51,
                "is_accepted": false,
                "score": 51,
                "last_activity_date": 1629996806,
                "last_edit_date": 1629996806,
                "creation_date": 1503894134,
                "answer_id": 45911762,
                "question_id": 38500363,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "jq also provides [`first/0`](https://github.com/stedolan/jq/blob/jq-1.6/src/builtin.jq#L178), [`last/0`](https://github.com/stedolan/jq/blob/jq-1.6/src/builtin.jq#L179), [`nth/1`](https://github.com/stedolan/jq/blob/jq-1.6/src/builtin.jq#L180) so in this case the filter\r\n\r\n      ( map(select(.a == &quot;x&quot;)) | first  )\r\n    , ( map(select(.a == &quot;x&quot;)) | last   ) \r\n    , ( map(select(.a == &quot;x&quot;)) | nth(1) )\r\n \r\nproduces\r\n \r\n    {\r\n      &quot;a&quot;: &quot;x&quot;,\r\n      &quot;b&quot;: true\r\n    }\r\n    {\r\n      &quot;a&quot;: &quot;x&quot;,\r\n      &quot;b&quot;: false\r\n    }\r\n    {\r\n      &quot;a&quot;: &quot;x&quot;,\r\n      &quot;b&quot;: false\r\n    }\r\n \r\nAdditional streaming forms [&#39;first/1&#39;](https://github.com/stedolan/jq/blob/jq-1.6/src/builtin.jq#L175), [&#39;last/1&#39;](https://github.com/stedolan/jq/blob/jq-1.6/src/builtin.jq#L176) and [&#39;nth/2&#39;](https://github.com/stedolan/jq/blob/jq-1.6/src/builtin.jq#L177) are also available so with this data\r\n    \r\n      ( first(.[]  | select(.a == &quot;x&quot;)) )   \r\n    , ( last(.[]   | select(.a == &quot;x&quot;)) )\r\n    , ( nth(1; .[] | select(.a == &quot;x&quot;)) )\r\n\r\nproduces\r\n\r\n    {\r\n      &quot;a&quot;: &quot;x&quot;,\r\n      &quot;b&quot;: true\r\n    }\r\n    {\r\n      &quot;a&quot;: &quot;x&quot;,\r\n      &quot;b&quot;: false\r\n    }\r\n    {\r\n      &quot;a&quot;: &quot;x&quot;,\r\n      &quot;b&quot;: false\r\n    }",
                "title": "get the first (or n&#39;th) element in a jq json parsing"
            },
            {
                "up_vote_count": 31,
                "is_accepted": false,
                "score": 31,
                "last_activity_date": 1705601239,
                "last_edit_date": 1705601239,
                "creation_date": 1623208599,
                "answer_id": 67897069,
                "question_id": 38500363,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Many of the previous answers work by avoiding to create a stream of objects in the first place. But what if you are *starting* with a stream of objects—for example JSON-formatted application logs? If your input file (or stream) has multiple objects in it, all you need to do to choose a single entry from a stream of independent objects is to use the `--slurp` option (or `-s` for the short form):\r\n\r\n&gt;        o   --slurp/-s:\r\n&gt;\r\n&gt;            Instead of running the filter for each JSON object in the input, read \r\n&gt;            the entire input stream into a large array and run the filter just once.\r\n\r\nThen you can just index into the array.  For example, to get second item (with index 1):\r\n\r\n    jq --slurp &#39;.[1]&#39;\r\n\r\nPutting this together with your original question, where you want to select that item from a stream:\r\n\r\n    echo &#39;{&quot;a&quot;:&quot;x&quot;, &quot;b&quot;:true} {&quot;a&quot;:&quot;XML&quot;, &quot;b&quot;:false}&#39; | jq --slurp &#39;.[1]&#39;\r\n\r\nwhich results in this output:\r\n\r\n```\r\n{\r\n  &quot;a&quot;: &quot;XML&quot;,\r\n  &quot;b&quot;: false\r\n}\r\n```\r\n\r\nThis method does, of course, read the entire input into memory. For an approach that avoids this problem, see [this answer](https://stackoverflow.com/a/73559001/2562319) from Martin von Wittich.",
                "title": "get the first (or n&#39;th) element in a jq json parsing"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1661962866,
                "creation_date": 1661962866,
                "answer_id": 73559001,
                "question_id": 38500363,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I have the same scenario as jbyler - I want to parse N lines of a JSON log, where each line is a single object:\r\n\r\n```\r\nhost ~ # head /var/log/nginx/access.log.json | cut -c 1-80 \r\n{&quot;remote_addr&quot;:&quot;127.0.0.1&quot;,&quot;remote_port&quot;:&quot;47700&quot;,&quot;time_iso8601&quot;:&quot;2022-08-31T00:0\r\n{&quot;remote_addr&quot;:&quot;127.0.0.1&quot;,&quot;remote_port&quot;:&quot;35576&quot;,&quot;time_iso8601&quot;:&quot;2022-08-31T00:0\r\n{&quot;remote_addr&quot;:&quot;127.0.0.1&quot;,&quot;remote_port&quot;:&quot;47708&quot;,&quot;time_iso8601&quot;:&quot;2022-08-31T00:0\r\n{&quot;remote_addr&quot;:&quot;127.0.0.1&quot;,&quot;remote_port&quot;:&quot;52974&quot;,&quot;time_iso8601&quot;:&quot;2022-08-31T00:0\r\n{&quot;remote_addr&quot;:&quot;127.0.0.1&quot;,&quot;remote_port&quot;:&quot;52976&quot;,&quot;time_iso8601&quot;:&quot;2022-08-31T00:0\r\n{&quot;remote_addr&quot;:&quot;127.0.0.1&quot;,&quot;remote_port&quot;:&quot;51414&quot;,&quot;time_iso8601&quot;:&quot;2022-08-31T00:0\r\n{&quot;remote_addr&quot;:&quot;127.0.0.1&quot;,&quot;remote_port&quot;:&quot;41942&quot;,&quot;time_iso8601&quot;:&quot;2022-08-31T00:1\r\n{&quot;remote_addr&quot;:&quot;127.0.0.1&quot;,&quot;remote_port&quot;:&quot;41946&quot;,&quot;time_iso8601&quot;:&quot;2022-08-31T00:1\r\n{&quot;remote_addr&quot;:&quot;127.0.0.1&quot;,&quot;remote_port&quot;:&quot;37982&quot;,&quot;time_iso8601&quot;:&quot;2022-08-31T00:1\r\n{&quot;remote_addr&quot;:&quot;127.0.0.1&quot;,&quot;remote_port&quot;:&quot;56602&quot;,&quot;time_iso8601&quot;:&quot;2022-08-31T00:1\r\n```\r\n\r\nI do not like the `--slurp` solution because this will cause `jq` to read the entire file, when I might only be interested in the first N lines.\r\n\r\nThe solution for this seems to be the [`input`](https://stedolan.github.io/jq/manual/#input) function combined with `jq -n`, which reads a single input object:\r\n\r\n```\r\nhost ~ # cat /var/log/nginx/access.log.json | jq -r -n &#39;input | [.remote_addr, .remote_port, .time_iso8601] | @tsv&#39; \r\n127.0.0.1       47700   2022-08-31T00:02:53+02:00\r\n```\r\n\r\nCombined with [`range`](https://stedolan.github.io/jq/manual/#range(upto),range(from;upto)range(from;upto;by)), I can use it to read up to N input objects:\r\n\r\n```\r\nhost ~ # cat /var/log/nginx/access.log.json | jq -r -n &#39;range(10) as $i | input | [.remote_addr, .remote_port, .time_iso8601] | @tsv&#39;\r\n127.0.0.1       47700   2022-08-31T00:02:53+02:00\r\n127.0.0.1       35576   2022-08-31T00:02:53+02:00\r\n127.0.0.1       47708   2022-08-31T00:02:53+02:00\r\n127.0.0.1       52974   2022-08-31T00:07:53+02:00\r\n127.0.0.1       52976   2022-08-31T00:07:53+02:00\r\n127.0.0.1       51414   2022-08-31T00:07:58+02:00\r\n127.0.0.1       41942   2022-08-31T00:12:53+02:00\r\n127.0.0.1       41946   2022-08-31T00:12:53+02:00\r\n127.0.0.1       37982   2022-08-31T00:13:03+02:00\r\n127.0.0.1       56602   2022-08-31T00:17:53+02:00\r\n```\r\n\r\nBe careful with wrapping this into an array though - doing it wrong will cause `jq` to *reevaluate* the `[range(10) as $i | input]` expression, so here I&#39;m not getting elements `[0, 1, 2]`, but `[0, 11, 22]`:\r\n\r\n```\r\n# WRONG, DON&#39;T DO THIS\r\nhost ~ # cat /var/log/nginx/access.log.json | jq -r -n &#39;[range(10) as $i | input][0,1,2] | [.remote_addr, .remote_port, .time_iso8601] | @tsv&#39;\r\n127.0.0.1       47700   2022-08-31T00:02:53+02:00\r\n127.0.0.1       59784   2022-08-31T00:18:22+02:00\r\n127.0.0.1       34316   2022-08-31T00:37:53+02:00\r\n```\r\n\r\nTo safely access the same array multiple times, you need to have a pipe in between:\r\n\r\n```\r\nhost ~ # cat /var/log/nginx/access.log.json | jq -r -n &#39;[range(10) as $i | input] | .[0,1,2] | [.remote_addr, .remote_port, .time_iso8601] | @tsv&#39;\r\n127.0.0.1       47700   2022-08-31T00:02:53+02:00\r\n127.0.0.1       35576   2022-08-31T00:02:53+02:00\r\n127.0.0.1       47708   2022-08-31T00:02:53+02:00\r\n```\r\n\r\nThis way, you can take up to N objects from the input file, and then extract arbitrary ones from this selection.",
                "title": "get the first (or n&#39;th) element in a jq json parsing"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1716461374,
                "creation_date": 1716461374,
                "answer_id": 78522591,
                "question_id": 38500363,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This could be solved with `first` (even without a map): \r\n```bash\r\ncat your.json | jq first\r\n```\r\nor \r\n```bash\r\njq first your.json\r\n```",
                "title": "get the first (or n&#39;th) element in a jq json parsing"
            }
        ],
        "is_answered": true,
        "answer_count": 6,
        "score": 126,
        "last_activity_date": 1716461374,
        "creation_date": 1469093521,
        "question_id": 38500363,
        "body_markdown": "I can get the 1st element in a json inside []\r\n\r\n    $ echo &#39;[{&quot;a&quot;:&quot;x&quot;, &quot;b&quot;:true}, {&quot;a&quot;:&quot;XML&quot;, &quot;b&quot;:false}]&#39; | jq &#39;.[1]&#39;\r\n    {\r\n      &quot;a&quot;: &quot;XML&quot;,\r\n      &quot;b&quot;: false\r\n    }\r\nBut if the json is already disassembled (for instance, after filtering entries using &#39;select&#39;), how can I choose a single entry and avoid the error seen here?\r\n\r\n    $ echo &#39;[{&quot;a&quot;:&quot;x&quot;, &quot;b&quot;:true}, {&quot;a&quot;:&quot;x&quot;, &quot;b&quot;:false},{&quot;a&quot;:&quot;XML&quot;, &quot;b&quot;:false}]&#39; | jq &#39;.[] | select( .a == &quot;x&quot;)&#39;\r\n    {\r\n      &quot;a&quot;: &quot;x&quot;,\r\n      &quot;b&quot;: true\r\n    }\r\n    {\r\n      &quot;a&quot;: &quot;x&quot;,\r\n      &quot;b&quot;: false\r\n    }\r\n    $ echo &#39;[{&quot;a&quot;:&quot;x&quot;, &quot;b&quot;:true}, {&quot;a&quot;:&quot;x&quot;, &quot;b&quot;:false},{&quot;a&quot;:&quot;XML&quot;, &quot;b&quot;:false}]&#39; | jq &#39;.[] | select( .a == &quot;x&quot;) | .[1]&#39;\r\n    jq: error (at &lt;stdin&gt;:1): Cannot index object with number\r\n\r\n",
        "link": "https://stackoverflow.com/questions/38500363/get-the-first-or-nth-element-in-a-jq-json-parsing",
        "title": "get the first (or n&#39;th) element in a jq json parsing"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1010747,
                    "reputation": 4623,
                    "user_id": 1023375,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/4a88005c4a96d91fec707fab7a69bb8a?s=256&d=identicon&r=PG",
                    "display_name": "Bram",
                    "link": "https://stackoverflow.com/users/1023375/bram"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1469112445,
                "post_id": 38505083,
                "comment_id": 64412963,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1469127989,
                "last_edit_date": 1469127989,
                "creation_date": 1469127413,
                "answer_id": 38512308,
                "question_id": 38505083,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You can use the following jq command:\r\n\r\n    jq -r &#39;.[]| &quot;\\(.name) \\(.protection.enabled)&quot;&#39; a.json \r\n\r\nYou can pipe it to `column` to get aligned output:\r\n\r\n    jq -r &#39;.[]| &quot;\\(.name) \\(.protection.enabled)&quot;&#39; a.json | column -t\r\n\r\nOutput:\r\n\r\n    ProductCostingBJF_v2.3.0  true\r\n    master                    true",
                "title": "Extracting multiple fields from a JSON payload"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1523582101,
                "creation_date": 1523582101,
                "answer_id": 49807918,
                "question_id": 38505083,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is alternative syntax using joined lines (`-j`):\r\n\r\n    $ jq -j &#39;.[] | .name, &quot;\\t&quot;, .protection.enabled, &quot;\\n&quot;&#39; payload.json \r\n    ProductCostingBJF_v2.3.0\ttrue\r\n    master\ttrue",
                "title": "Extracting multiple fields from a JSON payload"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1523582101,
        "creation_date": 1469106315,
        "last_edit_date": 1504654079,
        "question_id": 38505083,
        "body_markdown": "I have the following payload\r\n\r\n    [\r\n      {\r\n        &quot;name&quot;: &quot;ProductCostingBJF_v2.3.0&quot;,\r\n        &quot;commit&quot;: {\r\n        },\r\n        &quot;protection&quot;: {\r\n          &quot;enabled&quot;: true,\r\n          &quot;required_status_checks&quot;: {\r\n            &quot;enforcement_level&quot;: &quot;off&quot;,\r\n            &quot;contexts&quot;: []\r\n          }\r\n        }\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;master&quot;,\r\n        &quot;commit&quot;: {\r\n        },\r\n        &quot;protection&quot;: {\r\n          &quot;enabled&quot;: true,\r\n          &quot;required_status_checks&quot;: {\r\n            &quot;enforcement_level&quot;: &quot;off&quot;,\r\n            &quot;contexts&quot;: []\r\n          }\r\n        }\r\n      }\r\n    ]\r\n\r\ncan you help with the jq syntax to pull out and present\r\n\r\n    ProductCostingBJF_v2.3.0    true\r\n    master                      true\r\n\r\nI got the first part ... I can get the branch name with \r\n\r\n    jq  -r .[].name\r\n\r\nbut i cannot figure how to get the enabled value.\r\n",
        "link": "https://stackoverflow.com/questions/38505083/extracting-multiple-fields-from-a-json-payload",
        "title": "Extracting multiple fields from a JSON payload"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1469126852,
                "creation_date": 1469126852,
                "answer_id": 38512143,
                "question_id": 38508827,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "To include them, you need to verify that the id is any of the values in the keep set.\r\n\r\n    $ jq --argjson include &#39;[&quot;1&quot;, &quot;2&quot;, &quot;56&quot;, &quot;1337&quot;]&#39; &#39;map(select(.id == $include[]))&#39; ...\r\n\r\nTo exclude them, you need to verify that all values are not in your excluded set.  But it might just be easier to take the original set and remove the items that are in the excluded set.\r\n\r\n    $ jq --argjson exclude &#39;[&quot;1&quot;, &quot;2&quot;, &quot;56&quot;, &quot;1337&quot;]&#39; &#39;. - map(select(.id == $exclude[]))&#39; ...",
                "title": "Select or exclude multiples object with an array of IDs"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1503886629,
                "creation_date": 1503886629,
                "answer_id": 45911030,
                "question_id": 38508827,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a solution that uses **inside**. Assuming you run jq as\r\n\r\n    jq -M --argjson IDS &#39;[&quot;1&quot;,&quot;2&quot;,&quot;56&quot;,&quot;1337&quot;]&#39; -f filter.jq data.json\r\n    \r\nThis `filter.jq`\r\n\r\n    map( select([.id] | inside($IDS)) )\r\n\r\nproduces the ids from `data.json` that are in the `$IDS` array:\r\n\r\n    [\r\n      {\r\n        &quot;id&quot;: &quot;1&quot;,\r\n        &quot;foo&quot;: &quot;bar-a&quot;,\r\n        &quot;hello&quot;: &quot;world-a&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: &quot;2&quot;,\r\n        &quot;foo&quot;: &quot;bar-b&quot;,\r\n        &quot;hello&quot;: &quot;world-b&quot;\r\n      }\r\n    ]\r\n\r\nand this `filter.jq`\r\n\r\n    map( select([.id] | inside($IDS) | not) )\r\n    \r\nproduces the ids from `data.json` that are not in the `$IDS` array:\r\n\r\n    [\r\n      {\r\n        &quot;id&quot;: &quot;10&quot;,\r\n        &quot;foo&quot;: &quot;bar-c&quot;,\r\n        &quot;hello&quot;: &quot;world-c&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: &quot;42&quot;,\r\n        &quot;foo&quot;: &quot;bar-d&quot;,\r\n        &quot;hello&quot;: &quot;world-d&quot;\r\n      }\r\n    ]",
                "title": "Select or exclude multiples object with an array of IDs"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1503886629,
        "creation_date": 1469116289,
        "last_edit_date": 1495540372,
        "question_id": 38508827,
        "body_markdown": "I have the following JSON :\r\n\r\n    [\r\n      {\r\n        &quot;id&quot;: &quot;1&quot;,\r\n        &quot;foo&quot;: &quot;bar-a&quot;,\r\n        &quot;hello&quot;: &quot;world-a&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: &quot;2&quot;,\r\n        &quot;foo&quot;: &quot;bar-b&quot;,\r\n        &quot;hello&quot;: &quot;world-b&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: &quot;10&quot;,\r\n        &quot;foo&quot;: &quot;bar-c&quot;,\r\n        &quot;hello&quot;: &quot;world-c&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: &quot;42&quot;,\r\n        &quot;foo&quot;: &quot;bar-d&quot;,\r\n        &quot;hello&quot;: &quot;world-d&quot;\r\n      }\r\n    ]\r\n\r\nAnd I have the following array store in a variable: `[&quot;1&quot;, &quot;2&quot;, &quot;56&quot;, &quot;1337&quot;]` (note the IDs are string, and may contain any regular character).\r\n\r\nSo, thanks [to this SO][1], I found a way to filter my original data. `jq &#39;jq &#39;[.[] | select(.id == (&quot;1&quot;, &quot;2&quot;, &quot;56&quot;, &quot;1337&quot;))]&#39; ./data.json` (note the array is surrounded by parentheses and not brackets) produces :\r\n\r\n    [\r\n      {\r\n        &quot;id&quot;: &quot;1&quot;,\r\n        &quot;foo&quot;: &quot;bar-a&quot;,\r\n        &quot;hello&quot;: &quot;world-a&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: &quot;2&quot;,\r\n        &quot;foo&quot;: &quot;bar-b&quot;,\r\n        &quot;hello&quot;: &quot;world-b&quot;\r\n      }\r\n    ]\r\n\r\nBut I would also liked to do the opposite (basically excluding IDs instead of selecting them). Using `select(.id != (&quot;1&quot;, &quot;2&quot;, &quot;56&quot;, &quot;1337&quot;))` doesn&#39;t work and using `jq &#39;[. - [.[] | select(.id == (&quot;1&quot;, &quot;2&quot;, &quot;56&quot;, &quot;1337&quot;))]]&#39; ./data.json` seems very ugly and it doesn&#39;t work with my actual data (an output of `aws ec2 describe-instances`).\r\n\r\nSo have you any idea to do that? Thank you!\r\n\r\n  [1]: https://stackoverflow.com/questions/38121740/how-to-filter-array-of-objects-by-element-property-values-using-jq",
        "link": "https://stackoverflow.com/questions/38508827/select-or-exclude-multiples-object-with-an-array-of-ids",
        "title": "Select or exclude multiples object with an array of IDs"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1469431315,
                "creation_date": 1469431315,
                "answer_id": 38561826,
                "question_id": 38561384,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Try this &quot;`jq -s add ABC.json add.json`&quot; as below;\r\n\r\n\r\n    user@host:/tmp$ cat add.json\r\n    [\r\n    {\r\n        &quot;Value&quot;: {\r\n        &quot;Ref&quot;: &quot;TEAM&quot;\r\n         },\r\n         &quot;PropagateAtLaunch&quot;: true,\r\n             &quot;Key&quot;: &quot;TEAM&quot;\r\n         }\r\n    ]\r\n    user@host:/tmp$ jq -s add ABC.json add.json  &gt; ABCLAST.json\r\n    user@host:/tmp$ cat ABCLAST.json \r\n    [\r\n      {\r\n        &quot;PropagateAtLaunch&quot;: true,\r\n        &quot;Value&quot;: {\r\n          &quot;Ref&quot;: &quot;TNAM&quot;\r\n        },\r\n        &quot;Key&quot;: &quot;Name&quot;\r\n      },\r\n      {\r\n        &quot;PropagateAtLaunch&quot;: true,\r\n        &quot;Value&quot;: {\r\n          &quot;Ref&quot;: &quot;TAPP&quot;\r\n        },\r\n        &quot;Key&quot;: &quot;application&quot;\r\n      },\r\n      {\r\n        &quot;PropagateAtLaunch&quot;: true,\r\n        &quot;Value&quot;: {\r\n          &quot;Ref&quot;: &quot;TENV&quot;\r\n        },\r\n        &quot;Key&quot;: &quot;environment&quot;\r\n      },\r\n      {\r\n        &quot;PropagateAtLaunch&quot;: true,\r\n        &quot;Value&quot;: {\r\n          &quot;Ref&quot;: &quot;TSHA&quot;\r\n        },\r\n        &quot;Key&quot;: &quot;shared&quot;\r\n      },\r\n      {\r\n        &quot;PropagateAtLaunch&quot;: true,\r\n        &quot;Value&quot;: {\r\n          &quot;Ref&quot;: &quot;TTER&quot;\r\n        },\r\n        &quot;Key&quot;: &quot;tier&quot;\r\n      },\r\n      {\r\n        &quot;PropagateAtLaunch&quot;: true,\r\n        &quot;Value&quot;: {\r\n          &quot;Ref&quot;: &quot;CostCenter&quot;\r\n        },\r\n        &quot;Key&quot;: &quot;cost-center&quot;\r\n      },\r\n      {\r\n        &quot;PropagateAtLaunch&quot;: true,\r\n        &quot;Value&quot;: {\r\n          &quot;Ref&quot;: &quot;TEAM&quot;\r\n        },\r\n        &quot;Key&quot;: &quot;TEAM&quot;\r\n      }\r\n    ]\r\n",
                "title": "How to add section of json to the existing file using jq"
            },
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1469436755,
                "creation_date": 1469436755,
                "answer_id": 38563356,
                "question_id": 38561384,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You can pass the object as a jq variable using `--argjson`, then use `+=` to add the object to the array:\r\n\r\n    jq --argjson obj &#39;{&quot;sample&quot;: &quot;object&quot;}&#39; &#39;.Resources.ASGRP.Properties.Tags += [$obj]&#39;\r\n\r\nIf you don&#39;t want the original object, use `+` instead of `+=`.",
                "title": "How to add section of json to the existing file using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1469473890,
        "creation_date": 1469429633,
        "last_edit_date": 1469473890,
        "question_id": 38561384,
        "body_markdown": "I am using `jq` to parse a JSON file. I have some section of JSON file with below content\r\n\r\n    [\r\n      {\r\n        &quot;PropagateAtLaunch&quot;: true,\r\n        &quot;Value&quot;: {\r\n          &quot;Ref&quot;: &quot;TNAM&quot;\r\n        },\r\n        &quot;Key&quot;: &quot;Name&quot;\r\n      },\r\n      {\r\n        &quot;PropagateAtLaunch&quot;: true,\r\n        &quot;Value&quot;: {\r\n          &quot;Ref&quot;: &quot;TAPP&quot;\r\n        },\r\n        &quot;Key&quot;: &quot;application&quot;\r\n      },\r\n      {\r\n        &quot;PropagateAtLaunch&quot;: true,\r\n        &quot;Value&quot;: {\r\n          &quot;Ref&quot;: &quot;TENV&quot;\r\n        },\r\n        &quot;Key&quot;: &quot;environment&quot;\r\n      },\r\n      {\r\n        &quot;PropagateAtLaunch&quot;: true,\r\n        &quot;Value&quot;: {\r\n          &quot;Ref&quot;: &quot;TSHA&quot;\r\n        },\r\n        &quot;Key&quot;: &quot;shared&quot;\r\n      },\r\n      {\r\n        &quot;PropagateAtLaunch&quot;: true,\r\n        &quot;Value&quot;: {\r\n          &quot;Ref&quot;: &quot;TTER&quot;\r\n        },\r\n        &quot;Key&quot;: &quot;tier&quot;\r\n      },\r\n      {\r\n        &quot;PropagateAtLaunch&quot;: true,\r\n        &quot;Value&quot;: {\r\n          &quot;Ref&quot;: &quot;CostCenter&quot;\r\n        },\r\n        &quot;Key&quot;: &quot;cost-center&quot;\r\n      }\r\n    ]\r\n\r\nIn this I want to add another section like:\r\n\r\n    {\r\n      &quot;Value&quot;: {\r\n        &quot;Ref&quot;: &quot;TEAM&quot;\r\n      },\r\n      &quot;PropagateAtLaunch&quot;: true,\r\n      &quot;Key&quot;: &quot;TEAM&quot;\r\n    }\r\n\r\nHow can I add this new section?\r\n\r\nThis is the query I have used to extract the first section: \r\n\r\n    $ cat ABC.json | jq &#39;.Resources.ASGRP.Properties.Tags&#39;\r\n\r\n",
        "link": "https://stackoverflow.com/questions/38561384/how-to-add-section-of-json-to-the-existing-file-using-jq",
        "title": "How to add section of json to the existing file using jq"
    },
    {
        "tags": [
            "json",
            "bash",
            "shell",
            "sh",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1469625223,
                "last_edit_date": 1469625223,
                "creation_date": 1469590892,
                "answer_id": 38603329,
                "question_id": 38603161,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Got it. With jq seems super simple :\r\n\r\n    jq -s &#39;.[0] + .[1].default_attributes + .[1].override_attributes&#39; a-roles.json a-env.json &gt; manifest.json\r\n\r\nmanifest.json -&gt;\r\n\r\n    {\r\n      &quot;default&quot;: {\r\n        &quot;env&quot;: &quot;developmen-jq&quot;\r\n      },\r\n      &quot;7-zip&quot;: {\r\n        &quot;home&quot;: &quot;%SYSTEMDRIVE%\\\\7-zip&quot;\r\n      },\r\n      &quot;name&quot;: &quot;paypal_modmon&quot;,\r\n      &quot;description&quot;: &quot;Role For Paypal admin-service box&quot;,\r\n      &quot;run_list&quot;: [\r\n        &quot;recipe[djcm_paypal_win::sslVerify]&quot;\r\n      ],\r\n      &quot;seven_zip&quot;: {\r\n        &quot;url&quot;: &quot;https://djcm:Pib1StheK1N5@artifactory.dowjones.io/artifactory/djcm-zip-local/djcm/chef/paypal/7z1514-x64.msi&quot;\r\n      },\r\n      &quot;task_sched&quot;: {\r\n        &quot;credentials&quot;: &quot;kX?rLQ4XN$q&quot;\r\n      },\r\n      &quot;windows&quot;: {\r\n        &quot;password&quot;: &quot;Pib1StheK1N5&quot;\r\n      },\r\n      &quot;paypal&quot;: {\r\n        &quot;artifact&quot;: &quot;%5BINTEGRATION%5D&quot;\r\n      },\r\n      &quot;modmon&quot;: {\r\n        &quot;env&quot;: &quot;dev&quot;\r\n      }\r\n    }\r\n\r\n\r\nEDIT 1 :\r\n\r\nI also need to parse out the run_list key value pair from a-roles.json and ignore all other info to have something:\r\n\r\n    {\r\n      &quot;default&quot;: {\r\n        &quot;env&quot;: &quot;developmen-jq&quot;\r\n      },\r\n      &quot;7-zip&quot;: {\r\n        &quot;home&quot;: &quot;%SYSTEMDRIVE%\\\\7-zip&quot;\r\n      },\r\n      &quot;run_list&quot;: [\r\n        &quot;recipe[djcm_paypal_win::sslVerify]&quot;\r\n      ],\r\n      &quot;seven_zip&quot;: {\r\n        &quot;url&quot;: &quot;https://djcm:Pib1StheK1N5@artifactory.dowjones.io/artifactory/djcm-zip-local/djcm/chef/paypal/7z1514-x64.msi&quot;\r\n      },\r\n      &quot;task_sched&quot;: {\r\n        &quot;credentials&quot;: &quot;kX?rLQ4XN$q&quot;\r\n      },\r\n      &quot;windows&quot;: {\r\n        &quot;password&quot;: &quot;Pib1StheK1N5&quot;\r\n      },\r\n      &quot;paypal&quot;: {\r\n        &quot;artifact&quot;: &quot;%5BINTEGRATION%5D&quot;\r\n      },\r\n      &quot;modmon&quot;: {\r\n        &quot;env&quot;: &quot;dev&quot;\r\n      }\r\n    }\r\n\r\nis that possible with jq ?",
                "title": "merging 2 json into one single json with value parsing in bash."
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1469602999,
                "creation_date": 1469602999,
                "answer_id": 38605936,
                "question_id": 38603161,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Generally, if you&#39;re reading in multiple files, you should use the `--argfile` option so you can reference the contents of the file by name. And judging by the name of the attributes you wish to merge, you should be wary of the different merging options you have. `default_attributes` suggests it should be attributes that should be used if omitted. `override_attributes` suggests it should force it&#39;s values in.\r\n\r\n    $ jq --argfile merge input2.json \\\r\n    &#39;($merge.default_attributes * .) + $merge.override_attributes&#39; input1.json\r\n\r\nBy merging the input with the `default_attributes` using `*`, it allows you to start with the defaults and add your actual values in place.  That way missing values end up being provided by the default object.\r\n\r\nThen adding the `override_attributes` object, the values are completely replaced and not just merged.",
                "title": "merging 2 json into one single json with value parsing in bash."
            }
        ],
        "is_answered": false,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1469625223,
        "creation_date": 1469589725,
        "question_id": 38603161,
        "body_markdown": "I have two JSONS:\r\n\r\n    {\r\n      &quot;name&quot;: &quot;paypal_modmon&quot;,\r\n      &quot;description&quot;: &quot;Role For Paypal admin-service box&quot;,\r\n      &quot;run_list&quot;: [\r\n          &quot;recipe[djcm_paypal_win::sslVerify]&quot;\r\n        ]\r\n      }\r\n\r\nand \r\n\r\n    {\r\n      &quot;name&quot;: &quot;paypal_dev&quot;,\r\n      &quot;default_attributes&quot;: {\r\n        &quot;7-zip&quot;: {\r\n            &quot;home&quot;: &quot;%SYSTEMDRIVE%\\\\7-zip&quot;\r\n        },\r\n        &quot;modmon&quot;: {\r\n            &quot;env&quot;: &quot;dev&quot;\r\n        },\r\n        &quot;paypal&quot;: {\r\n            &quot;artifact&quot;: &quot;%5BINTEGRATION%5D&quot;\r\n        }\r\n      },\r\n      &quot;override_attributes&quot;: {\r\n        &quot;default&quot;: {\r\n            &quot;env&quot;: &quot;developmen&quot;\r\n        },\r\n        &quot;windows&quot;: {\r\n          &quot;password&quot;: &quot;Pib1StheK1N5&quot;\r\n        },\r\n        &quot;task_sched&quot;:{\r\n          &quot;credentials&quot;: &quot;kX?rLQ4XN$q&quot;\r\n        },\r\n        &quot;seven_zip&quot;: {\r\n            &quot;url&quot;: &quot;https://djcm:Pib1StheK1N5@artifactory.dowjones.io/artifactory/djcm-zip-local/djcm/chef/paypal/7z1514-x64.msi&quot;\r\n        }\r\n      },\r\n      &quot;chef_type&quot;: &quot;environment&quot;\r\n    }\r\n\r\n I want to read the values from the second json : &quot;default_attributes&quot; and &quot;override_attributes&quot; and merge them with the first json into an output like :\r\n\r\n    {\r\n      &quot;description&quot;: &quot;Role For Paypal admin-service box&quot;,\r\n      &quot;run_list&quot;: [\r\n        &quot;recipe[djcm_paypal_win::sslVerify]&quot;\r\n      ],\r\n      &quot;chef_type&quot;: &quot;environment&quot;,\r\n        &quot;seven_zip&quot;: {\r\n          &quot;url&quot;: &quot;https://djcm:Pib1StheK1N5@artifactory.dowjones.io/artifactory/djcm-zip-local/djcm/chef/paypal/7z1514-x64.msi&quot;\r\n        },\r\n        &quot;task_sched&quot;: {\r\n          &quot;credentials&quot;: &quot;kX?rLQ4XN$q&quot;\r\n        },\r\n        &quot;windows&quot;: {\r\n          &quot;password&quot;: &quot;Pib1StheK1N5&quot;\r\n        },\r\n        &quot;paypal&quot;: {\r\n          &quot;artifact&quot;: &quot;%5BINTEGRATION%5D&quot;\r\n        },\r\n        &quot;modmon&quot;: {\r\n          &quot;env&quot;: &quot;dev&quot;\r\n        },\r\n        &quot;7-zip&quot;: {\r\n          &quot;home&quot;: &quot;%SYSTEMDRIVE%\\\\7-zip&quot;\r\n        },\r\n        &quot;default&quot;: {\r\n          &quot;env&quot;: &quot;developmen&quot;\r\n        },\r\n      &quot;name&quot;: &quot;paypal_modmon&quot;\r\n    }\r\n\r\nIs there a way to do this in bash and how would go to achieve it ?",
        "link": "https://stackoverflow.com/questions/38603161/merging-2-json-into-one-single-json-with-value-parsing-in-bash",
        "title": "merging 2 json into one single json with value parsing in bash."
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 166270,
                    "reputation": 135171,
                    "user_id": 390278,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/84715fec547362389d02f5be0ed12814?s=256&d=identicon&r=PG",
                    "display_name": "Jeff Mercado",
                    "link": "https://stackoverflow.com/users/390278/jeff-mercado"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1469601970,
                "post_id": 38603792,
                "comment_id": 64598078,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 8243680,
                    "reputation": 51,
                    "user_id": 6200535,
                    "user_type": "registered",
                    "accept_rate": 20,
                    "profile_image": "https://www.gravatar.com/avatar/b0ee93132d171e81933dd367c71bd46b?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Pradeep BS",
                    "link": "https://stackoverflow.com/users/6200535/pradeep-bs"
                },
                "reply_to_user": {
                    "account_id": 166270,
                    "reputation": 135171,
                    "user_id": 390278,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/84715fec547362389d02f5be0ed12814?s=256&d=identicon&r=PG",
                    "display_name": "Jeff Mercado",
                    "link": "https://stackoverflow.com/users/390278/jeff-mercado"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1469613215,
                "post_id": 38603792,
                "comment_id": 64605562,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1470288751,
                "creation_date": 1470288751,
                "answer_id": 38759142,
                "question_id": 38603792,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "This is by no means the most efficient way, but it is functional. It returns a boolean value specifying whether or not there is a `true` boolean value under the `financial_debt` property.\r\n\r\n\r\n    jq &#39;[recurse | .financial_debt? | select(. != null) | recurse | booleans] | any&#39;\r\n",
                "title": "Json search and print"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1503554753,
                "creation_date": 1503554753,
                "answer_id": 45854082,
                "question_id": 38603792,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "**tostream** can be used to find paths containing `&quot;financial_debt&quot;` as follows:\r\n\r\n      tostream\r\n    | select(length==2)\r\n    | select(.[0] | contains([&quot;financial_debt&quot;]))\r\n    \r\nwith this filter in `filter.jq` and data in `data.json`\r\n    \r\n    $ jq -M -c -f filter.jq data.json\r\n\r\nproduces\r\n\r\n    [[&quot;main_attribute&quot;,&quot;financial_debt&quot;,&quot;bank_loan&quot;],true]\r\n    [[&quot;secondary_attr&quot;,&quot;education&quot;,&quot;financial_debt&quot;,&quot;bank_loan&quot;],false]\r\n\r\nThis intermediate result can be used along with **reduce**, **setpath**, **getpath** and a filter such as\r\n\r\n      . as $d\r\n    | reduce ( tostream\r\n             | select(length==2)\r\n             | select(.[0] | contains([&quot;financial_debt&quot;]))) as [$p,$v] (\r\n        {}\r\n      ; setpath($p[:-1]; $d | getpath($p[:-1]))\r\n      )\r\n\r\nto produce\r\n\r\n    {\r\n      &quot;main_attribute&quot;: {\r\n        &quot;financial_debt&quot;: {\r\n          &quot;bank_loan&quot;: true\r\n        }\r\n      },\r\n      &quot;secondary_attr&quot;: {\r\n        &quot;education&quot;: {\r\n          &quot;financial_debt&quot;: {\r\n            &quot;bank_loan&quot;: false\r\n          }\r\n        }\r\n      }\r\n    }",
                "title": "Json search and print"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": -1,
        "last_activity_date": 1503565434,
        "creation_date": 1469594039,
        "last_edit_date": 1503565434,
        "question_id": 38603792,
        "body_markdown": "I&#39;ve been trying to use jq parser to help me extract information from json files. \r\n\r\nHere is an example snippet\r\n\r\n    {\r\n      &quot;main_attribute&quot;: {\r\n        &quot;name&quot;: {\r\n          &quot;display_name&quot;: &quot;abc&quot;\r\n        },\r\n        &quot;address&quot;: {\r\n          &quot;unit&quot;: &quot;1&quot;,\r\n          &quot;street&quot;: &quot;Dundas&quot;,\r\n          &quot;suburb&quot;: &quot;Syd&quot;,\r\n          &quot;state&quot;: &quot;NSW&quot;\r\n        },\r\n        &quot;financial_debt&quot;: {\r\n          &quot;bank_loan&quot;: true\r\n        }\r\n      },\r\n      &quot;secondary_attr&quot;: {\r\n        &quot;income&quot;: {\r\n          &quot;pretax&quot;: 100000\r\n        },\r\n        &quot;automobile&quot;: {\r\n          &quot;make&quot;: &quot;Citroen&quot;,\r\n          &quot;model&quot;: 2015,\r\n          &quot;new&quot;: true\r\n        },\r\n        &quot;property&quot;: {\r\n          &quot;property_owned&quot;: 1,\r\n          &quot;owned_since&quot;: 2000,\r\n          &quot;first_sale&quot;: true\r\n        },\r\n        &quot;education&quot;: {\r\n          &quot;degree&quot;: &quot;MS&quot;,\r\n          &quot;graduated&quot;: 1990,\r\n          &quot;financial_debt&quot;: {\r\n            &quot;bank_loan&quot;: false\r\n          }\r\n        }      \r\n      }\r\n    }\r\n\r\nI need to find the blocks where &quot;financial_debt&quot; is true. This field could be either in the main_attribute (as a global value) or in the secondary attribute.\r\n\r\nExpected output:\r\n\r\nfinancial_debt: bank_loan on &quot;automobile&quot; and &quot;property&quot;\r\n\r\nCan you please advise how to go about doing this search using jq? ",
        "link": "https://stackoverflow.com/questions/38603792/json-search-and-print",
        "title": "Json search and print"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1469680603,
                "last_edit_date": 1495535325,
                "creation_date": 1469680603,
                "answer_id": 38627180,
                "question_id": 38626762,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "May be in next release of jq you can use builtin function `walk/1`.\r\nBut current jq-1.5 don&#39;t have `walk/1` so you have to copy it from `buitin.jq`\r\nhttps://github.com/stedolan/jq/blob/master/src/builtin.jq\r\n\r\nsave following code as `hoo.jq`\r\n\r\n    def walk(f):\r\n      . as $in\r\n      | if type == &quot;object&quot; then\r\n          reduce keys[] as $key\r\n            ( {}; . + { ($key):  ($in[$key] | walk(f)) } ) | f\r\n        elif type == &quot;array&quot; then map( walk(f) ) | f\r\n        else f\r\n        end;\r\n\r\n    walk(if type == &quot;object&quot; then del(.source) else . end)\r\n\r\nrun\r\n\r\n    $ jq -f hoo.jq &lt; YOUR_JSON.json\r\n\r\nreference: https://stackoverflow.com/questions/33558674/recursive-reduce-arrays-using-jq/33559836#33559836",
                "title": "JQ delete multiple properties"
            },
            {
                "up_vote_count": 26,
                "is_accepted": true,
                "score": 26,
                "last_activity_date": 1469791393,
                "creation_date": 1469791393,
                "answer_id": 38657597,
                "question_id": 38626762,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Iterate through all the elements in `.b`, then set their value to the result of removing the `.source` element from them:\r\n\r\n    .b[] |= del(.source)",
                "title": "JQ delete multiple properties"
            },
            {
                "up_vote_count": 21,
                "is_accepted": false,
                "score": 21,
                "last_activity_date": 1503888819,
                "creation_date": 1503888819,
                "answer_id": 45911210,
                "question_id": 38626762,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is another solution\r\n\r\n    del( .b[].source )",
                "title": "JQ delete multiple properties"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 23,
        "last_activity_date": 1511054616,
        "creation_date": 1469677633,
        "last_edit_date": 1511054616,
        "question_id": 38626762,
        "body_markdown": "I have an object like this:\r\n\r\n    {\r\n        &quot;a&quot; : 1,\r\n        &quot;b&quot; : {\r\n            &quot;c&quot; : {\r\n                &quot;c1&quot; : &quot;abc&quot;,\r\n                &quot;source&quot; : &quot;abcxyz&quot;\r\n            },\r\n            &quot;d&quot; : {\r\n                &quot;d1&quot; : &quot;abcd&quot;,\r\n                &quot;source&quot; : &quot;abcxyz&quot;\r\n            },\r\n            &quot;e&quot; : {\r\n                &quot;e1&quot; : &quot;abcde&quot;,\r\n                &quot;source&quot; : &quot;abcxyz&quot;\r\n            }\r\n        }\r\n    }\r\n\r\nMy expectation is\r\n\r\n    {\r\n        &quot;a&quot; : 1,\r\n        &quot;b&quot; : {\r\n            &quot;c&quot; : {\r\n                &quot;c1&quot; : &quot;abc&quot;\r\n            },\r\n            &quot;d&quot; : {\r\n                &quot;d1&quot; : &quot;abcd&quot;\r\n            },\r\n            &quot;e&quot; : {\r\n                &quot;e1&quot; : &quot;abcde&quot;\r\n            }\r\n        }\r\n    }\r\n\r\nI want to remove &quot;source&quot; properties. How can I do that without specifying keys &quot;c&quot;, &quot;d&quot; or &quot;e&quot;, because they are dynamic.",
        "link": "https://stackoverflow.com/questions/38626762/jq-delete-multiple-properties",
        "title": "JQ delete multiple properties"
    },
    {
        "tags": [
            "json",
            "bash",
            "structure",
            "jq",
            "datamodel"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 8712435,
                    "reputation": 4112,
                    "user_id": 6518219,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/42f5b6bcc29bd1f28ebd0dae503f01d8?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Mustafa DOGRU",
                    "link": "https://stackoverflow.com/users/6518219/mustafa-dogru"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1469695775,
                "post_id": 38630244,
                "comment_id": 64646589,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1469732512,
                "creation_date": 1469732512,
                "answer_id": 38644710,
                "question_id": 38630244,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "If you stream the input in, it will give you pairs of the paths and values contained in the input.\r\n\r\n    $ jq --stream &#39;select(length&gt;1)[0]&#39; input.json\r\n\r\nSo for an input like this:\r\n\r\n    {\r\n      &quot;foo&quot;: { &quot;bar&quot;: 1 },\r\n      &quot;biz&quot;: { &quot;baz&quot;: 2 }\r\n    }\r\n\r\nYou&#39;d get:\r\n\r\n    [\r\n      &quot;foo&quot;,\r\n      &quot;bar&quot;\r\n    ]\r\n    [\r\n      &quot;biz&quot;,\r\n      &quot;baz&quot;\r\n    ]\r\n\r\n\r\n",
                "title": "show structure of all levels of json with jq and bash"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1469732512,
        "creation_date": 1469692375,
        "question_id": 38630244,
        "body_markdown": "How can I list all unique keys of a json file for all levels and array attributes, together with their path?\r\n\r\nI found jq -s &#39;map(keys) | add | unique | sort&#39; input.json, but this only lists the first level, and no paths.\r\n\r\n",
        "link": "https://stackoverflow.com/questions/38630244/show-structure-of-all-levels-of-json-with-jq-and-bash",
        "title": "show structure of all levels of json with jq and bash"
    },
    {
        "tags": [
            "arrays",
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2251762,
                    "reputation": 292345,
                    "user_id": 1983854,
                    "user_type": "registered",
                    "accept_rate": 96,
                    "profile_image": "https://i.sstatic.net/KiqLo.png?s=256",
                    "display_name": "fedorqui",
                    "link": "https://stackoverflow.com/users/1983854/fedorqui"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1469701521,
                "post_id": 38633599,
                "comment_id": 64650654,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 5151128,
                    "reputation": 2168,
                    "user_id": 4125723,
                    "user_type": "registered",
                    "accept_rate": 95,
                    "profile_image": "https://i.sstatic.net/GLiXp.gif?s=256",
                    "display_name": "x3nr0s",
                    "link": "https://stackoverflow.com/users/4125723/x3nr0s"
                },
                "reply_to_user": {
                    "account_id": 2251762,
                    "reputation": 292345,
                    "user_id": 1983854,
                    "user_type": "registered",
                    "accept_rate": 96,
                    "profile_image": "https://i.sstatic.net/KiqLo.png?s=256",
                    "display_name": "fedorqui",
                    "link": "https://stackoverflow.com/users/1983854/fedorqui"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1469701838,
                "post_id": 38633599,
                "comment_id": 64650884,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1469701747,
                "creation_date": 1469701747,
                "answer_id": 38633757,
                "question_id": 38633599,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Just use `mapfile` command to read multiple lines into an array like this:\r\n\r\n    mapfile -t myArray &lt; &lt;(jq -r .user[].name &lt;&lt;&lt; &quot;$getNames&quot;)",
                "title": "Bash - Only go next index when new line occurs, instead of white space?"
            },
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1469701992,
                "creation_date": 1469701992,
                "answer_id": 38633848,
                "question_id": 38633599,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "A simple script in `bash` to feed each line of the output into the array `myArray`.\r\n\r\n    #!/bin/bash\r\n    \r\n    myArray=()\r\n    while IFS= read -r line; do\r\n        [[ $line ]] || break  # break if line is empty\r\n        myArray+=(&quot;$line&quot;)\r\n    done &lt; &lt;(jq -r .user[].name &lt;&lt;&lt; &quot;$getNames&quot;)\r\n    \r\n    # To print the array\r\n    printf &#39;%s\\n&#39; &quot;${myArray[@]}&quot;",
                "title": "Bash - Only go next index when new line occurs, instead of white space?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 3,
        "last_activity_date": 1596282747,
        "creation_date": 1469701277,
        "last_edit_date": 1596282747,
        "question_id": 38633599,
        "body_markdown": "I&#39;m parsing a JSON response with a tool called jq.\r\nThe output from jq will give me a list of full names in my command line.\r\n\r\nI have the variable *getNames* which contains JSON, for example:\r\n\r\n    {\r\n    \t&quot;count&quot;: 49,\r\n    \t&quot;user&quot;: [{\r\n    \t\t&quot;username&quot;: &quot;jamesbrown&quot;,\r\n    \t\t&quot;name&quot;: &quot;James Brown&quot;,\r\n    \t\t&quot;id&quot;: 1\r\n    \t}, {\r\n    \t\t&quot;username&quot;: &quot;matthewthompson&quot;,\r\n    \t\t&quot;name&quot;: &quot;Matthew Thompson&quot;,\r\n    \t\t&quot;id&quot;: 2\r\n    \t}]\r\n    }\r\n\r\n\r\n\r\nI pass this through JQ to filter the json using the following command:\r\n\r\n    echo $getNames | jq -r .user[].name\r\n\r\nWhich gives me a list like this:\r\n\r\n    James Brown   \r\n    Matthew Thompson   \r\n   \r\nI want to put each one of these entries into a bash array, so I enter the following commands:\r\n\r\n    declare -a myArray    \r\n    myArray=( `echo $getNames | jq -r .user[].name` )\r\n\r\nHowever, when I try to print the array using:\r\n\r\n \r\n\r\n    printf &#39;%s\\n&#39; &quot;${myArray[@]}&quot;\r\n\r\nI get the following:\r\n\r\n    James\r\n    Brown\r\n    Matthew\r\n    Thompson\r\n\r\nHow do I ensure that a new index is created after a new line and not a space? Why are the names being separated?\r\n\r\nThanks.",
        "link": "https://stackoverflow.com/questions/38633599/bash-only-go-next-index-when-new-line-occurs-instead-of-white-space",
        "title": "Bash - Only go next index when new line occurs, instead of white space?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1469718112,
                "last_edit_date": 1592644375,
                "creation_date": 1469718112,
                "answer_id": 38640098,
                "question_id": 38640063,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "From [the documentation](https://stedolan.github.io/jq/manual/#Basicfilters):\n\n&gt; `.`\n&gt;\n&gt; The absolute simplest (and least interesting) filter is `.`. This is a filter that takes its input and produces it unchanged as output.\n&gt;\n&gt; Since `jq` by default pretty-prints all output, this trivial program can be a useful way of formatting JSON output from, say, `curl`.",
                "title": "What does jq &#39;.&#39; do?"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1469788001,
                "creation_date": 1469788001,
                "answer_id": 38656501,
                "question_id": 38640063,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "In the jq programming language, `.` refers to the implicit input of a filter. For example, `def f: .;` defines a function `f` that outputs its implicit input as-is.\r\n\r\nNote that, inside filter arguments, the filter can change what `.` refers to: for example, `map(f)` is defined as `[.[] | f]`; on the jq program `[1, 2, 3] | map(. + 1)`, `.` refers to each of the elements of the array.",
                "title": "What does jq &#39;.&#39; do?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1471118761,
                "creation_date": 1471118761,
                "answer_id": 38936541,
                "question_id": 38640063,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "In addition to `jq .` pretty-printing the output, it also produces a warning if the input file cannot be parsed. As such it is handy for testing unknown JSON files to see if the source file has syntax issues.",
                "title": "What does jq &#39;.&#39; do?"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": -1,
        "last_activity_date": 1491044801,
        "creation_date": 1469718006,
        "last_edit_date": 1491044801,
        "question_id": 38640063,
        "body_markdown": "How the jq &#39;.&#39; parsing the json and displaying ? \r\n\r\n    curl &#39;https://api.github.com/repos/stedolan/jq/commits?per_page=5&#39; | jq &#39;.&#39;\r\n\r\nI see the json is parsed and diplayed correctly\r\n\r\n&gt; What is the implementation behind &quot; xxxx | jq &#39;.&#39; &quot;\r\n\r\nHow can i understand that ?",
        "link": "https://stackoverflow.com/questions/38640063/what-does-jq-do",
        "title": "What does jq &#39;.&#39; do?"
    },
    {
        "tags": [
            "python",
            "json",
            "elasticsearch",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 5843921,
                    "reputation": 218172,
                    "user_id": 4604579,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/reC2t.jpg?s=256",
                    "display_name": "Val",
                    "link": "https://stackoverflow.com/users/4604579/val"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1469794483,
                "post_id": 38658471,
                "comment_id": 64697965,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 340794,
                    "reputation": 13131,
                    "user_id": 671013,
                    "user_type": "registered",
                    "accept_rate": 50,
                    "profile_image": "https://www.gravatar.com/avatar/2d735ca95ae6d53fa8fd9fa79814e514?s=256&d=identicon&r=PG",
                    "display_name": "Dror",
                    "link": "https://stackoverflow.com/users/671013/dror"
                },
                "reply_to_user": {
                    "account_id": 5843921,
                    "reputation": 218172,
                    "user_id": 4604579,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/reC2t.jpg?s=256",
                    "display_name": "Val",
                    "link": "https://stackoverflow.com/users/4604579/val"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1469794824,
                "post_id": 38658471,
                "comment_id": 64698198,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1469794525,
                "creation_date": 1469794525,
                "answer_id": 38658606,
                "question_id": 38658471,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Definitely the `bulk` approach. But you need to put a bit more work into this, as it&#39;s not as easy as creating one file, sending it to ES and expect it to deal with it.\r\n\r\nIf the file is too big, of course it will struggle.\r\nDo please read this section of the documentation, especially the last part where it describes how you&#39;d need to decide how large a bulk batch needs to be: https://www.elastic.co/guide/en/elasticsearch/guide/current/bulk.html\r\n\r\nEach cluster has its own characteristics and each can deal with a certain number of batches/certain number of concurrent batches even. It depends on your specifics, so do please test this and determine the best number for your particular use case.",
                "title": "Indexing many JSON objects into Elasticsearch - the canonical way"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1469794525,
        "creation_date": 1469794110,
        "question_id": 38658471,
        "body_markdown": "Here&#39;s a scenario I keep facing, and I am in doubt whether the solution I take is the canonical/smart one. Assume you a file where each line is a valid JSON. Furthermore, each object contains a field `type` and `id` and the pairs of are unique. My goal is to index all the objects into an index on an ES cluster. So far I took two approaches:\r\n\r\nUsing the `bulk` API together with `jq` using something like: \r\n\r\n    $ cat foo.json | jq -c &#39;. | {&quot;index&quot;: {&quot;_index&quot;: &quot;your_test_index&quot;, &quot;_type&quot;: &quot;doc_type&quot;}}, .&#39; | curl -XPOST localhost:9200/_bulk --data-binary @-\r\n\r\nThis works very nicely, but it is super slow.\r\n\r\nI tried also to use the Python client, but still I have to read line by line and index them one by one. \r\n\r\nIs there some way to &quot;push&quot; the complete file and direct ES to process all lines the same way? Or in other words, what is the efficient way to index LARGE amount of JSON objects in a batch processing fashion?",
        "link": "https://stackoverflow.com/questions/38658471/indexing-many-json-objects-into-elasticsearch-the-canonical-way",
        "title": "Indexing many JSON objects into Elasticsearch - the canonical way"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1469893426,
                "creation_date": 1469893426,
                "answer_id": 38675698,
                "question_id": 38674118,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You know how to get the corresponding name that you&#39;re looking for, just add a `select` in there with the condition you need.  Fortunately, your condition involves the item you&#39;re searching for and not another unrelated object.\r\n\r\n    $ jq --arg secret &#39;klucze&#39; \\\r\n    &#39;.items[] | select(.spec.volumes[].secret.secretName == $secret).metadata.name&#39; input.json\r\n",
                "title": "extract correlated value in nested array"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1469893551,
        "creation_date": 1469882740,
        "last_edit_date": 1469893551,
        "question_id": 38674118,
        "body_markdown": "I want to get a value from this json\r\n\r\n    {\r\n      &quot;kind&quot;: &quot;List&quot;,\r\n      &quot;apiVersion&quot;: &quot;v1&quot;,\r\n      &quot;metadata&quot;: {},\r\n      &quot;items&quot;: [\r\n        {\r\n          &quot;kind&quot;: &quot;Pod&quot;,\r\n          &quot;apiVersion&quot;: &quot;v1&quot;,\r\n          &quot;metadata&quot;: {\r\n            &quot;name&quot;: &quot;provisioner-secrets-1750468340-ei8sl&quot;,\r\n            &quot;generateName&quot;: &quot;provisioner-secrets-1750468340-&quot;,\r\n            &quot;namespace&quot;: &quot;default&quot;,\r\n            &quot;selfLink&quot;: &quot;/api/v1/namespaces/default/pods/provisioner-secrets-1750468340-ei8sl&quot;,\r\n            &quot;uid&quot;: &quot;8d2ac8e4-5642-11e6-b139-72f9d49a4327&quot;,\r\n            &quot;resourceVersion&quot;: &quot;1473&quot;,\r\n            &quot;creationTimestamp&quot;: &quot;2016-07-30T10:44:11Z&quot;,\r\n            &quot;labels&quot;: {\r\n              &quot;pod-template-hash&quot;: &quot;1750468340&quot;,\r\n              &quot;run&quot;: &quot;git-sync&quot;\r\n            },\r\n            &quot;annotations&quot;: {\r\n              &quot;kubernetes.io/created-by&quot;: &quot;{\\&quot;kind\\&quot;:\\&quot;SerializedReference\\&quot;,\\&quot;apiVersion\\&quot;:\\&quot;v1\\&quot;,\\&quot;reference\\&quot;:{\\&quot;kind\\&quot;:\\&quot;ReplicaSet\\&quot;,\\&quot;namespace\\&quot;:\\&quot;default\\&quot;,\\&quot;name\\&quot;:\\&quot;provisioner-secrets-1750468340\\&quot;,\\&quot;uid\\&quot;:\\&quot;8d2904ba-5642-11e6-b139-72f9d49a4327\\&quot;,\\&quot;apiVersion\\&quot;:\\&quot;extensions\\&quot;,\\&quot;resourceVersion\\&quot;:\\&quot;1438\\&quot;}}\\n&quot;\r\n            }\r\n          },\r\n          &quot;spec&quot;: {\r\n            &quot;volumes&quot;: [\r\n              {\r\n                &quot;name&quot;: &quot;markdown&quot;,\r\n                &quot;emptyDir&quot;: {}\r\n              },\r\n              {\r\n                &quot;name&quot;: &quot;klucze&quot;,\r\n                &quot;secret&quot;: {\r\n                  &quot;secretName&quot;: &quot;klucze&quot;\r\n                }\r\n              },\r\n              {\r\n                &quot;name&quot;: &quot;default-token-xjc9q&quot;,\r\n                &quot;secret&quot;: {\r\n                  &quot;secretName&quot;: &quot;default-token-xjc9q&quot;\r\n                }\r\n              }\r\n            ],\r\n            &quot;containers&quot;: [\r\n              {\r\n                &quot;name&quot;: &quot;git-sync&quot;,\r\n                &quot;image&quot;: &quot;lukaszbielinski/git-sync:0.5&quot;,\r\n                &quot;env&quot;: [\r\n                  {\r\n                    &quot;name&quot;: &quot;GIT_SYNC_REPO&quot;,\r\n                    &quot;value&quot;: &quot;https://github.com/lukasz-bielinski/test-secrets&quot;\r\n                  },\r\n                  {\r\n                    &quot;name&quot;: &quot;GIT_SYNC_WAIT&quot;,\r\n                    &quot;value&quot;: &quot;10&quot;\r\n                  },\r\n                  {\r\n                    &quot;name&quot;: &quot;GIT_SYNC_DEST&quot;,\r\n                    &quot;value&quot;: &quot;/git&quot;\r\n                  }\r\n                ],\r\n                &quot;resources&quot;: {},\r\n                &quot;volumeMounts&quot;: [\r\n                  {\r\n                    &quot;name&quot;: &quot;markdown&quot;,\r\n                    &quot;mountPath&quot;: &quot;/git&quot;\r\n                  },\r\n                  {\r\n                    &quot;name&quot;: &quot;klucze&quot;,\r\n                    &quot;mountPath&quot;: &quot;/root/.ssh/klucze&quot;\r\n                  },\r\n                  {\r\n                    &quot;name&quot;: &quot;default-token-xjc9q&quot;,\r\n                    &quot;readOnly&quot;: true,\r\n                    &quot;mountPath&quot;: &quot;/var/run/secrets/kubernetes.io/serviceaccount&quot;\r\n                  }\r\n                ],\r\n                &quot;terminationMessagePath&quot;: &quot;/dev/termination-log&quot;,\r\n                &quot;imagePullPolicy&quot;: &quot;IfNotPresent&quot;\r\n              },\r\n              {\r\n                &quot;name&quot;: &quot;secprov&quot;,\r\n                &quot;image&quot;: &quot;lukaszbielinski/kubectl-image:0.19-secrets&quot;,\r\n                &quot;resources&quot;: {},\r\n                &quot;volumeMounts&quot;: [\r\n                  {\r\n                    &quot;name&quot;: &quot;markdown&quot;,\r\n                    &quot;mountPath&quot;: &quot;/srcsecrets&quot;\r\n                  },\r\n                  {\r\n                    &quot;name&quot;: &quot;default-token-xjc9q&quot;,\r\n                    &quot;readOnly&quot;: true,\r\n                    &quot;mountPath&quot;: &quot;/var/run/secrets/kubernetes.io/serviceaccount&quot;\r\n                  }\r\n                ],\r\n                &quot;terminationMessagePath&quot;: &quot;/dev/termination-log&quot;,\r\n                &quot;imagePullPolicy&quot;: &quot;Always&quot;\r\n              }\r\n            ],\r\n            &quot;restartPolicy&quot;: &quot;Always&quot;,\r\n            &quot;terminationGracePeriodSeconds&quot;: 30,\r\n            &quot;dnsPolicy&quot;: &quot;ClusterFirst&quot;,\r\n            &quot;serviceAccountName&quot;: &quot;default&quot;,\r\n            &quot;serviceAccount&quot;: &quot;default&quot;,\r\n            &quot;nodeName&quot;: &quot;minikubevm&quot;,\r\n            &quot;securityContext&quot;: {}\r\n          },\r\n          &quot;status&quot;: {\r\n            &quot;phase&quot;: &quot;Running&quot;,\r\n            &quot;conditions&quot;: [\r\n              {\r\n                &quot;type&quot;: &quot;Initialized&quot;,\r\n                &quot;status&quot;: &quot;True&quot;,\r\n                &quot;lastProbeTime&quot;: null,\r\n                &quot;lastTransitionTime&quot;: &quot;2016-07-30T10:44:11Z&quot;\r\n              },\r\n              {\r\n                &quot;type&quot;: &quot;Ready&quot;,\r\n                &quot;status&quot;: &quot;True&quot;,\r\n                &quot;lastProbeTime&quot;: null,\r\n                &quot;lastTransitionTime&quot;: &quot;2016-07-30T10:44:31Z&quot;\r\n              },\r\n              {\r\n                &quot;type&quot;: &quot;PodScheduled&quot;,\r\n                &quot;status&quot;: &quot;True&quot;,\r\n                &quot;lastProbeTime&quot;: null,\r\n                &quot;lastTransitionTime&quot;: &quot;2016-07-30T10:44:11Z&quot;\r\n              }\r\n            ],\r\n            &quot;hostIP&quot;: &quot;192.168.122.230&quot;,\r\n            &quot;podIP&quot;: &quot;172.17.0.10&quot;,\r\n            &quot;startTime&quot;: &quot;2016-07-30T10:44:11Z&quot;,\r\n            &quot;containerStatuses&quot;: [\r\n              {\r\n                &quot;name&quot;: &quot;git-sync&quot;,\r\n                &quot;state&quot;: {\r\n                  &quot;running&quot;: {\r\n                    &quot;startedAt&quot;: &quot;2016-07-30T10:44:12Z&quot;\r\n                  }\r\n                },\r\n                &quot;lastState&quot;: {},\r\n                &quot;ready&quot;: true,\r\n                &quot;restartCount&quot;: 0,\r\n                &quot;image&quot;: &quot;lukaszbielinski/git-sync:0.5&quot;,\r\n                &quot;imageID&quot;: &quot;docker://sha256:50f4c3009cd7072cb52d0edc5374ad973d7619ead7063482c4102fa230d16ce6&quot;,\r\n                &quot;containerID&quot;: &quot;docker://3d8f44f2c1cd8139fdf23660e5c7514d37ba5e39c739087f12defcfcd0a12f6d&quot;\r\n              },\r\n              {\r\n                &quot;name&quot;: &quot;secprov&quot;,\r\n                &quot;state&quot;: {\r\n                  &quot;running&quot;: {\r\n                    &quot;startedAt&quot;: &quot;2016-07-30T10:44:31Z&quot;\r\n                  }\r\n                },\r\n                &quot;lastState&quot;: {},\r\n                &quot;ready&quot;: true,\r\n                &quot;restartCount&quot;: 0,\r\n                &quot;image&quot;: &quot;lukaszbielinski/kubectl-image:0.19-secrets&quot;,\r\n                &quot;imageID&quot;: &quot;docker://sha256:6ebf833942e81d24d0bbc2f3e816f7620db979182ccf81a9edaf97488b512726&quot;,\r\n                &quot;containerID&quot;: &quot;docker://c1837b472c0a8123c244c7e7c5b4886a85e8607e8172271447024aa647a0a564&quot;\r\n              }\r\n            ]\r\n          }\r\n        }\r\n      ]\r\n    }\r\n\r\nthings I know:\r\n\r\n    &quot;secretName&quot;: &quot;klucze&quot;    \r\n\r\nthings I want extract\r\n\r\n    &quot;name&quot;: &quot;provisioner-secrets-1750468340-ei8sl&quot;    \r\n\r\n\r\nI tried \r\n\r\n    .items[] | .spec | .volumes[] | .secret | select(.secretName==&quot;klucze&quot;)    \r\n\r\n\r\nbut I don&#39;t know how to get correlated value from \r\n\r\n    .items[] | .metadata | .name    \r\n\r\n\r\nPlease suggest how can I resolve this problem",
        "link": "https://stackoverflow.com/questions/38674118/extract-correlated-value-in-nested-array",
        "title": "extract correlated value in nested array"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3118620,
                    "reputation": 2267,
                    "user_id": 2638872,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/657d6368539f235931cebfd857dc51a1?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "mrtig",
                    "link": "https://stackoverflow.com/users/2638872/mrtig"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1470013110,
                "post_id": 38689645,
                "comment_id": 64758886,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 5151128,
                    "reputation": 2168,
                    "user_id": 4125723,
                    "user_type": "registered",
                    "accept_rate": 95,
                    "profile_image": "https://i.sstatic.net/GLiXp.gif?s=256",
                    "display_name": "x3nr0s",
                    "link": "https://stackoverflow.com/users/4125723/x3nr0s"
                },
                "reply_to_user": {
                    "account_id": 3118620,
                    "reputation": 2267,
                    "user_id": 2638872,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/657d6368539f235931cebfd857dc51a1?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "mrtig",
                    "link": "https://stackoverflow.com/users/2638872/mrtig"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1470013451,
                "post_id": 38689645,
                "comment_id": 64758938,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 8151465,
                    "reputation": 769,
                    "user_id": 6639975,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/dvwQi.jpg?s=256",
                    "display_name": "GypsyCosmonaut",
                    "link": "https://stackoverflow.com/users/6639975/gypsycosmonaut"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1621232727,
                "post_id": 38689645,
                "comment_id": 119423053,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1470013678,
                "creation_date": 1470013678,
                "answer_id": 38689752,
                "question_id": 38689645,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Give this a shot: \r\n\r\n    echo $jsonVariable | jq &#39;{Name: .details.name, Id: .Id}  | select(.name == &quot;James Brown&quot;)&#39;",
                "title": "jq - How do I print a parent value of an object when I am already deep into the object&#39;s children?"
            },
            {
                "up_vote_count": 5,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1470020978,
                "creation_date": 1470020978,
                "answer_id": 38690477,
                "question_id": 38689645,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Rather than querying up to the value you&#39;re testing for, query up to the root object that contains the value you&#39;re querying on and the values you wish to select.\r\n\r\nYou need the object that contains both the `id` and the `name`.\r\n\r\n    $ jq --arg name &#39;James Brown&#39; &#39;select(.details.name == $name).id&#39; input.json",
                "title": "jq - How do I print a parent value of an object when I am already deep into the object&#39;s children?"
            },
            {
                "up_vote_count": 110,
                "is_accepted": true,
                "score": 110,
                "last_activity_date": 1470038362,
                "creation_date": 1470038362,
                "answer_id": 38693695,
                "question_id": 38689645,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "For a more generic approach, save the value of the &quot;parent&quot; element at the detail level you want, then pipe it at the end of your filter:\r\n\r\n`jq &#39;. as $parent | .details.name | select(. == &quot;James Brown&quot;) | $parent&#39;`\r\n\r\nOf course, for the trivial case you expose, you could omit this entirely:\r\n\r\n`jq &#39;select(.details.name == &quot;James Brown&quot;)&#39;`\r\n\r\nAlso, consider that if your selecting filters return many matches for a single parent object, you will receive a copy of the parent object for each match. You may wish to make sure your select filters only return one element at the parent level by wrapping all matches below parent level into an array, or to deduplicate the final result with `unique`.",
                "title": "jq - How do I print a parent value of an object when I am already deep into the object&#39;s children?"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 74,
        "last_activity_date": 1547049091,
        "creation_date": 1470012419,
        "last_edit_date": 1540492316,
        "question_id": 38689645,
        "body_markdown": "Say I have the following JSON, stored in my variable *jsonVariable*.\r\n\r\n    {\r\n        &quot;id&quot;: 1,\r\n        &quot;details&quot;: {\r\n            &quot;username&quot;: &quot;jamesbrown&quot;,\r\n            &quot;name&quot;: &quot;James Brown&quot;\r\n        }\r\n    }\r\n\r\nI parse this JSON with jq using the following:\r\n\r\n    echo $jsonVariable | jq &#39;.details.name | select(.name == &quot;James Brown&quot;)&#39;\r\n\r\nThis would give me the output\r\n\r\n*James Brown*\r\n\r\nBut what if I want to get the id of this person as well? Now, I&#39;m aware this is a rough and simple example - the program I&#39;m working with at the moment is 5 or 6 levels deep with many different JQ functions other than select. I need a way to select a parent&#39;s field when I am already 5 or 6 layers deep after carrying out various methods of filtering.\r\n\r\nCan anyone help? Is there any way of &#39;going in reverse&#39;, back up to the parent? (Not sure if I&#39;m making sense!)",
        "link": "https://stackoverflow.com/questions/38689645/jq-how-do-i-print-a-parent-value-of-an-object-when-i-am-already-deep-into-the",
        "title": "jq - How do I print a parent value of an object when I am already deep into the object&#39;s children?"
    },
    {
        "tags": [
            "json",
            "jq",
            "amazon-ecs"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1470098042,
                "creation_date": 1470098042,
                "answer_id": 38710069,
                "question_id": 38709766,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You have to select the corresponding environment node first before setting the value.  Your query doesn&#39;t change the context so it&#39;s still on the root item so you end up adding the new value to the root.\r\n\r\n    $ jq --arg update_name &quot;CONFIG_URL&quot; --arg update_value &quot;this is a test&quot; \\\r\n    &#39;(.containerDefinitions[].environment[] | select(.name == $update_name)).value = $update_value&#39; input.json",
                "title": "Jq update JSON key:value based on value"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1503890692,
                "creation_date": 1503890692,
                "answer_id": 45911409,
                "question_id": 38709766,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a solution which uses jq [Complex assignments](https://github.com/stedolan/jq/blob/master/docs/content/3.manual/manual.yml#L3042-L3080)\r\n\r\n    (\r\n      .containerDefinitions[]\r\n    | .environment[]\r\n    | select(.name == &quot;CONFIG_URL&quot;)\r\n    | .value\r\n    ) |= &quot;this is atest&quot;\r\n\r\n",
                "title": "Jq update JSON key:value based on value"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1546690239,
        "creation_date": 1470095571,
        "question_id": 38709766,
        "body_markdown": "I&#39;m pretty new to jq and wanted to use it to update an AWS ECS task definition with a new value. AWS cli returns the following json response and i would like to modify the object with *name* property *CONFIG_URL* with *value* &quot;this is atest&quot;. \r\n\r\n    {\r\n      &quot;family&quot;: &quot;contentpublishing-task&quot;,\r\n      &quot;volumes&quot;: [],\r\n      &quot;containerDefinitions&quot;: [\r\n        {\r\n          &quot;environment&quot;: [\r\n            {\r\n              &quot;name&quot;: &quot;TEST_ENV&quot;,\r\n              &quot;value&quot;: &quot;TEST&quot;\r\n            },\r\n            {\r\n              &quot;name&quot;: &quot;CONFIG_URL&quot;,\r\n              &quot;value&quot;: &quot;s3://stg-appcfg/config-20160729-1130.json&quot;\r\n            }\r\n          ],\r\n          &quot;name&quot;: &quot;contentpublishing&quot;,\r\n          &quot;mountPoints&quot;: [],\r\n          &quot;image&quot;: &quot;contentpublishing:blah&quot;,\r\n          &quot;cpu&quot;: 512,\r\n          &quot;portMappings&quot;: [\r\n            {\r\n              &quot;protocol&quot;: &quot;tcp&quot;,\r\n              &quot;containerPort&quot;: 8081,\r\n              &quot;hostPort&quot;: 8080\r\n            }\r\n          ],\r\n          &quot;memory&quot;: 256,\r\n          &quot;essential&quot;: true,\r\n          &quot;volumesFrom&quot;: []\r\n        }\r\n      ]\r\n    }\r\n\r\nTried the following query \r\n\r\n     cat test.json | jq &#39;select(.containerDefinitions[0].environment[].name==&quot;CONFIG_URL&quot;).value|=&quot;this is atest&quot;&#39; 2&gt;&amp;1 \r\n\r\nBut following has been returned. As you can see an additional value key is added the outer most json object.\r\n\r\n    {\r\n      &quot;family&quot;: &quot;contentpublishing-task&quot;,\r\n      &quot;volumes&quot;: [],\r\n      &quot;containerDefinitions&quot;: [\r\n        {\r\n          &quot;environment&quot;: [\r\n            {\r\n              &quot;name&quot;: &quot;TEST_ENV&quot;,\r\n              &quot;value&quot;: &quot;TEST&quot;\r\n            },\r\n            {\r\n              &quot;name&quot;: &quot;CONFIG_URL&quot;,\r\n              &quot;value&quot;: &quot;s3://stg-appcfg/config-20160729-1130.json&quot;\r\n            }\r\n          ],\r\n          &quot;name&quot;: &quot;contentpublishing&quot;,\r\n          &quot;mountPoints&quot;: [],\r\n          &quot;image&quot;: &quot;contentpublishing:blah&quot;,\r\n          &quot;cpu&quot;: 512,\r\n          &quot;portMappings&quot;: [\r\n            {\r\n              &quot;protocol&quot;: &quot;tcp&quot;,\r\n              &quot;containerPort&quot;: 8081,\r\n              &quot;hostPort&quot;: 8080\r\n            }\r\n          ],\r\n          &quot;memory&quot;: 256,\r\n          &quot;essential&quot;: true,\r\n          &quot;volumesFrom&quot;: []\r\n        }\r\n      ],\r\n      &quot;value&quot;: &quot;this is atest&quot;\r\n    }\r\n",
        "link": "https://stackoverflow.com/questions/38709766/jq-update-json-keyvalue-based-on-value",
        "title": "Jq update JSON key:value based on value"
    },
    {
        "tags": [
            "linux",
            "jq",
            "amazon-linux"
        ],
        "answers": [
            {
                "up_vote_count": 63,
                "is_accepted": true,
                "score": 62,
                "last_activity_date": 1470131676,
                "creation_date": 1470131676,
                "answer_id": 38717223,
                "question_id": 38716209,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "jq is available in the yum repo so run the following\r\n\r\n    sudo yum install jq\r\n\r\nwill install jq on the instance",
                "title": "How to install jq on amazon EC2 instance"
            },
            {
                "up_vote_count": 15,
                "is_accepted": false,
                "score": 15,
                "last_activity_date": 1579515100,
                "creation_date": 1579515100,
                "answer_id": 59821030,
                "question_id": 38716209,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Tried yum install jq on RHEL but did not work as this package is not there..However following commands made the JQ available on my RHEL machine on AWS...\r\n\r\n    wget -O jq https://github.com/stedolan/jq/releases/download/jq-1.6/jq-linux64\r\n    chmod +x ./jq\r\n    cp jq /usr/bin",
                "title": "How to install jq on amazon EC2 instance"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 33,
        "last_activity_date": 1579515100,
        "creation_date": 1470128878,
        "last_edit_date": 1528786191,
        "question_id": 38716209,
        "body_markdown": "I am trying to install jq JSON parser on amazon instance, unfortunately, i&#39;m not able to install it can someone guide me.",
        "link": "https://stackoverflow.com/questions/38716209/how-to-install-jq-on-amazon-ec2-instance",
        "title": "How to install jq on amazon EC2 instance"
    },
    {
        "tags": [
            "bash",
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2251762,
                    "reputation": 292345,
                    "user_id": 1983854,
                    "user_type": "registered",
                    "accept_rate": 96,
                    "profile_image": "https://i.sstatic.net/KiqLo.png?s=256",
                    "display_name": "fedorqui",
                    "link": "https://stackoverflow.com/users/1983854/fedorqui"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1470137504,
                "post_id": 38719225,
                "comment_id": 64814529,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 3597475,
                    "reputation": 983,
                    "user_id": 3001733,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/33f896531860ff37015d7738a2aa3f3c?s=256&d=identicon&r=PG",
                    "display_name": "KartikKannapur",
                    "link": "https://stackoverflow.com/users/3001733/kartikkannapur"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1470137823,
                "post_id": 38719225,
                "comment_id": 64814733,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 8936793,
                    "reputation": 9,
                    "user_id": 6667371,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d818b6e445bfbd51be26135f64309710?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Arun",
                    "link": "https://stackoverflow.com/users/6667371/arun"
                },
                "reply_to_user": {
                    "account_id": 3597475,
                    "reputation": 983,
                    "user_id": 3001733,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/33f896531860ff37015d7738a2aa3f3c?s=256&d=identicon&r=PG",
                    "display_name": "KartikKannapur",
                    "link": "https://stackoverflow.com/users/3001733/kartikkannapur"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1470139254,
                "post_id": 38719225,
                "comment_id": 64815774,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1470156703,
                "creation_date": 1470156703,
                "answer_id": 38726326,
                "question_id": 38719225,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Given your input, you could create that as csv data using this:\r\n\r\n    $ jq -rs &#39;\r\n    def to_csv($headers):\r\n        def _object_to_csv:\r\n            ($headers | @csv),\r\n            (.[] | [.[$headers[]]] | @csv);\r\n        def _array_to_csv:\r\n            ($headers | @csv),\r\n            (.[][:$headers|length] | @csv);\r\n        if .[0]|type == &quot;object&quot; then\r\n            _object_to_csv\r\n        else\r\n            _array_to_csv\r\n        end;\r\n    map({ label: .info, date: .timestamp[:10] })\r\n        | group_by(.)\r\n        | map(.[0] + { count: length })\r\n        | to_csv([&quot;label&quot;, &quot;date&quot;, &quot;count&quot;])\r\n    &#39; input.json\r\n\r\nThis yields:\r\n\r\n    &quot;label&quot;,&quot;date&quot;,&quot;count&quot;\r\n    &quot;label1&quot;,&quot;2016-07-27&quot;,1\r\n    &quot;label2&quot;,&quot;2016-07-27&quot;,2\r\n    &quot;label2&quot;,&quot;2016-07-29&quot;,1\r\n    &quot;label3&quot;,&quot;2016-07-29&quot;,1\r\n\r\n",
                "title": "How to read from a json log file in a shell script .sh file and get the analytics data by counting the number of occurance in the log file"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1503542345,
                "creation_date": 1503542345,
                "answer_id": 45852089,
                "question_id": 38719225,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is an approach which uses **reduce** instead of **group_by**.  \r\n\r\nAssuming your data is in `out.log` and the following filter in `filter.jq`\r\n\r\n    [&quot;Labels&quot;, &quot;Date&quot;, &quot;Count&quot;], \r\n    [&quot;&quot;, &quot;&quot;, &quot;&quot;], \r\n    (\r\n      reduce .[] as $r (\r\n          {}\r\n        ; [$r.info, $r.timestamp[0:10]] as $p\r\n        | setpath($p;getpath($p)+1)\r\n      )\r\n      | tostream\r\n      | select(length==2)\r\n      | flatten\r\n    )\r\n    | @tsv\r\n    \r\nyou can run \r\n\r\n    jq -M -s -r -f filter.jq out.log\r\n\r\nto produce tab-separated output\r\n\r\n    Labels\tDate\tCount\r\n    \t\t\r\n    label1\t2016-07-27\t1\r\n    label2\t2016-07-27\t2\r\n    label2\t2016-07-29\t1\r\n    label3\t2016-07-29\t1",
                "title": "How to read from a json log file in a shell script .sh file and get the analytics data by counting the number of occurance in the log file"
            }
        ],
        "is_answered": false,
        "answer_count": 2,
        "score": -2,
        "last_activity_date": 1503542345,
        "creation_date": 1470137384,
        "last_edit_date": 1470139211,
        "question_id": 38719225,
        "body_markdown": "Need to read data from a json log file and get analytics data from that using shell script.\r\n\r\n**log file contains json as below:**\r\n\r\n    {\r\n    info: &#39;label1&#39;,\r\n    description: &#39;some desc&#39;,\r\n    timestamp: &#39;2016-07-27T06:24:50.335Z&#39;\r\n    }\r\n    {\r\n    info: &#39;label2&#39;,\r\n    description: &#39;some desc&#39;,\r\n    timestamp: &#39;2016-07-27T06:24:50.335Z&#39;\r\n    }\r\n    {\r\n    info: &#39;label2&#39;,\r\n    description: &#39;some desc&#39;,\r\n    timestamp: &#39;2016-07-27T06:24:50.335Z&#39;\r\n    }\r\n    {\r\n    info: &#39;label2&#39;,\r\n    description: &#39;some desc&#39;,\r\n    timestamp: &#39;2016-07-29T06:24:50.335Z&#39;\r\n    }\r\n    {\r\n    info: &#39;label3&#39;,\r\n    description: &#39;some desc&#39;,\r\n    timestamp: &#39;2016-07-29T06:24:50.335Z&#39;\r\n    }\r\n\r\n**I need the result as below (using shell script):**\r\n\r\n    Labels    Date                  Count\r\n    \r\n    label1   2016-07-27             1\r\n    label2   2016-07-27             2              \r\n    label2   2016-07-29             1\r\n    label3   2016-07-29             1\r\n\r\nThis is as far I could go, need some suggestion on how to approach.\\\r\n\r\n    #!/bin/bash\r\n    my_dir=`dirname $0`\r\n    file=&quot;out.log&quot;\r\n    #keysFile=&quot;$my_dir/keys.txt&quot;\r\n    for log in $(cat $file | jq &#39;{id: .info,time: .timestamp}&#39;); do\r\n    #This is as far as I could get. I was able to read the data in the form of {id: &#39;label1&#39;, time: &#39;2016-07-27T06:24:50.335Z&#39; }\r\n    #Now I need to somehow create a key value thing in shell and store timestamp / label as key and increment the count\r\n    echo $log\r\n    done\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/38719225/how-to-read-from-a-json-log-file-in-a-shell-script-sh-file-and-get-the-analytic",
        "title": "How to read from a json log file in a shell script .sh file and get the analytics data by counting the number of occurance in the log file"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1470198182,
                "creation_date": 1470198182,
                "answer_id": 38734364,
                "question_id": 38734034,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "There&#39;s plenty of ways you can do this but the simplest way you can do so is to convert that object to entries so you can get access to the keys, then filter the entries by the names you want then back again.\r\n\r\n    with_entries(select(.key | startswith(&quot;tag_Name&quot;)))",
                "title": "How to make it work with filter in jq"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1503892484,
                "creation_date": 1503892484,
                "answer_id": 45911593,
                "question_id": 38734034,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here are a few more solutions:\r\n\r\n1) combining values for matching keys with **add**\r\n\r\n       . as $d\r\n     | keys\r\n     | map( select(startswith(&quot;tag_Name&quot;)) | {(.): $d[.]} )\r\n     | add\r\n     \r\n2) filtering out non-matching keys with **delpaths**\r\n\r\n     delpaths([\r\n          keys[]\r\n        | select(startswith(&quot;tag_Name&quot;) | not)\r\n        | [.]\r\n     ])\r\n\r\n3) filtering out non-matching keys with **reduce** and **del**\r\n\r\n     reduce keys[] as $k (\r\n       .\r\n     ; if ($k|startswith(&quot;tag_Name&quot;)) then . else del(.[$k]) end\r\n     )\r\n     ",
                "title": "How to make it work with filter in jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 4,
        "last_activity_date": 1503892484,
        "creation_date": 1470195996,
        "question_id": 38734034,
        "body_markdown": "I&#39;d like to filter output from below json file to get all start with &quot;tag_Name&quot;\r\n\r\n    {\r\n      ...\r\n\r\n      &quot;tag_Name_abc&quot;: [\r\n        &quot;10_1_4_3&quot;,\r\n        &quot;10_1_6_2&quot;,\r\n        &quot;10_1_5_3&quot;,\r\n        &quot;10_1_5_5&quot;\r\n      ],\r\n      &quot;tag_Name_efg&quot;: [\r\n        &quot;10_1_4_5&quot;\r\n      ],\r\n\r\n      ...\r\n\r\n    }\r\n\r\nTry something but failed.\r\n\r\n    $ cat output.json |jq &#39;map(select(startswith(&quot;tag_Name&quot;)))&#39;\r\n    jq: error (at &lt;stdin&gt;:1466): startswith() requires string inputs",
        "link": "https://stackoverflow.com/questions/38734034/how-to-make-it-work-with-filter-in-jq",
        "title": "How to make it work with filter in jq"
    },
    {
        "tags": [
            "json",
            "parsing",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1470218580,
                "last_edit_date": 1470218580,
                "creation_date": 1470216544,
                "answer_id": 38739652,
                "question_id": 38738843,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You can use the following `jq` command:\r\n\r\n    jq &#39;.Maps.Campus[]|&quot;\\(.name)&gt;\\(.Building[]|&quot;\\(.name)&gt;\\(.Floor[]?.name)&quot;)&quot;&#39; file.json\r\n\r\n`jq` is smart enough to print the combinations of `.name` and `.Building[].name` since `.Building` is an array. The same action get&#39;s applied to `.Building[].name` and `Floor[]?.name`. `?` because floor is not always set.",
                "title": "jq json parser concate nested array object value"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1503892885,
                "creation_date": 1503892885,
                "answer_id": 45911639,
                "question_id": 38738843,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a solution which uses jq variables\r\n\r\n      .Maps.Campus[]\r\n    | .name as $campus\r\n    | .Building[]\r\n    | .name as $bldg\r\n    | .Floor[]?\r\n    | .name as $floor\r\n    | &quot;\\($campus)&gt;\\($bldg)&gt;\\($floor)&quot;",
                "title": "jq json parser concate nested array object value"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1503892885,
        "creation_date": 1470214376,
        "last_edit_date": 1470217193,
        "question_id": 38738843,
        "body_markdown": "Hi I have the below JSON file with nested object:\r\n\r\n    {\r\n      &quot;Maps&quot;: {\r\n        &quot;Campus&quot;: [\r\n          {\r\n            &quot;name&quot;: &quot;nus&quot;,\r\n            &quot;Building&quot;: [\r\n              {\r\n                &quot;name&quot;: &quot;sde1&quot;,\r\n                &quot;Floor&quot;: [\r\n                  {\r\n                    &quot;name&quot;: &quot;floor1&quot;\r\n                  },\r\n                  {\r\n                    &quot;name&quot;: &quot;floor2&quot;\r\n                  }\r\n                ]\r\n              },\r\n              {\r\n                &quot;name&quot;: &quot;sde2&quot;\r\n              }\r\n            ]\r\n          },\r\n          {\r\n            &quot;name&quot;: &quot;ntu&quot;,\r\n            &quot;Building&quot;: [\r\n              {\r\n                &quot;name&quot;: &quot;ece1&quot;,\r\n                &quot;Floor&quot;: [\r\n                  {\r\n                    &quot;name&quot;: &quot;floor1&quot;\r\n                  },\r\n                  {\r\n                    &quot;name&quot;: &quot;floor2&quot;\r\n                  }\r\n                ]\r\n              },\r\n              {\r\n                &quot;name&quot;: &quot;ece2&quot;\r\n              }\r\n            ]\r\n          }\r\n        ]\r\n      }\r\n    }\r\n\r\nI want to use `jq` to parse the above JSON file and get the below format:\r\n\r\n    nus&gt;sde1&gt;floor1\r\n    nus&gt;sde1&gt;floor2\r\n    ntu&gt;ece1&gt;floor1\r\n    ntu&gt;ece1&gt;floor2\r\n\r\n\r\nbasically I have to concatenate the `Campus Name` with `Building Name` and `Floor name` and put a `&lt;` symbol in between.\r\n\r\nIf the nested object field `Floor` is not exist, ignore the parse and continue the next child object.\r\n\r\nHow to achieve that? thanks.\r\n",
        "link": "https://stackoverflow.com/questions/38738843/jq-json-parser-concate-nested-array-object-value",
        "title": "jq json parser concate nested array object value"
    },
    {
        "tags": [
            "parsing",
            "hash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 4624068,
                    "reputation": 54457,
                    "user_id": 3748349,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/ArUlH.png?s=256",
                    "display_name": "Hans Z.",
                    "link": "https://stackoverflow.com/users/3748349/hans-z"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1470222801,
                "post_id": 38739648,
                "comment_id": 64857662,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 1259023,
                    "reputation": 1189,
                    "user_id": 1217856,
                    "user_type": "registered",
                    "accept_rate": 74,
                    "profile_image": "https://www.gravatar.com/avatar/8a54782c26b32dd10766189b5417e64d?s=256&d=identicon&r=PG",
                    "display_name": "Xianlin",
                    "link": "https://stackoverflow.com/users/1217856/xianlin"
                },
                "reply_to_user": {
                    "account_id": 4624068,
                    "reputation": 54457,
                    "user_id": 3748349,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/ArUlH.png?s=256",
                    "display_name": "Hans Z.",
                    "link": "https://stackoverflow.com/users/3748349/hans-z"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1470277767,
                "post_id": 38739648,
                "comment_id": 64887589,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1517463749,
                "last_edit_date": 1517463749,
                "creation_date": 1472726226,
                "answer_id": 39269280,
                "question_id": 38739648,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "&gt; My expected hash function can be simple as using native linux command **md5sum**\r\n\r\nThis stays native and might be suitable;\r\n\r\n\r\nInvocation :\r\n------\r\n   \r\n    jq -c .[] &quot;$jsonfile&quot; |\r\n    while read -r jsonline ; do\r\n\t  hashmac=&quot;$(jq --arg mysalt &quot;$mysalt&quot; -s -j &#39;\r\n            .[] | &quot;\\($mysalt)&quot; + .macAddress&#39; &lt;&lt;&lt;&quot;$jsonline&quot; |\r\n          md5sum | cut -d &#39; &#39; -f1)&quot;\r\n      jq --arg hashmac &quot;$hashmac&quot; -s -r &#39;\r\n          .[] | .macAddress |= &quot;\\($hashmac)&quot;&#39; &lt;&lt;&lt;&quot;$jsonline&quot;\r\n    done\r\n\r\n\r\n-----\r\n\r\nExample file - /tmp/testfile:\r\n-----\r\n\r\n    [{\r\n      &quot;macAddress&quot;: &quot;ac:5f:3e:87:d7:1a&quot;,\r\n      &quot;ip&quot;: &quot;1.2.3.4&quot;\r\n    },\r\n    {\r\n      &quot;macAddress&quot;: &quot;ac:5f:3e:87:d7:2a&quot;,\r\n      &quot;ip&quot;: &quot;1.2.3.4&quot;\r\n    },\r\n    {\r\n      &quot;macAddress&quot;: &quot;ac:5f:3e:87:d7:3a&quot;,\r\n      &quot;ip&quot;: &quot;1.2.3.4&quot;\r\n    },\r\n    {\r\n     &quot;macAddress&quot;: &quot;42:12:20:2e:2b:ca&quot;,\r\n     &quot;ip&quot;: &quot;1.2.3.4&quot;\r\n    }]\r\n\r\n\r\n\r\nResult Output: \r\n-----\r\n\r\n\r\n    {\r\n      &quot;macAddress&quot;: &quot;1f960fe4d24684ca44e5e67b6259362c&quot;,\r\n      &quot;ip&quot;: &quot;1.2.3.4&quot;\r\n    }\r\n    {\r\n      &quot;macAddress&quot;: &quot;3527422754ecbfdd01d48b17fce87842&quot;,\r\n      &quot;ip&quot;: &quot;1.2.3.4&quot;\r\n    }\r\n    {\r\n      &quot;macAddress&quot;: &quot;9bc8da72324448c3032a20fb67a31466&quot;,\r\n      &quot;ip&quot;: &quot;1.2.3.4&quot;\r\n    }\r\n    {\r\n      &quot;macAddress&quot;: &quot;d973ea7c353e78ba1724efbc8054dfdc&quot;,\r\n      &quot;ip&quot;: &quot;1.2.3.4&quot;\r\n    }\r\n\r\nComments:\r\n-------\r\n\r\n - `-j` causes jq to not output a newline, equivalent to your `echo -n` example\r\n\r\n - Variables in this example are sent to `jq` as strings using `-arg`, and referenced as `&quot;\\($var)&quot;` **as opposed to** escaping the variable directly, for example: \r\n\r\n   - `&quot;\\($mysalt)&quot; + .macAddress&#39;` (jq variable)\r\n\r\n        Instead of:\r\n\r\n   - `&quot;&#39;&quot;$mysalt&quot;&#39;&quot; + .macAddress&#39;` (direct shell substitution)\r\n\r\n - This example uses `cut -d &#39; &#39; -f1` to trim off the ` -`, but there&#39;s probably a better way\r\n\r\nAlternate:\r\n-------\r\n\r\n`jq --arg hashmac &quot;$hashmac&quot; -s -r &#39;.[]  |= . + {&quot;hashAddress&quot;:&quot;\\($hashmac)&quot;}&#39;`\r\n\r\nWould append the json\r\n\r\n    [\r\n      {\r\n        &quot;macAddress&quot;: &quot;ac:5f:3e:87:d7:1a&quot;,\r\n        &quot;ip&quot;: &quot;1.2.3.4&quot;,\r\n        &quot;hashAddress&quot;: &quot;1f960fe4d24684ca44e5e67b6259362c&quot;\r\n      }\r\n    ]\r\n\r\netc.\r\n\r\n",
                "title": "jq json parser hash the field value"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1517499284,
                "creation_date": 1517499284,
                "answer_id": 48566445,
                "question_id": 38739648,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The accepted answer entails 2n + 1 invocations of jq, where n is the number invocations of the message digest function. \r\n\r\nTo reduce the number of invocations to just 2, see https://stackoverflow.com/questions/48548580/shell-out-value-to-md5-crypto-function",
                "title": "jq json parser hash the field value"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1517499284,
        "creation_date": 1470216537,
        "last_edit_date": 1470413575,
        "question_id": 38739648,
        "body_markdown": "I have a JSON file as the below:\r\n\r\n    [{\r\n      &quot;macAddress&quot;: &quot;ac:5f:3e:87:d7:1a&quot;,\r\n      &quot;ip&quot;: &quot;1.2.3.4&quot;\r\n    },\r\n    {\r\n      &quot;macAddress&quot;: &quot;ac:5f:3e:87:d7:2a&quot;,\r\n      &quot;ip&quot;: &quot;1.2.3.4&quot;\r\n    },\r\n    {\r\n      &quot;macAddress&quot;: &quot;ac:5f:3e:87:d7:3a&quot;,\r\n      &quot;ip&quot;: &quot;1.2.3.4&quot;\r\n    }]\r\n\r\n\r\nuse `jq` to hash the `macAddress` field like so:\r\n\r\n    jq .[] | hash(.macAddress)\r\n\r\nCan I define my own hash function and let `jq` to run the hash during the parsing process?\r\n\r\nMy expected hash function can be simple as using native linux command `md5sum`\r\n\r\n    echo -n &quot;my_salt&quot;&quot;42:12:20:2e:2b:ca&quot; | md5sum\r\n    d973ea7c353e78ba1724efbc8054dfdc -\r\n\r\n\r\nSo the output json will be\r\n\r\n    [{\r\n      &quot;macAddress&quot;: &quot;d973ea7c353e78ba1724efbc8054dfdc&quot;,\r\n      &quot;ip&quot;: &quot;1.2.3.4&quot;\r\n    },\r\n    {\r\n      &quot;macAddress&quot;: &quot;d973ea7c353e78ba1724efbc8054d2er&quot;,\r\n      &quot;ip&quot;: &quot;1.2.3.4&quot;\r\n    },\r\n    {\r\n      &quot;macAddress&quot;: &quot;d973ea7c353e78ba2324efbc8054d123&quot;,\r\n      &quot;ip&quot;: &quot;1.2.3.4&quot;\r\n    }]\r\n \r\n",
        "link": "https://stackoverflow.com/questions/38739648/jq-json-parser-hash-the-field-value",
        "title": "jq json parser hash the field value"
    },
    {
        "tags": [
            "json",
            "jq",
            "jsawk"
        ],
        "answers": [
            {
                "up_vote_count": 29,
                "is_accepted": true,
                "score": 29,
                "last_activity_date": 1743611109,
                "last_edit_date": 1743611109,
                "creation_date": 1470261269,
                "answer_id": 38754276,
                "question_id": 38752499,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You would either have to use the command line arg `--argjson` or `fromjson` filter to convert the argument to a number.  Arrays may only be indexed by ints and using `--arg` keeps the input as a string.\r\n\r\n    $ jq --argjson i &quot;$i&quot; &#39;.SecurityGroups[$i]&#39;\r\n    $ jq --arg i &quot;$i&quot; &#39;.SecurityGroups[$i|fromjson]&#39;",
                "title": "How can I put integer as an argument in jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 23,
        "last_activity_date": 1743611109,
        "creation_date": 1470254086,
        "question_id": 38752499,
        "body_markdown": "I have been trying to use jq to parse a json file returned from the aws cli, but I&#39;m stuck with the problem of referencing an array using the index number. I need to do this because I want to export a text file describing the security groups in a specific format, including all the inbound and outbound rules.\r\n\r\n\r\n    for (( i=1; i&lt;=groupCount; i++ )) ; \r\n    do\r\n        echo $i\r\n        echo $(echo &quot;$input&quot; | jq --arg i $i &#39;.SecurityGroups[$i]&#39;)\r\n    done\r\n\r\n\r\n\r\nThis returns an error:\r\n\r\n\r\n    1\r\n    jq: error (at &lt;stdin&gt;:189): Cannot index array with string &quot;1&quot;\r\n    \r\n    2\r\n    jq: error (at &lt;stdin&gt;:189): Cannot index array with string &quot;2&quot;\r\n    \r\n    3\r\n    jq: error (at &lt;stdin&gt;:189): Cannot index array with string &quot;3&quot;\r\n\r\n\r\n\r\nIs there any way around this?\r\n",
        "link": "https://stackoverflow.com/questions/38752499/how-can-i-put-integer-as-an-argument-in-jq",
        "title": "How can I put integer as an argument in jq?"
    },
    {
        "tags": [
            "json",
            "bash",
            "parsing",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 8,
                "is_accepted": true,
                "score": 7,
                "last_activity_date": 1476041403,
                "last_edit_date": 1476041403,
                "creation_date": 1470360707,
                "answer_id": 38779788,
                "question_id": 38779732,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Assuming you wanted to list out the key/values of the `apps` object:\r\n\r\n    $ jq -r &#39;.apps | to_entries[] | &quot;\\(.key)\\t\\(.value)&quot;&#39; input.json\r\n\r\nTo invoke another program using the output as arguments, you should get acquainted with [xargs](https://linux.die.net/man/1/xargs):\r\n\r\n    $ jq -r &#39;...&#39; input.json | xargs some_program",
                "title": "Running bash commands for each JSON item through jq"
            },
            {
                "up_vote_count": 5,
                "is_accepted": false,
                "score": 5,
                "last_activity_date": 1504023472,
                "creation_date": 1504023472,
                "answer_id": 45943903,
                "question_id": 38779732,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is an bash script which demonstrates a possible solution.\r\n\r\n    #!/bin/bash\r\n    json=&#39;\r\n    {\r\n        &quot;apps&quot;: {\r\n            &quot;firefox&quot;: &quot;1.0.0&quot;,\r\n            &quot;ie&quot;: &quot;1.0.1&quot;,\r\n            &quot;chrome&quot;: &quot;2.0.0&quot;\r\n        }\r\n    }&#39;\r\n    \r\n    jq -M -r &#39;\r\n        .apps | keys[] as $k | $k, .[$k]\r\n    &#39; &lt;&lt;&lt; &quot;$json&quot; | \\\r\n    while read -r key; read -r val; do\r\n       echo &quot;$key $val&quot;\r\n    done\r\n    \r\nExample output\r\n    \r\n    chrome 2.0.0\r\n    firefox 1.0.0\r\n    ie 1.0.1\r\n",
                "title": "Running bash commands for each JSON item through jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 14,
        "last_activity_date": 1504023472,
        "creation_date": 1470360057,
        "last_edit_date": 1470360718,
        "question_id": 38779732,
        "body_markdown": "I would like to run a bash command for each field in a JSON formatted piece of data by leveraging jq.\r\n\r\n    {\r\n        &quot;apps&quot;: {\r\n            &quot;firefox&quot;: &quot;1.0.0&quot;,\r\n            &quot;ie&quot;: &quot;1.0.1&quot;,\r\n            &quot;chrome&quot;: &quot;2.0.0&quot;\r\n        }\r\n    }\r\n\r\nBasically I want something of the sort:\r\n\r\n    foreach app:\r\n       echo &quot;$key $val&quot;\r\n    done\r\n\r\n",
        "link": "https://stackoverflow.com/questions/38779732/running-bash-commands-for-each-json-item-through-jq",
        "title": "Running bash commands for each JSON item through jq"
    },
    {
        "tags": [
            "json",
            "amazon-web-services",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 7501,
                    "reputation": 202732,
                    "user_id": 13070,
                    "user_type": "registered",
                    "accept_rate": 90,
                    "profile_image": "https://i.sstatic.net/G3J7P8QE.jpg?s=256",
                    "display_name": "Mark B",
                    "link": "https://stackoverflow.com/users/13070/mark-b"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1470591622,
                "post_id": 38816114,
                "comment_id": 65000637,
                "content_license": "CC BY-SA 3.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": 1471164153,
                "post_id": 38816114,
                "comment_id": 65236254,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1470602547,
                "last_edit_date": 1470602547,
                "creation_date": 1470592010,
                "answer_id": 38816892,
                "question_id": 38816114,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You could just pipe the filters of each invocation and you should get the same result.\r\n\r\n    $ jq &#39;.ChangeBatch.Changes[].Action = &quot;UPSERT&quot;\r\n        | .ChangeBatch.Changes[].ResourceRecordSet.Name = &quot;host.domain&quot;\r\n        | .ChangeBatch.Changes[].ResourceRecordSet.Type = &quot;A&quot;\r\n        | .ChangeBatch.Changes[].ResourceRecordSet.ResourceRecords[].TTL =&quot;300&quot;\r\n        | .ChangeBatch.Changes[].ResourceRecordSet.ResourceRecords[].Value =&quot;10.120.0.1&quot;&#39; x.json\r\n\r\nBut there&#39;s a lot of repetition there just selecting the objects you wish to update.  You could update multiple values by merging an object with it with the values you want to set.\r\n\r\n    $ jq &#39;.ChangeBatch.Changes[] *= {\r\n        Action: &quot;UPSERT&quot;,\r\n        ResourceRecordSet: {\r\n            Name: &quot;host.domain&quot;,\r\n            Type: &quot;A&quot;,\r\n            ResourceRecords: [\r\n                {\r\n                    TTL: &quot;300&quot;,\r\n                    Value: &quot;10.120.0.1&quot;\r\n                }\r\n            ]\r\n        }\r\n    }&#39; x.json\r\n\r\nHowever, the way merges work, only objects are recursively merged. Arrays have to be merged manually.  So if you want to preserve the items in your array (if there&#39;s more than 1), you&#39;ll have to adjust it to this:\r\n\r\n    $ jq &#39;.ChangeBatch.Changes[] |= . * {\r\n        Action: &quot;UPSERT&quot;,\r\n        ResourceRecordSet: {\r\n            Name: &quot;host.domain&quot;,\r\n            Type: &quot;A&quot;,\r\n            ResourceRecords: .ResourceRecordSet.ResourceRecords | map(\r\n                . * {\r\n                    TTL: &quot;300&quot;,\r\n                    Value: &quot;10.120.0.1&quot;\r\n                }\r\n            )\r\n        }\r\n    }&#39; x.json\r\n\r\n",
                "title": "Updating Multiple Elements to AWS Route 53 JSON Template"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1471165803,
                "last_edit_date": 1471165803,
                "creation_date": 1471164787,
                "answer_id": 38940617,
                "question_id": 38816114,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The following reasonably concise filter should do the job in a straightforward way, thanks to the power of `|=`:\r\n\r\n```\r\n.ChangeBatch.Changes[] |=\r\n  ( .Action = &quot;UPSERT&quot;\r\n  | .ResourceRecordSet.Name = &quot;host.domain&quot;\r\n  | .ResourceRecordSet.Type = &quot;A&quot;\r\n  | .ResourceRecordSet.ResourceRecords[].TTL =&quot;300&quot;\r\n  | .ResourceRecordSet.ResourceRecords[].Value =&quot;10.120.0.1&quot;\r\n  )\r\n```",
                "title": "Updating Multiple Elements to AWS Route 53 JSON Template"
            }
        ],
        "is_answered": false,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1471165803,
        "creation_date": 1470586721,
        "last_edit_date": 1470587560,
        "question_id": 38816114,
        "body_markdown": "The following command updates 4 elements in an AWS Route 53 JSON Template by calling jq 4 times:\r\n\r\n    cat x.json | jq &#39;.ChangeBatch.Changes[].Action = &quot;UPSERT&quot;&#39;|\\\r\n    jq &#39;.ChangeBatch.Changes[].ResourceRecordSet.Name = &quot;host.domain&quot;&#39;|\\\r\n    jq &#39;.ChangeBatch.Changes[].ResourceRecordSet.Type = &quot;A&quot;&#39;|\\\r\n    jq &#39;.ChangeBatch.Changes[].ResourceRecordSet.ResourceRecords[].TTL =&quot;300&quot;&#39;\\|\r\n    jq &#39;.ChangeBatch.Changes[].ResourceRecordSet.ResourceRecords[].Value =&quot;10.120.0.1&quot;&#39;\r\n\r\nResults in the following correct output:\r\n\r\n    {\r\n      &quot;HostedZoneId&quot;: &quot;&quot;,\r\n      &quot;ChangeBatch&quot;: {\r\n      &quot;Comment&quot;: &quot;&quot;,\r\n      &quot;Changes&quot;: [\r\n      {\r\n        &quot;Action&quot;: &quot;UPSERT&quot;,\r\n        &quot;ResourceRecordSet&quot;: {\r\n          &quot;Name&quot;: &quot;host.domain&quot;,\r\n          &quot;Type&quot;: &quot;A&quot;,\r\n          &quot;SetIdentifier&quot;: &quot;&quot;,\r\n          &quot;Weight&quot;: 0,\r\n          &quot;Region&quot;: &quot;&quot;,\r\n          &quot;GeoLocation&quot;: {\r\n            &quot;ContinentCode&quot;: &quot;&quot;,\r\n            &quot;CountryCode&quot;: &quot;&quot;,\r\n            &quot;SubdivisionCode&quot;: &quot;&quot;\r\n          },\r\n          &quot;Failover&quot;: &quot;&quot;,\r\n          &quot;TTL&quot;: 0,\r\n          &quot;ResourceRecords&quot;: [\r\n            {\r\n              &quot;Value&quot;: &quot;10.120.0.1&quot;,\r\n              &quot;TTL&quot;: &quot;300&quot;\r\n            }\r\n\r\nIs there a way to update all 4 fields with a single invocation of jq?",
        "link": "https://stackoverflow.com/questions/38816114/updating-multiple-elements-to-aws-route-53-json-template",
        "title": "Updating Multiple Elements to AWS Route 53 JSON Template"
    },
    {
        "tags": [
            "json",
            "bash",
            "docker",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 221320,
                    "reputation": 6191,
                    "user_id": 479230,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://i.sstatic.net/fK2jw.jpg?s=256",
                    "display_name": "Jimmy",
                    "link": "https://stackoverflow.com/users/479230/jimmy"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1470777908,
                "post_id": 38860529,
                "comment_id": 65085332,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 221320,
                    "reputation": 6191,
                    "user_id": 479230,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://i.sstatic.net/fK2jw.jpg?s=256",
                    "display_name": "Jimmy",
                    "link": "https://stackoverflow.com/users/479230/jimmy"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1470777982,
                "post_id": 38860529,
                "comment_id": 65085363,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "reply_to_user": {
                    "account_id": 221320,
                    "reputation": 6191,
                    "user_id": 479230,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://i.sstatic.net/fK2jw.jpg?s=256",
                    "display_name": "Jimmy",
                    "link": "https://stackoverflow.com/users/479230/jimmy"
                },
                "edited": false,
                "score": 3,
                "creation_date": 1470786555,
                "post_id": 38860529,
                "comment_id": 65088058,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "reply_to_user": {
                    "account_id": 221320,
                    "reputation": 6191,
                    "user_id": 479230,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://i.sstatic.net/fK2jw.jpg?s=256",
                    "display_name": "Jimmy",
                    "link": "https://stackoverflow.com/users/479230/jimmy"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1470787912,
                "post_id": 38860529,
                "comment_id": 65088367,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "reply_to_user": {
                    "account_id": 221320,
                    "reputation": 6191,
                    "user_id": 479230,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://i.sstatic.net/fK2jw.jpg?s=256",
                    "display_name": "Jimmy",
                    "link": "https://stackoverflow.com/users/479230/jimmy"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1470790266,
                "post_id": 38860529,
                "comment_id": 65088844,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 221320,
                    "reputation": 6191,
                    "user_id": 479230,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://i.sstatic.net/fK2jw.jpg?s=256",
                    "display_name": "Jimmy",
                    "link": "https://stackoverflow.com/users/479230/jimmy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1470813876,
                "post_id": 38860529,
                "comment_id": 65096331,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "reply_to_user": {
                    "account_id": 221320,
                    "reputation": 6191,
                    "user_id": 479230,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://i.sstatic.net/fK2jw.jpg?s=256",
                    "display_name": "Jimmy",
                    "link": "https://stackoverflow.com/users/479230/jimmy"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1470840792,
                "post_id": 38860529,
                "comment_id": 65115079,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1470783721,
                "creation_date": 1470783721,
                "answer_id": 38861765,
                "question_id": 38860529,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "    JSONSTR=&quot;&quot;\r\n    declare -a JSONNAMES=()\r\n    declare -A JSONARRAY=()\r\n    LOOPNUM=0\r\n\r\n    cat ~/newfile | while IFS=: read CONTAINER CPU MEMUSE MEMPC NETIO BLKIO PIDS; do\r\n        if [[ &quot;$LOOPNUM&quot; = 0 ]]; then\r\n            JSONNAMES=(&quot;$CONTAINER&quot; &quot;$CPU&quot; &quot;$MEMUSE&quot; &quot;$MEMPC&quot; &quot;$NETIO&quot; &quot;$BLKIO&quot; &quot;$PIDS&quot;)\r\n            LOOPNUM=$(( LOOPNUM+1 ))\r\n        else\r\n            echo &quot;{ \\&quot;${JSONNAMES[0]}\\&quot;: \\&quot;${CONTAINER}\\&quot;, \\&quot;${JSONNAMES[1]}\\&quot;: \\&quot;${CPU}\\&quot;, \\&quot;${JSONNAMES[2]}\\&quot;: \\&quot;${MEMUSE}\\&quot;, \\&quot;${JSONNAMES[3]}\\&quot;: \\&quot;${MEMPC}\\&quot;, \\&quot;${JSONNAMES[4]}\\&quot;: \\&quot;${NETIO}\\&quot;, \\&quot;${JSONNAMES[5]}\\&quot;: \\&quot;${BLKIO}\\&quot;, \\&quot;${JSONNAMES[6]}\\&quot;: \\&quot;${PIDS}\\&quot; }&quot;\r\n        fi \r\n    done\r\n\r\nReturns:\r\n\r\n    { &quot;CONTAINER&quot;: &quot;nginx_container&quot;, &quot;CPU%&quot;: &quot;0.02%&quot;, &quot;MEMUSAGE/LIMIT&quot;: &quot;25.09MiB/15.26GiB&quot;, &quot;MEM%&quot;: &quot;0.16%&quot;, &quot;NETI/O&quot;: &quot;0B/0B&quot;, &quot;BLOCKI/O&quot;: &quot;22.09MB/4.096kB&quot;, &quot;PIDS&quot;: &quot;0&quot; }\r\n\r\n\r\n\r\n",
                "title": "Create JSON using jq from pipe-separated keys and values in bash"
            },
            {
                "up_vote_count": 89,
                "is_accepted": true,
                "score": 89,
                "last_activity_date": 1470840909,
                "last_edit_date": 1470840909,
                "creation_date": 1470786941,
                "answer_id": 38862221,
                "question_id": 38860529,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "### Prerequisite\r\n\r\nFor all of the below, it&#39;s assumed that your content is in a shell variable named `s`:\r\n\r\n    s=&#39;CONTAINER|CPU%|MEMUSAGE/LIMIT|MEM%|NETI/O|BLOCKI/O|PIDS\r\n    nginx_container|0.02%|25.09MiB/15.26GiB|0.16%|0B/0B|22.09MB/4.096kB|0&#39;\r\n\r\n### What (modern jq)\r\n\r\n    # thanks to @JeffMercado and @chepner for refinements, see comments\r\n    jq -Rn &#39;\r\n    ( input  | split(&quot;|&quot;) ) as $keys |\r\n    ( inputs | split(&quot;|&quot;) ) as $vals |\r\n    [[$keys, $vals] | transpose[] | {key:.[0],value:.[1]}] | from_entries\r\n    &#39; &lt;&lt;&lt;&quot;$s&quot;\r\n\r\n### How (modern jq)\r\n\r\nThis requires very new (probably 1.5?) `jq` to work, and is a dense chunk of code. To break it down:\r\n\r\n- Using `-n` prevents `jq` from reading stdin on its own, leaving the entirety of the input stream available to be read by `input` and `inputs` -- the former to read a single line, and the latter to read all remaining lines. (`-R`, for raw input, causes textual lines rather than JSON objects to be read).\r\n- With `[$keys, $vals] | transpose[]`, we&#39;re generating `[key, value]` pairs (in Python terms, zipping the two lists).\r\n- With `{key:.[0],value:.[1]}`, we&#39;re making each `[key, value]` pair into an object of the form `{&quot;key&quot;: key, &quot;value&quot;: value}`\r\n- With `from_entries`, we&#39;re combining those pairs into objects containing those keys and values.\r\n\r\n---\r\n\r\n### What (shell-assisted)\r\n\r\nThis will work with a significantly older `jq` than the above, and is an easily adopted approach for scenarios where a native-`jq` solution can be harder to wrangle:\r\n\r\n    {\r\n       IFS=&#39;|&#39; read -r -a keys # read first line into an array of strings\r\n\r\n       ## read each subsequent line into an array named &quot;values&quot;\r\n       while IFS=&#39;|&#39; read -r -a values; do\r\n\r\n        # setup: positional arguments to pass in literal variables, query with code    \r\n        jq_args=( )\r\n        jq_query=&#39;.&#39;\r\n\r\n        # copy values into the arguments, reference them from the generated code    \r\n        for idx in &quot;${!values[@]}&quot;; do\r\n            [[ ${keys[$idx]} ]] || continue # skip values with no corresponding key\r\n            jq_args+=( --arg &quot;key$idx&quot;   &quot;${keys[$idx]}&quot;   )\r\n            jq_args+=( --arg &quot;value$idx&quot; &quot;${values[$idx]}&quot; )\r\n            jq_query+=&quot; | .[\\$key${idx}]=\\$value${idx}&quot;\r\n        done\r\n\r\n        # run the generated command\r\n        jq &quot;${jq_args[@]}&quot; &quot;$jq_query&quot; &lt;&lt;&lt;&#39;{}&#39;\r\n      done\r\n    } &lt;&lt;&lt;&quot;$s&quot;\r\n\r\n\r\n\r\n---\r\n\r\n### How (shell-assisted)\r\n\r\nThe invoked `jq` command from the above is similar to:\r\n\r\n    jq --arg key0   &#39;CONTAINER&#39; \\\r\n       --arg value0 &#39;nginx_container&#39; \\\r\n       --arg key1   &#39;CPU%&#39; \\\r\n       --arg value1 &#39;0.0.2%&#39; \\\r\n       --arg key2   &#39;MEMUSAGE/LIMIT&#39; \\\r\n       --arg value2 &#39;25.09MiB/15.26GiB&#39; \\\r\n       &#39;. | .[$key0]=$value0 | .[$key1]=$value1 | .[$key2]=$value2&#39; \\\r\n       &lt;&lt;&lt;&#39;{}&#39;\r\n\r\n...passing each key and value out-of-band (such that it&#39;s treated as a literal string rather than parsed as JSON), then referring to them individually.\r\n\r\n---\r\n\r\n### Result\r\n\r\nEither of the above will emit:\r\n\r\n    {\r\n      &quot;CONTAINER&quot;: &quot;nginx_container&quot;,\r\n      &quot;CPU%&quot;: &quot;0.02%&quot;,\r\n      &quot;MEMUSAGE/LIMIT&quot;: &quot;25.09MiB/15.26GiB&quot;,\r\n      &quot;MEM%&quot;: &quot;0.16%&quot;,\r\n      &quot;NETI/O&quot;: &quot;0B/0B&quot;,\r\n      &quot;BLOCKI/O&quot;: &quot;22.09MB/4.096kB&quot;,\r\n      &quot;PIDS&quot;: &quot;0&quot;\r\n    }\r\n\r\n---\r\n\r\n### Why\r\n\r\nIn short: *Because it&#39;s guaranteed to generate valid JSON as output*.\r\n\r\nConsider the following as an example that would break more naive approaches:\r\n\r\n    s=&#39;key ending in a backslash\\\r\n    value &quot;with quotes&quot;&#39;\r\n\r\nSure, these are unexpected scenarios, but `jq` knows how to deal with them:\r\n\r\n    {\r\n      &quot;key ending in a backslash\\\\&quot;: &quot;value \\&quot;with quotes\\&quot;&quot;\r\n    }\r\n\r\n...whereas an implementation that didn&#39;t understand JSON strings could easily end up emitting:\r\n\r\n    {\r\n      &quot;key ending in a backslash\\&quot;: &quot;value &quot;with quotes&quot;&quot;\r\n    }",
                "title": "Create JSON using jq from pipe-separated keys and values in bash"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1503895703,
                "creation_date": 1503895703,
                "answer_id": 45911916,
                "question_id": 38860529,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a solution which uses the `-R` and `-s` options along with [`transpose`](https://github.com/stedolan/jq/blob/master/src/builtin.jq#L190-L197):\r\n\r\n       split(&quot;\\n&quot;)                       # [ &quot;CONTAINER...&quot;, &quot;nginx_container|0.02%...&quot;, ...]\r\n     | (.[0]    | split(&quot;|&quot;)) as $keys   # [ &quot;CONTAINER&quot;, &quot;CPU%&quot;, &quot;MEMUSAGE/LIMIT&quot;, ... ]\r\n     | (.[1:][] | split(&quot;|&quot;))            # [ &quot;nginx_container&quot;, &quot;0.02%&quot;, ... ] [ ... ] ...\r\n     | select(length &gt; 0)                # (remove empty [] caused by trailing newline)\r\n     | [$keys, .]                        # [ [&quot;CONTAINER&quot;, ...], [&quot;nginx_container&quot;, ...] ] ...\r\n     | [ transpose[] | {(.[0]):.[1]} ]   # [ {&quot;CONTAINER&quot;: &quot;nginx_container&quot;}, ... ] ...\r\n     | add                               # {&quot;CONTAINER&quot;: &quot;nginx_container&quot;, &quot;CPU%&quot;: &quot;0.02%&quot; ...",
                "title": "Create JSON using jq from pipe-separated keys and values in bash"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1533709690,
                "last_edit_date": 1533709690,
                "creation_date": 1533707325,
                "answer_id": 51739405,
                "question_id": 38860529,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`json_template=&#39;{&quot;CONTAINER&quot;:&quot;%s&quot;,&quot;CPU%&quot;:&quot;%s&quot;,&quot;MEMUSAGE/LIMIT&quot;:&quot;%s&quot;, &quot;MEM%&quot;:&quot;%s&quot;,&quot;NETI/O&quot;:&quot;%s&quot;,&quot;BLOCKI/O&quot;:&quot;%s&quot;,&quot;PIDS&quot;:&quot;%s&quot;}&#39;\r\njson_string=$(printf &quot;$json_template&quot; &quot;nginx_container&quot; &quot;0.02%&quot; &quot;25.09MiB/15.26GiB&quot; &quot;0.16%&quot; &quot;0B/0B&quot; &quot;22.09MB/4.096kB&quot; &quot;0&quot;)\r\necho &quot;$json_string&quot;`\r\n\r\nNot using jq but possible to use args and environment in values.\r\n\r\n`CONTAINER=nginx_container\r\njson_template=&#39;{&quot;CONTAINER&quot;:&quot;%s&quot;,&quot;CPU%&quot;:&quot;%s&quot;,&quot;MEMUSAGE/LIMIT&quot;:&quot;%s&quot;, &quot;MEM%&quot;:&quot;%s&quot;,&quot;NETI/O&quot;:&quot;%s&quot;,&quot;BLOCKI/O&quot;:&quot;%s&quot;,&quot;PIDS&quot;:&quot;%s&quot;}&#39;\r\njson_string=$(printf &quot;$json_template&quot; &quot;$CONTAINER&quot; &quot;$1&quot; &quot;25.09MiB/15.26GiB&quot; &quot;0.16%&quot; &quot;0B/0B&quot; &quot;22.09MB/4.096kB&quot; &quot;0&quot;)\r\necho &quot;$json_string&quot;`",
                "title": "Create JSON using jq from pipe-separated keys and values in bash"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1551293325,
                "creation_date": 1551293325,
                "answer_id": 54912511,
                "question_id": 38860529,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you&#39;re starting with tabular data, I think it makes more sense to use something  that works with tabular data natively, like [sqawk](https://github.com/dbohdan/sqawk) to make it into json, and then use jq work with it further.\r\n\r\n    echo &#39;CONTAINER|CPU%|MEMUSAGE/LIMIT|MEM%|NETI/O|BLOCKI/O|PIDS\r\n    nginx_container|0.02%|25.09MiB/15.26GiB|0.16%|0B/0B|22.09MB/4.096kB|0&#39; \\\r\n            | sqawk -FS &#39;[|]&#39; -RS &#39;\\n&#39; -output json &#39;select * from a&#39; header=1 \\\r\n            | jq &#39;.[] | with_entries(select(.key|test(&quot;^a.*&quot;)|not))&#39;\r\n\r\n        {\r\n          &quot;CONTAINER&quot;: &quot;nginx_container&quot;,\r\n          &quot;CPU%&quot;: &quot;0.02%&quot;,\r\n          &quot;MEMUSAGE/LIMIT&quot;: &quot;25.09MiB/15.26GiB&quot;,\r\n          &quot;MEM%&quot;: &quot;0.16%&quot;,\r\n          &quot;NETI/O&quot;: &quot;0B/0B&quot;,\r\n          &quot;BLOCKI/O&quot;: &quot;22.09MB/4.096kB&quot;,\r\n          &quot;PIDS&quot;: &quot;0&quot;\r\n        }\r\n\r\nWithout `jq`, `sqawk` gives a bit too much:\r\n\r\n    [\r\n      {\r\n        &quot;anr&quot;: &quot;1&quot;,\r\n        &quot;anf&quot;: &quot;7&quot;,\r\n        &quot;a0&quot;: &quot;nginx_container|0.02%|25.09MiB/15.26GiB|0.16%|0B/0B|22.09MB/4.096kB|0&quot;,\r\n        &quot;CONTAINER&quot;: &quot;nginx_container&quot;,\r\n        &quot;CPU%&quot;: &quot;0.02%&quot;,\r\n        &quot;MEMUSAGE/LIMIT&quot;: &quot;25.09MiB/15.26GiB&quot;,\r\n        &quot;MEM%&quot;: &quot;0.16%&quot;,\r\n        &quot;NETI/O&quot;: &quot;0B/0B&quot;,\r\n        &quot;BLOCKI/O&quot;: &quot;22.09MB/4.096kB&quot;,\r\n        &quot;PIDS&quot;: &quot;0&quot;,\r\n        &quot;a8&quot;: &quot;&quot;,\r\n        &quot;a9&quot;: &quot;&quot;,\r\n        &quot;a10&quot;: &quot;&quot;\r\n      }\r\n    ]\r\n",
                "title": "Create JSON using jq from pipe-separated keys and values in bash"
            },
            {
                "up_vote_count": 9,
                "is_accepted": false,
                "score": 9,
                "last_activity_date": 1551293623,
                "creation_date": 1551293623,
                "answer_id": 54912578,
                "question_id": 38860529,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can ask docker to give you JSON data in the first place\r\n\r\n    docker stats --format &quot;{{json .}}&quot;\r\n\r\nFor more on this, see: https://docs.docker.com/config/formatting/",
                "title": "Create JSON using jq from pipe-separated keys and values in bash"
            },
            {
                "up_vote_count": 20,
                "is_accepted": false,
                "score": 19,
                "last_activity_date": 1555019755,
                "creation_date": 1555019755,
                "answer_id": 55641730,
                "question_id": 38860529,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I know this is an old post, but the tool you seek is called `jo`: https://github.com/jpmens/jo\r\n\r\nA quick and easy example:\r\n\r\n    $ jo my_variable=&quot;simple&quot;\r\n    {&quot;my_variable&quot;:&quot;simple&quot;}\r\n\r\nA little more complex\r\n\r\n    $ jo -p name=jo n=17 parser=false\r\n    {\r\n      &quot;name&quot;: &quot;jo&quot;,\r\n      &quot;n&quot;: 17,\r\n      &quot;parser&quot;: false\r\n    }\r\n\r\nAdd an array\r\n\r\n    $ jo -p name=jo n=17 parser=false my_array=$(jo -a {1..5})\r\n    {\r\n      &quot;name&quot;: &quot;jo&quot;,\r\n      &quot;n&quot;: 17,\r\n      &quot;parser&quot;: false,\r\n      &quot;my_array&quot;: [\r\n        1,\r\n        2,\r\n        3,\r\n        4,\r\n        5\r\n      ]\r\n    }\r\n\r\nI&#39;ve made some pretty complex stuff with jo and the nice thing is that you don&#39;t have to worry about rolling your own solution worrying about the possiblity of making invalid json.",
                "title": "Create JSON using jq from pipe-separated keys and values in bash"
            }
        ],
        "is_answered": true,
        "answer_count": 7,
        "score": 35,
        "last_activity_date": 1555019755,
        "creation_date": 1470777192,
        "last_edit_date": 1470790373,
        "question_id": 38860529,
        "body_markdown": "I am trying to create a json object from a string in bash. The string is as follows. \r\n\r\n    CONTAINER|CPU%|MEMUSAGE/LIMIT|MEM%|NETI/O|BLOCKI/O|PIDS\r\n    nginx_container|0.02%|25.09MiB/15.26GiB|0.16%|0B/0B|22.09MB/4.096kB|0\r\n\r\nThe output is from docker stats command and my end goal is to publish custom metrics to aws cloudwatch. I would like to format this string as json. \r\n\r\n    {\r\n        &quot;CONTAINER&quot;:&quot;nginx_container&quot;,\r\n        &quot;CPU%&quot;:&quot;0.02%&quot;, \r\n        ....\r\n    }\r\n\r\nI have used jq command before and it seems like it should work well in this case but I have not been able to come up with a good solution yet. Other than hardcoding variable names and indexing using sed or awk. Then creating a json from scratch. Any suggestions would be appreciated. Thanks. ",
        "link": "https://stackoverflow.com/questions/38860529/create-json-using-jq-from-pipe-separated-keys-and-values-in-bash",
        "title": "Create JSON using jq from pipe-separated keys and values in bash"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1470795018,
                "creation_date": 1470795018,
                "answer_id": 38863165,
                "question_id": 38860798,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You almost got it.  Use this:\r\n\r\n    .a.b[] |= (.x.x1 = .y.y1)\r\n\r\nWe want to update every item in the `.a.b` array where `.x.x1` takes the value of `.y.y1`",
                "title": "Using JQ to replace a value with another value from the same dictionary"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1470795018,
        "creation_date": 1470778414,
        "question_id": 38860798,
        "body_markdown": "Given the following JSON file foo.js (stripped down for clarity):\r\n\r\n    {&quot;a&quot;:{&quot;b&quot;:[{&quot;x&quot;:{&quot;x1&quot;:1},&quot;y&quot;:{&quot;y1&quot;:5}},{&quot;x&quot;:{&quot;x1&quot;:1},&quot;y&quot;:{&quot;y1&quot;:6}}]}}\r\n\r\nI want to replace the value of x1 with the corresponding value of y1. That is, I want to end up with:\r\n\r\n    {&quot;a&quot;:{&quot;b&quot;:[{&quot;x&quot;:{&quot;x1&quot;:5},&quot;y&quot;:{&quot;y1&quot;:5}},{&quot;x&quot;:{&quot;x1&quot;:6},&quot;y&quot;:{&quot;y1&quot;:6}}]}}\r\n\r\nThis replaces the values, but returns only the modified dictionaries rather than the complete JSON file:\r\n\r\n    % jq -Mc &#39;.a.b[] | .x.x1 = .y.y1&#39; foo.js\r\n    {&quot;x&quot;:{&quot;x1&quot;:5},&quot;y&quot;:{&quot;y1&quot;:5}}\r\n    {&quot;x&quot;:{&quot;x1&quot;:6},&quot;y&quot;:{&quot;y1&quot;:6}}\r\n\r\nThis works to replace x1 with a constant value:\r\n\r\n    % jq -Mc &#39;(.a.b[] | .x.x1) |= 9&#39; foo.js\r\n    {&quot;a&quot;:{&quot;b&quot;:[{&quot;x&quot;:{&quot;x1&quot;:9},&quot;y&quot;:{&quot;y1&quot;:5}},{&quot;x&quot;:{&quot;x1&quot;:9},&quot;y&quot;:{&quot;y1&quot;:6}}]}}\r\n\r\nBut this attempt to use the same idea doesn&#39;t work:\r\n\r\n    % jq -Mc &#39;(.a.b[] | .x.x1) |= .y.y1&#39; foo.js\r\n    jq: error (at foo.js:1): Cannot index number with string &quot;y&quot;\r\n",
        "link": "https://stackoverflow.com/questions/38860798/using-jq-to-replace-a-value-with-another-value-from-the-same-dictionary",
        "title": "Using JQ to replace a value with another value from the same dictionary"
    },
    {
        "tags": [
            "awk",
            "gawk",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1471050004,
                "last_edit_date": 1471050004,
                "creation_date": 1471047722,
                "answer_id": 38928028,
                "question_id": 38926506,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The confusing thing for me was the non-ascii `—` character, but I was able to make it work in `awk` &amp; `sed` by copy/pasting the char into the following:\r\n\r\n    awk &#39;/^—/ {d=1} /^=/ {d=0; next} !d&#39;\r\n    sed &#39;/^—/,/^=/ d&#39;\r\n\r\nHere are the results:\r\n\r\n    $ awk &#39;/^—/ {d=1} /^=/ {d=0; next} !d&#39; esc.txt | jq -R . | jq -s\r\n    [\r\n      &quot;default&quot;,\r\n      &quot;dev-external&quot;,\r\n      &quot;my-sg&quot;\r\n    ]\r\n    $ sed &#39;/^—/,/^=/ d&#39; esc.txt | jq -R . | jq -s\r\n    [\r\n      &quot;default&quot;,\r\n      &quot;dev-external&quot;,\r\n      &quot;my-sg&quot;\r\n    ]\r\n\r\nIf we want to make it more obvious that we are trying to match a non-ascii character, we can leverage the feature in `awk` to match on the octal representation of the character:\r\n\r\n    $ awk &#39;/^\\342\\200\\224/ {d=1} /^=/ {d=0; next} !d&#39; esc.txt | jq -R . | jq -s\r\n    [\r\n      &quot;default&quot;,\r\n      &quot;dev-external&quot;,\r\n      &quot;my-sg&quot;\r\n    ]\r\n\r\n*(Numbers found using* `od` *and &quot;trial and error.&quot;)*\r\n\r\n",
                "title": "How do I get rid of unwanted ANSI escape characters printed when using gawk / awk and jq?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1471050065,
                "last_edit_date": 1592644375,
                "creation_date": 1471050065,
                "answer_id": 38928208,
                "question_id": 38926506,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "From the [`jq` manual page][1], one of these options seems likely to help:\n\n&gt; - --color-output / -C and --monochrome-output / -M:\n&gt; \n&gt; By default, jq outputs colored JSON if writing to a terminal. You can\n&gt; force it to produce color even if writing to a pipe or a file using\n&gt; -C, and disable color with -M.\n&gt; \n&gt; - --ascii-output / -a:\n&gt; \n&gt; jq usually outputs non-ASCII Unicode codepoints as UTF-8, even if the\n&gt; input specified them as escape sequences (like “\\u03bc”). Using this\n&gt; option, you can force jq to produce pure ASCII output with every\n&gt; non-ASCII character replaced with the equivalent escape sequence.\n\n(posted as an answer even though it&#39;s more-comment like because it&#39;s too long and would be unreadable as a comment - and it might even be right...)\n\n  [1]: https://stedolan.github.io/jq/manual/",
                "title": "How do I get rid of unwanted ANSI escape characters printed when using gawk / awk and jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1471050065,
        "creation_date": 1471036215,
        "last_edit_date": 1471043268,
        "question_id": 38926506,
        "body_markdown": "I am using jq to parse json files to text and vice versa in bash script.\r\n\r\nI have faced this problem while trying to parse a text file line by line, to make it a json object.\r\n\r\nHere is my input file :\r\n\r\n    default\r\n    ———————————\r\n    out           0-65535  0.0.0.0/0          -1  \r\n    in            80       0.0.0.0/0          tcp \r\n    in            8080     0.0.0.0/0          tcp \r\n    in            21017    192.168.1.0/32     tcp \r\n    in            2379     0.0.0.0/0          udp \r\n    in            0-65535  sg-10fa3c75        -1  \r\n    ===========\r\n    dev-external\r\n    ———————————\r\n    out           0-65535  4.1.0.0/32         -1  \r\n    in            1-2      sg-10fa3c75        -1  \r\n    in            21034    sg-10fa3c75        tcp \r\n    in            9418     24.115.129.102/32  tcp \r\n    in            80       0.0.0.0/0          tcp \r\n    in            8080     default            tcp \r\n    in            21017    192.168.1.0/0      tcp \r\n    in            123-655  1.45.9.1/32        -1  \r\n    ===========\r\n    my-sg\r\n    ———————————\r\n    out           0-65535  0.0.0.0/0          -1  \r\n    in            80       0.0.0.0/0          tcp \r\n    in            8070     0.0.0.0/0          tcp \r\n    in            8080     0.0.0.0/0          tcp \r\n    in            21017    192.168.1.0/32     tcp \r\n    in            0-65535  sg-10fa3c75        -1  \r\n    ===========\r\n\r\nI tried to parse this file using gawk:\r\n\r\n`gawk &#39;BEGIN{RS=&quot;\\n=+\\n&quot;; FS=&quot;\\n&quot;; ORS=&quot;\\n&quot;} { print $1 }&#39;`\r\n\r\n\r\nwhich returns : \r\n\r\n    default                                                                                                                                                                             \r\n    dev-external\r\n    my-sg\r\n\r\nbut when I parse this using jq :\r\n\r\n`| jq -R . | jq -s .`\r\n\r\n\r\nI have these unwanted escape characters attached. \r\n\r\n    [\r\n      &quot;\\u001b[3g\\r\\u001bH            \\u001bH            \\u001bH              \\u001bH            \\u001bH            \\u001bH            \\u001bH            \\u001bH            \\u001bH            \\u001bH            \\u001bH            \\u001bH            \\u001bH            \\u001bH            \\u001bH            \\u001bH\\rdefault&quot;,\r\n      &quot;dev-external&quot;,\r\n      &quot;my-sg&quot;\r\n    ]\r\n\r\n\r\nPlease help.\r\nThank you.",
        "link": "https://stackoverflow.com/questions/38926506/how-do-i-get-rid-of-unwanted-ansi-escape-characters-printed-when-using-gawk-aw",
        "title": "How do I get rid of unwanted ANSI escape characters printed when using gawk / awk and jq?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": -2,
                "last_activity_date": 1471192617,
                "creation_date": 1471192617,
                "answer_id": 38944292,
                "question_id": 38943819,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "    [foreach .[] as $list ({};\r\n      {\r\n        &quot;M&quot;: $list[0].M,\r\n        &quot;X&quot;: [foreach $list[] as $item ({};\r\n                {&quot;\\($item.C)&quot;: $item.R}\r\n             )]\r\n      }\r\n    )]",
                "title": "Using jq to &quot;normalize&quot; JSON"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1471193521,
                "creation_date": 1471193521,
                "answer_id": 38944420,
                "question_id": 38943819,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Set `X` to the result of mapping over the array and creating a one-element object for each entry, with `C` as the key and `R` as the value.\r\n\r\n    map({M: .[0].M, X: map({&quot;\\(.C)&quot;: .R})})",
                "title": "Using jq to &quot;normalize&quot; JSON"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1501999395,
                "creation_date": 1501999395,
                "answer_id": 45529071,
                "question_id": 38943819,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Since `map(f)` is defined as `[.[]|f]`, here is an expanded form of [Santiago](https://stackoverflow.com/users/3899165/santiago-lapresta)&#39;s solution with some additional comments:\r\n\r\n    [                             # compute result array from\r\n      .[]                         #   scaning input array\r\n    | {  M: .[0].M                #   compute M from the .M of the first element\r\n       , X: [                     #   compute X array from\r\n             .[]                  #     scanning each element&#39;s objects\r\n           | {&quot;\\(.C)&quot;:.R}         #     and constructing new {C:R} objects\r\n         ]                        \r\n      }\r\n    ]\r\n",
                "title": "Using jq to &quot;normalize&quot; JSON"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1501999395,
        "creation_date": 1471189302,
        "last_edit_date": 1471192070,
        "question_id": 38943819,
        "body_markdown": "I am trying to use jq to &quot;normalize&quot; JSON so that given the input:\r\n\r\n    [\r\n        [                                                                            \r\n          {&quot;M&quot;:6, &quot;C&quot;:66, &quot;R&quot;:0.1},      \r\n          {&quot;M&quot;:6, &quot;C&quot;:81, &quot;R&quot;:0.9}\r\n        ],\r\n        [    \r\n          {&quot;M&quot;:11, &quot;C&quot;:94, &quot;R&quot;:0.8},    \r\n          {&quot;M&quot;:11, &quot;C&quot;:55, &quot;R&quot;:0.46}     \r\n        ]\r\n        ,\r\n        ...\r\n    ]                                                                         \r\n\r\nthe output should be:\r\n\r\n    [\r\n        {\r\n            &quot;M&quot; : 6,\r\n            &quot;X&quot; : [{&quot;66&quot; : 0.1},{&quot;81&quot;: 0.9}]\r\n        },\r\n        {\r\n            &quot;M&quot; : 11,\r\n            &quot;X&quot; : [{&quot;94&quot; : 0.8},{&quot;55&quot;: 0.46}]\r\n        },\r\n        ...\r\n\r\n    ]\r\n\r\nI can extract M with ` map({M: .[0].M` but not sure how to proceed",
        "link": "https://stackoverflow.com/questions/38943819/using-jq-to-normalize-json",
        "title": "Using jq to &quot;normalize&quot; JSON"
    },
    {
        "tags": [
            "arrays",
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 9022486,
                    "reputation": 33,
                    "user_id": 6723072,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/57df8d46b97392f63c1bbd8a3eda30d3?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "bweiss",
                    "link": "https://stackoverflow.com/users/6723072/bweiss"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1471374163,
                "post_id": 38981671,
                "comment_id": 65317996,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1471375671,
                "last_edit_date": 1471375671,
                "creation_date": 1471372015,
                "answer_id": 38982011,
                "question_id": 38981671,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "To change the `columnName` field in the desired containers, you can use\r\n\r\n    jq &#39;(.sheets[] | .formulas[]? | .columnName | select(.==&quot;MONTH&quot;)) |= &quot;YEAR&quot;&#39; tmp.json\r\n\r\n(The `?` avoids an error if there is no key `formula`.)\r\n\r\nTo replace `MONTH` with `YEAR` in formula strings, replace each `formulaString` value with a possible modified string returned by `sub`.\r\n\r\n    jq &#39;(.sheets[] | .formulas[]? | .formulaString) |= sub(&quot;MONTH&quot;; &quot;YEAR&quot;)&#39; tmp.json\r\n\r\n(`sub` requires `jq` 1.5, compiled with the Oniguruma library.)\r\n\r\nTo combine these into a single `jq` filter? I&#39;m not sure yet; I have only a tenuous understanding of why either one alone works.",
                "title": "JSON: use jq to edit specific values in nested arrays"
            },
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1471374692,
                "creation_date": 1471374692,
                "answer_id": 38982730,
                "question_id": 38981671,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "It looks like you&#39;re updating more than just fields in the formulas arrays, but a little bit of everything.\r\n\r\nIf you want to indiscriminately change all occurrences of the string `&quot;MONTH&quot;` to `&quot;YEAR&quot;`, you could do this:\r\n\r\n    (.. | strings) |= sub(&quot;MONTH&quot;; &quot;YEAR&quot;)",
                "title": "JSON: use jq to edit specific values in nested arrays"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1471429930,
                "creation_date": 1471429930,
                "answer_id": 38994159,
                "question_id": 38981671,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "This may be a task for walk/1.\r\n\r\n(If your jq does not have walk/1, then you can copy its definition from https://github.com/stedolan/jq/blob/master/src/builtin.jq)\r\n\r\nFor example, if you want to change &quot;MONTH&quot; to &quot;YEAR&quot; whenever &quot;MONTH&quot; appears as the value of a key in an object, then the following would do the job:\r\n\r\n```\r\njq &#39;walk(if type == &quot;object&quot; \r\n         then with_entries(.value |= (if . == &quot;MONTH&quot; then &quot;YEAR&quot; else . end)) \r\n         else . end)&#39; input.json\r\n```\r\n\r\nEquivalently:\r\n```\r\njq &#39;walk(if type == &quot;object&quot; \r\n         then with_entries(if .value == &quot;MONTH&quot; then .value = &quot;YEAR&quot; else . end)\r\n         else . end)&#39; input.json\r\n```\r\n\r\nThese can easily be modified in accordance with similar requirements.",
                "title": "JSON: use jq to edit specific values in nested arrays"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 3,
        "last_activity_date": 1471429930,
        "creation_date": 1471370833,
        "last_edit_date": 1471371937,
        "question_id": 38981671,
        "body_markdown": "I&#39;m trying to update values within an array inside an array using the utility jq. I&#39;ve pasted the sample json below. \r\n\r\nMore specifically: Within the sheets array, and then within the formulas array, I&#39;d like to change each columnName with a value of &quot;MONTH&quot; to &quot;YEAR&quot;. I&#39;d like to do the same for within the sheets array, within the columnStyles array, change each incidence of &quot;MONTH&quot; also to &quot;YEAR&quot;\r\n\r\nThis jq filter gets me the list of columnNames.\r\n\r\n    .sheets[1] | .formulas[] | .columnName\r\n\r\nHow can I edit the entire file in place by just updating the values I want? Do I use map with if?\r\n\r\nAnd what if I wanted to edit a portion of a value? For example, in a forumlaString property, just changing the part of the string that contains MONTH but leaving the rest intact?\r\n\r\n    {\r\n      &quot;version&quot;: &quot;6.1.1&quot;,\r\n      &quot;className&quot;: &quot;xyz&quot;,\r\n      &quot;sheets&quot;: [    \r\n      {\r\n          &quot;name&quot;: &quot;Pass1&quot;,\r\n          &quot;sheetId&quot;: &quot;95e6c2cd-abbe-46c1-8012-bdf37438b9b7&quot;,\r\n          &quot;keep&quot;: true,\r\n          &quot;formulas&quot;: [\r\n            {\r\n              &quot;columnName&quot;: &quot;SAMPLE_PROVIDER&quot;,\r\n              &quot;columnId&quot;: &quot;0&quot;,\r\n              &quot;columnIndex&quot;: 0,\r\n              &quot;formulaString&quot;: &quot;\\u003dGROUPBY(#Raw!SAMPLE_PROVIDER)&quot;\r\n            },\r\n            {\r\n              &quot;columnName&quot;: &quot;MONTH&quot;,\r\n              &quot;columnId&quot;: &quot;1&quot;,\r\n              &quot;columnIndex&quot;: 1,\r\n              &quot;formulaString&quot;: &quot;\\u003dGROUPBY(#Raw!MONTH)&quot;\r\n            }\r\n          ],\r\n          &quot;columnStyles&quot;: [\r\n            {\r\n              &quot;columnId&quot;: &quot;0&quot;,\r\n              &quot;name&quot;: &quot;SAMPLE_PROVIDER&quot;,\r\n              &quot;width&quot;: 206,\r\n              &quot;thousandSeparator&quot;: true\r\n            },\r\n            {\r\n              &quot;columnId&quot;: &quot;1&quot;,\r\n              &quot;name&quot;: &quot;MONTH&quot;,\r\n              &quot;width&quot;: 100,\r\n              &quot;thousandSeparator&quot;: true\r\n            }\r\n            ],\r\n          &quot;nextColumnId&quot;: 2\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;Transform1&quot;,\r\n          &quot;sheetId&quot;: &quot;49071c1c-fa84-4ae3-92c1-b63175a6b26c&quot;,\r\n          &quot;keep&quot;: true,\r\n          &quot;formulas&quot;: [\r\n            {\r\n              &quot;columnName&quot;: &quot;SAMPLE_PROVIDER&quot;,\r\n              &quot;columnId&quot;: &quot;0&quot;,\r\n              &quot;columnIndex&quot;: 0,\r\n              &quot;formulaString&quot;: &quot;\\u003d#Pass1!SAMPLE_PROVIDER&quot;\r\n            },\r\n            {\r\n              &quot;columnName&quot;: &quot;MONTH&quot;,\r\n              &quot;columnId&quot;: &quot;1&quot;,\r\n              &quot;columnIndex&quot;: 1,\r\n              &quot;formulaString&quot;: &quot;\\u003d#Pass1!MONTH&quot;\r\n            }\r\n          ],\r\n          &quot;columnStyles&quot;: [\r\n            {\r\n              &quot;columnId&quot;: &quot;0&quot;,\r\n              &quot;name&quot;: &quot;SAMPLE_PROVIDER&quot;,\r\n              &quot;width&quot;: 179,\r\n              &quot;thousandSeparator&quot;: true\r\n            },\r\n            {\r\n              &quot;columnId&quot;: &quot;1&quot;,\r\n              &quot;name&quot;: &quot;MONTH&quot;,\r\n              &quot;width&quot;: 100,\r\n              &quot;thousandSeparator&quot;: true\r\n            }\r\n          ],\r\n          &quot;nextColumnId&quot;: 3\r\n        }\r\n      ],\r\n      &quot;advancedSchedulingInUse&quot;: true,\r\n      &quot;errorHandlingMode&quot;: &quot;IGNORE&quot;\r\n    }\r\n\r\n",
        "link": "https://stackoverflow.com/questions/38981671/json-use-jq-to-edit-specific-values-in-nested-arrays",
        "title": "JSON: use jq to edit specific values in nested arrays"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2787584,
                    "reputation": 325,
                    "user_id": 2980538,
                    "user_type": "registered",
                    "accept_rate": 38,
                    "profile_image": "https://www.gravatar.com/avatar/70b2535e89ef04897362eb9e2289e6d0?s=256&d=identicon&r=PG",
                    "display_name": "vamsi",
                    "link": "https://stackoverflow.com/users/2980538/vamsi"
                },
                "reply_to_user": {
                    "account_id": 2251762,
                    "reputation": 292345,
                    "user_id": 1983854,
                    "user_type": "registered",
                    "accept_rate": 96,
                    "profile_image": "https://i.sstatic.net/KiqLo.png?s=256",
                    "display_name": "fedorqui",
                    "link": "https://stackoverflow.com/users/1983854/fedorqui"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1471515126,
                "post_id": 39015374,
                "comment_id": 65381460,
                "content_license": "CC BY-SA 3.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": 1471521017,
                "post_id": 39015374,
                "comment_id": 65385176,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 2787584,
                    "reputation": 325,
                    "user_id": 2980538,
                    "user_type": "registered",
                    "accept_rate": 38,
                    "profile_image": "https://www.gravatar.com/avatar/70b2535e89ef04897362eb9e2289e6d0?s=256&d=identicon&r=PG",
                    "display_name": "vamsi",
                    "link": "https://stackoverflow.com/users/2980538/vamsi"
                },
                "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": 1471521766,
                "post_id": 39015374,
                "comment_id": 65385706,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 4474787,
                    "reputation": 8029,
                    "user_id": 3640161,
                    "user_type": "registered",
                    "accept_rate": 61,
                    "profile_image": "https://www.gravatar.com/avatar/065307b80129366f064b9b99811658aa?s=256&d=identicon&r=PG",
                    "display_name": "Tiago Lopo",
                    "link": "https://stackoverflow.com/users/3640161/tiago-lopo"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1471522257,
                "post_id": 39015374,
                "comment_id": 65386071,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 2787584,
                    "reputation": 325,
                    "user_id": 2980538,
                    "user_type": "registered",
                    "accept_rate": 38,
                    "profile_image": "https://www.gravatar.com/avatar/70b2535e89ef04897362eb9e2289e6d0?s=256&d=identicon&r=PG",
                    "display_name": "vamsi",
                    "link": "https://stackoverflow.com/users/2980538/vamsi"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1472019925,
                "post_id": 39015374,
                "comment_id": 65578222,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 2787584,
                    "reputation": 325,
                    "user_id": 2980538,
                    "user_type": "registered",
                    "accept_rate": 38,
                    "profile_image": "https://www.gravatar.com/avatar/70b2535e89ef04897362eb9e2289e6d0?s=256&d=identicon&r=PG",
                    "display_name": "vamsi",
                    "link": "https://stackoverflow.com/users/2980538/vamsi"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1472035057,
                "post_id": 39015374,
                "comment_id": 65587575,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1471522206,
                "last_edit_date": 1471522206,
                "creation_date": 1471516709,
                "answer_id": 39016052,
                "question_id": 39015374,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The snippet below should do what you want: \r\n\r\n    jq &#39;{\r\n    \t&quot;name&quot;: .name, \r\n    \t&quot;values&quot;: [ \r\n    \t\t{\r\n    \t\t\t&quot;field1&quot; : .values[0].field1[0], \r\n    \t\t\t&quot;field2&quot; : .values[0].field2[0],\r\n    \t\t\t&quot;New_name&quot;: .values[0].name1  \r\n    \t\t},\r\n    \t\t{\r\n    \t\t\t&quot;field1&quot; : .values[1].field1[0],\r\n    \t\t\t&quot;field2&quot; : .values[1].field2[0],\r\n    \t\t\t&quot;new_name&quot; : .values[1].name1\r\n    \t\t},\r\n    \t\t{\r\n    \t\t\t&quot;field1&quot; : .values[2].field1[0],\r\n    \t\t\t&quot;field2&quot; : .values[2].field2[0],\r\n    \t\t\t&quot;new_name&quot; : .values[2].name1\r\n    \t\t}\r\n    \t]  \r\n    }&#39; &lt; /tmp/input.json\r\n\r\n\r\n**EDIT**\r\n\r\nSince the number of objects are not fixed the snippet below will do: \r\n\r\n    jq &#39;{ \r\n            &quot;name&quot; : .name,\r\n            &quot;values&quot; : [\r\n                    .values[] as $in | \r\n                    { \r\n                            &quot;field1&quot; : $in.field1[0],\r\n                            &quot;field2&quot; : $in.field2[0],\r\n                            &quot;new_name&quot; : $in.name1 \r\n                    }\r\n            ]\r\n    \r\n    }&#39; &lt; /tmp/input.json\r\n\r\n",
                "title": "changing the json using jq in bash"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1471542874,
                "last_edit_date": 1471542874,
                "creation_date": 1471525167,
                "answer_id": 39018920,
                "question_id": 39015374,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "This should work; I&#39;m not sure if there is a way to refactor the assignments to `field1` and `field2`:\r\n\r\n    jq &#39;.values[] |= (.field1=.field1[0] | .field2=.field2[0])&#39; tmp1.json",
                "title": "changing the json using jq in bash"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1504128467,
                "creation_date": 1504128467,
                "answer_id": 45969966,
                "question_id": 39015374,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is another solution.\r\n\r\n      .values |= map({\r\n         field1:   .field1[0],\r\n         field2:   .field2[0],\r\n         new_name: .name1\r\n      })",
                "title": "changing the json using jq in bash"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 3,
        "last_activity_date": 1504128467,
        "creation_date": 1471514764,
        "last_edit_date": 1471517699,
        "question_id": 39015374,
        "body_markdown": "i have the following json\r\n\r\n    {\r\n    \t&quot;name&quot; : &quot;qwerty&quot;,\r\n    \t&quot;values&quot; :[\r\n    \t{\r\n    \t\t&quot;field1&quot; : [\r\n    \t\t\t&quot;val1&quot;\r\n    \t\t\t],\r\n    \t\t&quot;field2&quot; : [\r\n    \t\t\t&quot;val2&quot;\r\n    \t\t\t],\r\n            &quot;name1&quot; : [[&quot;a&quot;, &quot;b&quot;], [&quot;c&quot;, &quot;d&quot;]]\r\n    \t},\r\n    \t{\r\n    \t\t&quot;field1&quot; : [\r\n    \t\t\t&quot;val3&quot;\r\n    \t\t\t],\r\n    \t\t&quot;field2&quot; : [\r\n    \t\t\t&quot;val4&quot;\r\n    \t\t\t],\r\n            &quot;name1&quot; : [[&quot;a&quot;, &quot;b&quot;], [&quot;c&quot;, &quot;d&quot;]]\r\n    \t},\r\n    \t{\r\n    \t\t&quot;field1&quot; : [\r\n    \t\t\t&quot;val5&quot;\r\n    \t\t\t],\r\n    \t\t&quot;field2&quot; : [\r\n    \t\t\t&quot;val6&quot;\r\n    \t\t\t],\r\n             &quot;name1&quot; : [[&quot;a&quot;, &quot;b&quot;], [&quot;c&quot;, &quot;d&quot;]]\r\n    \t}\r\n    \t]\r\n    }\r\n\r\n\r\nI need to change the above json to the following using jq in bash\r\n\r\n    {\r\n    \t&quot;name&quot; : &quot;qwerty&quot;,\r\n    \t&quot;values&quot; :[\r\n    \t{\r\n    \t\t&quot;field1&quot; : \t&quot;val1&quot;,\r\n    \t\t&quot;field2&quot; : \t&quot;val2&quot;,\r\n            &quot;new_name&quot; : [[&quot;a&quot;, &quot;b&quot;], [&quot;c&quot;, &quot;d&quot;]]\r\n    \t},\r\n    \t{\r\n    \t\t&quot;field1&quot; : &quot;val3&quot;,\r\n    \t\t&quot;field2&quot; : &quot;val4&quot;,\r\n            &quot;new_name&quot; : [[&quot;a&quot;, &quot;b&quot;], [&quot;c&quot;, &quot;d&quot;]]\r\n    \t},\r\n    \t{\r\n    \t\t&quot;field1&quot; : &quot;val5&quot;,\r\n    \t\t&quot;field2&quot; : &quot;val6&quot;,\r\n            &quot;new_name&quot; : [[&quot;a&quot;, &quot;b&quot;], [&quot;c&quot;, &quot;d&quot;]]\r\n    \t}\r\n    \t]\r\n    \r\n    }\r\n\r\n\r\nHere i am facing the following issues :\r\n\r\nI tried parsing the inner json with tag values and replace the &#39;[&#39; &#39;]&#39; with spaces, however, when i try to put the &quot;values&quot; in a variable in the form of list, jq is prettifying and then showing each new line as a element of an array. \r\n\r\n\r\nThe number of inner jsons in the values array is not fixed. \r\n\r\nCan some one please help me with framing the jq statement to be run in bash to make the required changes.",
        "link": "https://stackoverflow.com/questions/39015374/changing-the-json-using-jq-in-bash",
        "title": "changing the json using jq in bash"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 33705,
                    "reputation": 60201,
                    "user_id": 94559,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/7501656b7213a6a9a5fbcfa0aab53857?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "user94559",
                    "link": "https://stackoverflow.com/users/94559/user94559"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1471540633,
                "post_id": 39023953,
                "comment_id": 65398753,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 5590824,
                    "reputation": 375,
                    "user_id": 4430098,
                    "user_type": "registered",
                    "accept_rate": 40,
                    "profile_image": "https://www.gravatar.com/avatar/7a3ace0d726dd8516636694d7bbec698?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Rick DeBay",
                    "link": "https://stackoverflow.com/users/4430098/rick-debay"
                },
                "reply_to_user": {
                    "account_id": 33705,
                    "reputation": 60201,
                    "user_id": 94559,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/7501656b7213a6a9a5fbcfa0aab53857?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "user94559",
                    "link": "https://stackoverflow.com/users/94559/user94559"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1471541694,
                "post_id": 39023953,
                "comment_id": 65399358,
                "content_license": "CC BY-SA 3.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": 1471541831,
                "post_id": 39023953,
                "comment_id": 65399430,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 5590824,
                    "reputation": 375,
                    "user_id": 4430098,
                    "user_type": "registered",
                    "accept_rate": 40,
                    "profile_image": "https://www.gravatar.com/avatar/7a3ace0d726dd8516636694d7bbec698?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Rick DeBay",
                    "link": "https://stackoverflow.com/users/4430098/rick-debay"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1471541841,
                "post_id": 39023953,
                "comment_id": 65399440,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 5590824,
                    "reputation": 375,
                    "user_id": 4430098,
                    "user_type": "registered",
                    "accept_rate": 40,
                    "profile_image": "https://www.gravatar.com/avatar/7a3ace0d726dd8516636694d7bbec698?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Rick DeBay",
                    "link": "https://stackoverflow.com/users/4430098/rick-debay"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1471543157,
                "post_id": 39023953,
                "comment_id": 65400150,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1666129666,
                "post_id": 39023953,
                "comment_id": 130861836,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1471541677,
                "creation_date": 1471541677,
                "answer_id": 39024299,
                "question_id": 39023953,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "There are extra spaces in this line: `&quot;asdf&quot;:   &quot;1.0&quot;,` .. I wonder if there might be an invalid character in there.",
                "title": "jq &quot;Invalid numeric literal&quot; error with valid JSON data"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1471543181,
        "creation_date": 1471540410,
        "question_id": 39023953,
        "body_markdown": "The data\r\n\r\n    {    \r\n\t  &quot;asdf&quot;:   &quot;1.0&quot;,\r\n\t  &quot;jkadfsjkl&quot;: &quot;xxx&quot;\r\n    }\r\npasses JSONLint but jqplay.org and jq v1.5 return\r\n\r\n    parse error: Invalid numeric literal at line 2, column 9",
        "link": "https://stackoverflow.com/questions/39023953/jq-invalid-numeric-literal-error-with-valid-json-data",
        "title": "jq &quot;Invalid numeric literal&quot; error with valid JSON data"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1471551067,
                "creation_date": 1471551067,
                "answer_id": 39026711,
                "question_id": 39026573,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The root object doesn&#39;t have keys `bar1` and `bar2`; those occur in the objects in the array assigned to the name `foos`. Compare your filter to\r\n\r\n    jq &#39;.foos[] | [.bar_1.baz_a, .bar_1.baz_b, .bar_2.qux_1,.bar_2.qux_2]&#39; tmp.json",
                "title": "simple jq filter has null results"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1471551067,
        "creation_date": 1471550378,
        "question_id": 39026573,
        "body_markdown": "I&#39;m using the filter \r\n\r\n    [.bar_1.baz_a, .bar_1.baz_b, .bar_2.qux_1,.bar_2.qux_2]\r\n\r\non the following JSON and it&#39;s returning four nulls instead of two lines each having four elements of nonsense data.  This is my first attempt at a filter, what concept am I not comprehending?\r\n\r\n    {\r\n      &quot;version&quot;: &quot;0.1&quot;,\r\n      &quot;foos&quot;: [\r\n        {\r\n          &quot;bar_1&quot;: {\r\n            &quot;baz_a&quot;: 673396201,\r\n            &quot;baz_b&quot;: &quot;dfgsfg&quot;\r\n          },\r\n          &quot;bar_2&quot;: {\r\n            &quot;qux_1&quot;: &quot;ghjhj&quot;,\r\n            &quot;qux_2&quot;: &quot;Q&quot;\r\n          }\r\n        },\r\n        {\r\n          &quot;bar_1&quot;: {\r\n            &quot;baz_a&quot;: 674567484,\r\n            &quot;baz_b&quot;: &quot;tyutyj&quot;\r\n          },\r\n          &quot;bar_2&quot;: {\r\n            &quot;qux_1&quot;: &quot;bnmn&quot;,\r\n            &quot;qux_2&quot;: &quot;Z&quot;\r\n          }\r\n        }\r\n      ]\r\n    }",
        "link": "https://stackoverflow.com/questions/39026573/simple-jq-filter-has-null-results",
        "title": "simple jq filter has null results"
    },
    {
        "tags": [
            "json",
            "foreach",
            "key-value",
            "jq",
            "map-function"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1471970835,
                "last_edit_date": 1471970835,
                "creation_date": 1471968932,
                "answer_id": 39106177,
                "question_id": 39105521,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The most straight-forward way to accomplish the task would probably be to use the following filter:\r\n\r\n```\r\n.dependencies |= map_values(&quot;*&quot;)\r\n| .devDependencies |= map_values(&quot;*&quot;)\r\n| .optionalDependencies |= map_values(&quot;*&quot;)\r\n```\r\n\r\nTo avoid the repetition:\r\n\r\n```\r\n(.dependencies, .devDependencies, .optionalDependencies) |= map_values(&quot;*&quot;)\r\n```\r\n  ",
                "title": "Replacing all values of multiple JSON objects with jq"
            },
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1471970506,
                "creation_date": 1471970506,
                "answer_id": 39106619,
                "question_id": 39105521,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You could update all in one fell swoop by taking advantage of the comma operator.  To update all values to `&quot;*&quot;`, you could do this:\r\n\r\n    .[&quot;dependencies&quot;, &quot;devDependencies&quot;, &quot;optionalDependencies&quot;] |= map_values(&quot;*&quot;)",
                "title": "Replacing all values of multiple JSON objects with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1471970835,
        "creation_date": 1471966956,
        "last_edit_date": 1495542782,
        "question_id": 39105521,
        "body_markdown": "I&#39;m trying to replace all values of a JSON object with `*` (asterisk character) using [jq][1].\r\n\r\nThis is my package.json file:\r\n\r\n    {\r\n      &quot;name&quot;: &quot;project&quot;,\r\n      &quot;version&quot;: &quot;0.0.1&quot;,\r\n      &quot;description&quot;: &quot;project-desc&quot;,\r\n      &quot;main&quot;: &quot;gulpfile.js&quot;,\r\n      &quot;directories&quot;: {\r\n        &quot;test&quot;: &quot;tests&quot;\r\n      },\r\n      &quot;dependencies&quot;: {\r\n        &quot;babel-polyfill&quot;: &quot;^6.7.4&quot;,\r\n        &quot;babel-preset-es2015&quot;: &quot;^6.6.0&quot;,\r\n        &quot;babel-preset-react&quot;: &quot;^6.5.0&quot;,\r\n        &quot;gulp-clean&quot;: &quot;^0.3.2&quot;,\r\n        &quot;jquery&quot;: &quot;^2.1.4&quot;,\r\n        &quot;lodash&quot;: &quot;^4.0.0&quot;,\r\n        &quot;moment&quot;: &quot;^2.13.0&quot;,\r\n        &quot;moment-timezone&quot;: &quot;^0.5.0&quot;,\r\n        &quot;radium&quot;: &quot;^0.16.2&quot;,\r\n        &quot;react&quot;: &quot;^15.1.0&quot;,\r\n        &quot;react-bootstrap-sweetalert&quot;: &quot;^1.1.10&quot;,\r\n        &quot;react-dom&quot;: &quot;^15.1.0&quot;,\r\n        &quot;react-timeago&quot;: &quot;^2.2.1&quot;,\r\n        &quot;sprintf&quot;: &quot;^0.1.5&quot;,\r\n        &quot;smoothscroll&quot;: &quot;~0.2.2&quot;\r\n      },\r\n      &quot;devDependencies&quot;: {\r\n        &quot;babel&quot;: &quot;^6.3.26&quot;,\r\n        &quot;babelify&quot;: &quot;^7.2.0&quot;,\r\n        &quot;browserify&quot;: &quot;^12.0.1&quot;,\r\n        &quot;console-stamp&quot;: &quot;^0.2.0&quot;,\r\n        &quot;estraverse-fb&quot;: &quot;^1.3.1&quot;,\r\n        &quot;gulp&quot;: &quot;^3.9.0&quot;,\r\n        &quot;gulp-concat&quot;: &quot;^2.6.0&quot;,\r\n        &quot;gulp-sass&quot;: &quot;^2.1.1&quot;,\r\n        &quot;gulp-sourcemaps&quot;: &quot;^1.6.0&quot;,\r\n        &quot;gulp-util&quot;: &quot;^3.0.7&quot;,\r\n        &quot;lodash&quot;: &quot;^4.5.1&quot;,\r\n        &quot;lodash.assign&quot;: &quot;^3.2.0&quot;,\r\n        &quot;lodash.isfunction&quot;: &quot;^3.0.8&quot;,\r\n        &quot;lodash.reduce&quot;: &quot;^4.3.0&quot;,\r\n        &quot;node-sass&quot;: &quot;^3.4.2&quot;,\r\n        &quot;react-bootstrap&quot;: &quot;^0.29.4&quot;,\r\n        &quot;react-intl&quot;: &quot;^2.1.0&quot;,\r\n        &quot;reactify&quot;: &quot;^1.1.1&quot;,\r\n        &quot;sweetalert&quot;: &quot;^1.1.3&quot;,\r\n        &quot;vinyl&quot;: &quot;^1.1.0&quot;,\r\n        &quot;vinyl-buffer&quot;: &quot;^1.0.0&quot;,\r\n        &quot;vinyl-source-stream&quot;: &quot;^1.1.0&quot;,\r\n        &quot;watchify&quot;: &quot;^3.4.0&quot;,\r\n        &quot;jsx-to-string&quot;: &quot;~0.2.11&quot;\r\n      },\r\n      &quot;optionalDependencies&quot;: {\r\n        &quot;pkg-save&quot;: &quot;~1.0.2&quot;\r\n      },\r\n      &quot;scripts&quot;: {\r\n        &quot;test&quot;: &quot;echo \\&quot;Error: no test specified\\&quot; &amp;&amp; exit 1&quot;\r\n      },\r\n      &quot;repository&quot;: {\r\n        &quot;type&quot;: &quot;git&quot;,\r\n        &quot;url&quot;: &quot;mygiturl&quot;\r\n      },\r\n      &quot;author&quot;: &quot;authorname&quot;,\r\n      &quot;license&quot;: &quot;MIT&quot;\r\n    }\r\n\r\nI want to replace all values of the `dependencies`, `devDependencies` and `optionalDependencies` objects with asterisk, like so (abbreviated example below):\r\n\r\n    ...\r\n    &quot;devDependencies&quot;: {\r\n            &quot;babel&quot;: &quot;*&quot;,\r\n            &quot;babelify&quot;: &quot;*&quot;,\r\n            &quot;browserify&quot;: &quot;*&quot;,\r\n            &quot;console-stamp&quot;: &quot;*&quot;,\r\n    ...\r\n\r\nHere&#39;s the filter I&#39;m using:  \r\n`.dependencies, .devDependencies, .optionalDependencies | .foreach .[] as $item ([]; $item = &quot;*&quot;)`  \r\nPassed in the command line as:  \r\n`cat package.json | jq &#39;.dependencies, .devDependencies, .optionalDependencies | .foreach .[] as $item ([]; $item = &quot;*&quot;)&#39;`\r\n\r\nIt&#39;s returning an error though, and not the desired result:\r\n\r\n    error: syntax error, unexpected &#39;[&#39;, expecting IDENT\r\n    .dependencies, .devDependencies, .optionalDependencies | .foreach .[] as $item ([]; $item = &quot;*&quot;)\r\n                                                                       ^\r\n    1 compile error\r\n\r\nMore than just being a syntax error, I&#39;m sure it&#39;s only manipulating the top-level items and not each key-value pair within the objects which is what I intend to do.\r\n\r\nReferences and related questions:\r\n\r\n - https://stedolan.github.io/jq/manual/#foreach\r\n - https://stedolan.github.io/jq/manual/#map(x),map_values(x)\r\n - https://stackoverflow.com/questions/39103215/cant-match-regex-with-sed\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/",
        "link": "https://stackoverflow.com/questions/39105521/replacing-all-values-of-multiple-json-objects-with-jq",
        "title": "Replacing all values of multiple JSON objects with jq"
    },
    {
        "tags": [
            "filtering",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1472141590,
                "last_edit_date": 1472141590,
                "creation_date": 1472102848,
                "answer_id": 39137295,
                "question_id": 39135954,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "`inputs` will produce a result for every input that it is fed.  You want to filter those inputs by the type so you could put your filter there:\r\n\r\n    reduce (inputs | select(.type == &quot;AUDIT_CHANNEL&quot;)) as $r ...\r\n\r\nI would write your filter like so:\r\n\r\n    reduce (inputs | select(.type == &quot;AUDIT_CHANNEL&quot;)) as $r ({};\r\n        ([\r\n            &quot;Pipeline&quot;, $r.m.&quot;topic.type&quot;,\r\n            &quot;Channel&quot;,  $r.channel,\r\n            &quot;Campaign&quot;, $r.campaign,\r\n            &quot;Cellcode&quot;, $r.cellcode,\r\n            &quot;Tracking&quot;, $r.tracking,\r\n            &quot;Template&quot;, $r.m.&quot;template.id&quot;,\r\n            &quot;Event&quot;,    $r.name,\r\n            &quot;Reason&quot;,   $r.reason\r\n        ] | join(&quot;:&quot;)) as $key\r\n        | .[$key] |= [ .[0]+1, .[1]+($r.duration|tonumber) ]\r\n    )",
                "title": "How do I filter a &#39;reduce inputs&#39; over a large stream of objects?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1472410445,
        "creation_date": 1472093409,
        "last_edit_date": 1472410445,
        "question_id": 39135954,
        "body_markdown": "I use this to accumulate a map of unique keys whose value is the aggregate count and duration totals. Currently it runs on every input via &#39;reduce inputs&#39;.\r\n\r\n    reduce inputs as $r\r\n    ({};\r\n    (&quot;Pipeline:&quot; + $r.m.&quot;topic.type&quot;) as $topic\r\n    | (&quot;Channel:&quot; + $r.channel) as $channel\r\n    | (&quot;Campaign:&quot; + $r.campaign) as $campaign\r\n    | (&quot;Cellcode:&quot; + $r.cellcode) as $cellcode\r\n    | (&quot;Tracking:&quot; + $r.tracking) as $tracking\r\n    | (&quot;Template:&quot; + $r.m.&quot;template.id&quot;) as $template\r\n    | (&quot;Event:&quot; + $r.name) as $event\r\n    | (&quot;Reason:&quot; + $r.reason) as $reason\r\n    | ($r.duration|tonumber) as $duration\r\n    | (($topic + &quot;:&quot; + $channel + &quot;:&quot; + $campaign + &quot;:&quot; + $cellcode + &quot;:&quot; + $tracking + &quot;:&quot; + $template + &quot;:&quot; + $event + &quot;:&quot; + $reason) as $key\r\n      | .[$key][0] += 1 | .[$key][1] += $duration)\r\n\r\nI cannot figure out where to put a select() filter so that I do my reduce across only those entries that pass a &#39;select($r.type == &quot;AUDIT_CHANNEL&quot;)&#39; check, in order to skip the 2 &quot;type&quot;:&quot;AUDIT_SYSTEM&quot; events in this test data:\r\n\r\n    {&quot;type&quot;:&quot;AUDIT_CHANNEL&quot;,&quot;name&quot;:&quot;DROPPED&quot;,&quot;reason&quot;:&quot;INVALID_MAIL_META_DATA&quot;,&quot;start&quot;:&quot;1472083067058&quot;,&quot;duration&quot;:&quot;91&quot;,&quot;end&quot;:&quot;1472083067149&quot;,&quot;dc&quot;:&quot;dev&quot;,&quot;pool&quot;:&quot;raptor-app&quot;,&quot;host.name&quot;:&quot;L-SEA-10002721&quot;,&quot;host.ip&quot;:&quot;10.236.67.80&quot;,&quot;rlogid&quot;:&quot;tfsqiu.dvw9%3FJ*P%40G*25671246-156befd00b2-0x293&quot;,&quot;channel&quot;:&quot;EMAIL&quot;,&quot;m&quot;:{&quot;audited&quot;:&quot;1472083067058&quot;,&quot;created&quot;:&quot;1472083066974&quot;,&quot;enabled&quot;:&quot;true&quot;,&quot;entity.common.version&quot;:&quot;1&quot;,&quot;template.id&quot;:&quot;2840df6d-d9e8-4f27-e8b5-918c122d4561&quot;,&quot;template.version&quot;:&quot;17&quot;,&quot;topic.curname&quot;:&quot;eddude-default-topic&quot;,&quot;topic.curtype&quot;:&quot;DEFAULT&quot;,&quot;topic.dc&quot;:&quot;LVS&quot;,&quot;topic.name&quot;:&quot;eddude-default-topic&quot;,&quot;topic.part&quot;:&quot;5&quot;,&quot;topic.type&quot;:&quot;DEFAULT&quot;},&quot;id&quot;:&quot;0AEC4350-1C6E2FC9B80-0156BEF9ED92-0000000000000003&quot;,&quot;campaign&quot;:&quot;999&quot;,&quot;contract&quot;:&quot;a5872a5c-8912-dd63-583f-61fa8db3efde&quot;,&quot;user&quot;:1276847275,&quot;cellcode&quot;:&quot;&quot;,&quot;age&quot;:&quot;175&quot;}\r\n\r\n    {&quot;type&quot;:&quot;AUDIT_SYSTEM&quot;,&quot;name&quot;:&quot;ROTATED&quot;,&quot;start&quot;:&quot;1472083081033&quot;,&quot;duration&quot;:&quot;0&quot;,&quot;end&quot;:&quot;1472083081033&quot;,&quot;dc&quot;:&quot;dev&quot;,&quot;pool&quot;:&quot;raptor-app&quot;,&quot;host.name&quot;:&quot;L-SEA-10002721&quot;,&quot;host.ip&quot;:&quot;10.236.67.80&quot;,&quot;rlogid&quot;:&quot;tfsqiu.dvw9%3FJ*P%40G*25671246-156befd3749-0xce&quot;}\r\n\r\n    {&quot;type&quot;:&quot;AUDIT_SYSTEM&quot;,&quot;name&quot;:&quot;ROTATED&quot;,&quot;start&quot;:&quot;1472083141034&quot;,&quot;duration&quot;:&quot;0&quot;,&quot;end&quot;:&quot;1472083141034&quot;,&quot;dc&quot;:&quot;dev&quot;,&quot;pool&quot;:&quot;raptor-app&quot;,&quot;host.name&quot;:&quot;L-SEA-10002721&quot;,&quot;host.ip&quot;:&quot;10.236.67.80&quot;,&quot;rlogid&quot;:&quot;tfsqiu.dvw9%3FJ*P%40G*25671246-156befe21aa-0xce&quot;}\r\n\r\n    {&quot;type&quot;:&quot;AUDIT_CHANNEL&quot;,&quot;name&quot;:&quot;RECEIVED&quot;,&quot;start&quot;:&quot;1472083158860&quot;,&quot;duration&quot;:&quot;109&quot;,&quot;end&quot;:&quot;1472083158969&quot;,&quot;dc&quot;:&quot;dev&quot;,&quot;pool&quot;:&quot;raptor-app&quot;,&quot;host.name&quot;:&quot;L-SEA-10002721&quot;,&quot;host.ip&quot;:&quot;10.236.67.80&quot;,&quot;rlogid&quot;:&quot;tfsqiu.dvw9%3FJ*P%40G*25671246-156befe674c-0x10f&quot;,&quot;channel&quot;:&quot;EMAIL&quot;,&quot;m&quot;:{&quot;audited&quot;:&quot;1472083158860&quot;,&quot;created&quot;:&quot;1472083158860&quot;,&quot;enabled&quot;:&quot;true&quot;,&quot;entity.common.version&quot;:&quot;1&quot;,&quot;template.id&quot;:&quot;2840df6d-d9e8-4f27-e8b5-918c122d4561&quot;,&quot;template.version&quot;:&quot;17&quot;,&quot;topic.curname&quot;:&quot;eddude-default-topic&quot;,&quot;topic.curtype&quot;:&quot;DEFAULT&quot;,&quot;topic.dc&quot;:&quot;LVS&quot;,&quot;topic.name&quot;:&quot;eddude-default-topic&quot;,&quot;topic.part&quot;:&quot;5&quot;,&quot;topic.type&quot;:&quot;DEFAULT&quot;},&quot;id&quot;:&quot;0AEC4350-1C6E2FC9B80-0156BEF9ED92-0000000000000004&quot;,&quot;campaign&quot;:&quot;999&quot;,&quot;contract&quot;:&quot;a5872a5c-8912-dd63-583f-61fa8db3efde&quot;,&quot;user&quot;:1276847275,&quot;cellcode&quot;:&quot;&quot;,&quot;age&quot;:&quot;109&quot;}\r\n\r\nI tried putting it in front of the reduce, inside the reduce, etc but I don&#39;t get the desired output which is:\r\n\r\n    {\r\n      &quot;Pipeline:DEFAULT:Channel:EMAIL:Campaign:999:Cellcode::Tracking::Template:2840df6d-d9e8-4f27-e8b5-918c122d4561:Event:DROPPED:Reason:INVALID_MAIL_META_DATA&quot;: [\r\n        1,\r\n        91\r\n      ],\r\n      &quot;Pipeline:DEFAULT:Channel:EMAIL:Campaign:999:Cellcode::Tracking::Template:2840df6d-d9e8-4f27-e8b5-918c122d4561:Event:RECEIVED:Reason:&quot;: [\r\n        1,\r\n        109\r\n      ]\r\n    }\r\n\r\nDo I have to perform filtering totally outside of the reduce run, or am I just not aware of how to do this with a single filter-and-reduce?\r\n\r\nBtw, assume this input is a giant stream of millions of records, with a few hundred unique &quot;keys&quot; that get calculated for accumulating into.",
        "link": "https://stackoverflow.com/questions/39135954/how-do-i-filter-a-reduce-inputs-over-a-large-stream-of-objects",
        "title": "How do I filter a &#39;reduce inputs&#39; over a large stream of objects?"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1841815,
                    "reputation": 21043,
                    "user_id": 1671066,
                    "user_type": "registered",
                    "accept_rate": 82,
                    "profile_image": "https://www.gravatar.com/avatar/bd4c9461f2d17a884fba66eeed20e320?s=256&d=identicon&r=PG",
                    "display_name": "Micha Wiedenmann",
                    "link": "https://stackoverflow.com/users/1671066/micha-wiedenmann"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1472110603,
                "post_id": 39139107,
                "comment_id": 65622964,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 1841815,
                    "reputation": 21043,
                    "user_id": 1671066,
                    "user_type": "registered",
                    "accept_rate": 82,
                    "profile_image": "https://www.gravatar.com/avatar/bd4c9461f2d17a884fba66eeed20e320?s=256&d=identicon&r=PG",
                    "display_name": "Micha Wiedenmann",
                    "link": "https://stackoverflow.com/users/1671066/micha-wiedenmann"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1472110668,
                "post_id": 39139107,
                "comment_id": 65623008,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 1841815,
                    "reputation": 21043,
                    "user_id": 1671066,
                    "user_type": "registered",
                    "accept_rate": 82,
                    "profile_image": "https://www.gravatar.com/avatar/bd4c9461f2d17a884fba66eeed20e320?s=256&d=identicon&r=PG",
                    "display_name": "Micha Wiedenmann",
                    "link": "https://stackoverflow.com/users/1671066/micha-wiedenmann"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1472110719,
                "post_id": 39139107,
                "comment_id": 65623048,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 121,
                "is_accepted": true,
                "score": 118,
                "last_activity_date": 1655842036,
                "last_edit_date": 1655842036,
                "creation_date": 1472111180,
                "answer_id": 39139478,
                "question_id": 39139107,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Why not something like:\r\n\r\n    echo &#39;[{\r\n        &quot;name&quot;: &quot;George&quot;,\r\n        &quot;id&quot;: 12,\r\n        &quot;email&quot;: &quot;george@domain.example&quot;\r\n    }, {\r\n        &quot;name&quot;: &quot;Jack&quot;,\r\n        &quot;id&quot;: 18,\r\n        &quot;email&quot;: &quot;jack@domain.example&quot;\r\n    }, {\r\n        &quot;name&quot;: &quot;Joe&quot;,\r\n        &quot;id&quot;: 19,\r\n        &quot;email&quot;: &quot;joe@domain.example&quot;\r\n    }]&#39; | jq -r &#39;.[] | &quot;\\(.id)\\t\\(.name)&quot;&#39;\r\n\r\nOutput\r\n\r\n    12\tGeorge\r\n    18\tJack\r\n    19\tJoe\r\n\r\n___\r\n\r\n**Edit 1 :** For fine grained formatting use tools like `awk`\r\n\r\n     echo &#39;[{\r\n        &quot;name&quot;: &quot;George&quot;,\r\n        &quot;id&quot;: 12,\r\n        &quot;email&quot;: &quot;george@domain.example&quot;\r\n    }, {\r\n        &quot;name&quot;: &quot;Jack&quot;,\r\n        &quot;id&quot;: 18,\r\n        &quot;email&quot;: &quot;jack@domain.example&quot;\r\n    }, {\r\n        &quot;name&quot;: &quot;Joe&quot;,\r\n        &quot;id&quot;: 19,\r\n        &quot;email&quot;: &quot;joe@domain.example&quot;\r\n    }]&#39; | jq -r &#39;.[] | [.id, .name] | @csv&#39; | awk -v FS=&quot;,&quot; &#39;BEGIN{print &quot;ID\\tName&quot;;print &quot;============&quot;}{printf &quot;%s\\t%s%s&quot;,$1,$2,ORS}&#39;\r\n    ID\tName\r\n    ============\r\n    12\t&quot;George&quot;\r\n    18\t&quot;Jack&quot;\r\n    19\t&quot;Joe&quot;\r\n\r\n____\r\n\r\n**Edit 2 :** In reply to\r\n\r\n&gt; There&#39;s no way I can get a variable containing an array straight\r\n&gt; from jq?\r\n\r\nWhy not?\r\n\r\nA bit involved example( in fact modified from yours ) where email is changed to an array demonstrates this\r\n\r\n    echo &#39;[{\r\n        &quot;name&quot;: &quot;George&quot;,\r\n        &quot;id&quot;: 20,\r\n        &quot;email&quot;: [ &quot;george@domain1.example&quot; , &quot;george@domain2.example&quot; ]\r\n    }, {\r\n        &quot;name&quot;: &quot;Jack&quot;,\r\n        &quot;id&quot;: 18,\r\n        &quot;email&quot;: [ &quot;jack@domain3.example&quot; , &quot;jack@domain5.example&quot; ]\r\n    }, {\r\n        &quot;name&quot;: &quot;Joe&quot;,\r\n        &quot;id&quot;: 19,\r\n        &quot;email&quot;: [ &quot;joe@domain.example&quot; ]\r\n    }]&#39; | jq -r &#39;.[] | .email&#39;\r\n\r\n**Output**\r\n\r\n    [\r\n      &quot;george@domain1.example&quot;,\r\n      &quot;george@domain2.example&quot;\r\n    ]\r\n    [\r\n      &quot;jack@domain3.example&quot;,\r\n      &quot;jack@domain5.example&quot;\r\n    ]\r\n    [\r\n      &quot;joe@domain.example&quot;\r\n    ]\r\n\r\n",
                "title": "How to format a JSON string as a table using jq?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1472126077,
                "last_edit_date": 1472126077,
                "creation_date": 1472111277,
                "answer_id": 39139507,
                "question_id": 39139107,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "If the values don&#39;t contain spaces, this might be helpful:\r\n\r\n    read -r -a data &lt;&lt;&lt;&#39;name1 value1 name2 value2&#39;\r\n    \r\n    echo &quot;name value&quot;\r\n    echo &quot;==========&quot;\r\n    \r\n    for ((i=0; i&lt;${#data[@]}; i+=2)); do\r\n      echo ${data[$i]} ${data[$((i+1))]}\r\n    done\r\n\r\n**Output**\r\n\r\n    name value\r\n    ==========\r\n    name1 value1\r\n    name2 value2",
                "title": "How to format a JSON string as a table using jq?"
            },
            {
                "up_vote_count": 205,
                "is_accepted": false,
                "score": 204,
                "last_activity_date": 1668635994,
                "last_edit_date": 1668635994,
                "creation_date": 1472125389,
                "answer_id": 39144364,
                "question_id": 39139107,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using the `@tsv` filter has much to recommend it, mainly because it handles numerous &quot;edge cases&quot; in a standard way:\r\n\r\n    .[] | [.id, .name] | @tsv\r\n\r\nAdding the headers can be done like so:\r\n\r\n    jq -r &#39;[&quot;ID&quot;,&quot;NAME&quot;], [&quot;--&quot;,&quot;------&quot;], (.[] | [.id, .name]) | @tsv&#39;\r\n\r\nThe result:\r\n\r\n    ID\tNAME\r\n    --\t------\r\n    12\tGeorge\r\n    18\tJack\r\n    19\tJoe\r\n\r\nAs pointed out by @Tobia, you might want to format the table for viewing by using `column` to post-process the result produced by jq. If you are using a bash-like shell then `column -ts $&#39;\\t&#39;` should be quite portable.\r\n\r\n## `length*&quot;-&quot;`\r\n\r\nTo automate the production of the line of dashes:\r\n\r\n    jq -r &#39;([&quot;ID&quot;,&quot;NAME&quot;] | (., map(length*&quot;-&quot;))), (.[] | [.id, .name]) | @tsv&#39;\r\n\r\n",
                "title": "How to format a JSON string as a table using jq?"
            },
            {
                "up_vote_count": 48,
                "is_accepted": false,
                "score": 48,
                "last_activity_date": 1655842074,
                "last_edit_date": 1655842074,
                "creation_date": 1551026639,
                "answer_id": 54854136,
                "question_id": 39139107,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Defining headers by hand is suboptimal! Omitting headers is also suboptimal.\r\n\r\nTL;DR\r\n\r\n### data\r\n\r\n    [{ &quot;name&quot;: &quot;George&quot;, &quot;id&quot;: 12, &quot;email&quot;: &quot;george@domain.example&quot; },\r\n    { &quot;name&quot;: &quot;Jack&quot;, &quot;id&quot;: 18, &quot;email&quot;: &quot;jack@domain.example&quot; },\r\n    { &quot;name&quot;: &quot;Joe&quot;, &quot;id&quot;: 19, &quot;email&quot;: &quot;joe@domain.example&quot; }]\r\n\r\n### script\r\n\r\n      [.[]| with_entries( .key |= ascii_downcase ) ]\r\n          |    (.[0] |keys_unsorted | @tsv)\r\n             , (.[]  |map(.) |@tsv)\r\n\r\n### how to run\r\n\r\n    $ &lt; data jq -rf script  | column -t\r\n    name    id  email\r\n    George  12  george@domain.example\r\n    Jack    18  jack@domain.example\r\n    Joe     19  joe@domain.example\r\n\r\nI found this question while summarizng some data from amazon web services. The problem I was working on, in case you want another example:\r\n\r\n    $ aws ec2 describe-spot-instance-requests | tee /tmp/ins |\r\n    \tjq  --raw-output &#39;\r\n    \t                                 # extract instances as a flat list.\r\n    \t[.SpotInstanceRequests | .[]\r\n                                         # remove unwanted data\r\n    \t| {\r\n    \t\tState,\r\n    \t\tstatusCode: .Status.Code,\r\n    \t\ttype: .LaunchSpecification.InstanceType,\r\n    \t\tblockPrice: .ActualBlockHourlyPrice,\r\n    \t\tcreated: .CreateTime,\r\n    \t\tSpotInstanceRequestId}\r\n    \t]\r\n                                            # lowercase keys\r\n                                            # (for predictable sorting, optional)\r\n    \t|  [.[]| with_entries( .key |= ascii_downcase ) ]\r\n            |    (.[0] |keys_unsorted | @tsv)               # print headers\r\n               , (.[]|.|map(.) |@tsv)                       # print table\r\n    \t&#39; | column -t\r\n\r\nOutput:\r\n\r\n    state      statuscode                   type     blockprice  created                   spotinstancerequestid\r\n    closed     instance-terminated-by-user  t3.nano  0.002000    2019-02-24T15:21:36.000Z  sir-r5bh7skq\r\n    cancelled  bad-parameters               t3.nano  0.002000    2019-02-24T14:51:47.000Z  sir-1k9s5h3m\r\n    closed     instance-terminated-by-user  t3.nano  0.002000    2019-02-24T14:55:26.000Z  sir-43x16b6n\r\n    cancelled  bad-parameters               t3.nano  0.002000    2019-02-24T14:29:23.000Z  sir-2jsh5brn\r\n    active     fulfilled                    t3.nano  0.002000    2019-02-24T15:37:26.000Z  sir-z1e9591m\r\n    cancelled  bad-parameters               t3.nano  0.002000    2019-02-24T14:33:42.000Z  sir-n7c15y5p\r\n\r\nInput:\r\n\r\n    $ cat /tmp/ins\r\n    {\r\n        &quot;SpotInstanceRequests&quot;: [\r\n            {\r\n                &quot;Status&quot;: {\r\n                    &quot;Message&quot;: &quot;2019-02-24T15:29:38+0000 : 2019-02-24T15:29:38+0000 : Spot Instance terminated due to user-initiated termination.&quot;,\r\n                    &quot;Code&quot;: &quot;instance-terminated-by-user&quot;,\r\n                    &quot;UpdateTime&quot;: &quot;2019-02-24T15:31:03.000Z&quot;\r\n                },\r\n                &quot;ActualBlockHourlyPrice&quot;: &quot;0.002000&quot;,\r\n                &quot;ValidUntil&quot;: &quot;2019-03-03T15:21:36.000Z&quot;,\r\n                &quot;InstanceInterruptionBehavior&quot;: &quot;terminate&quot;,\r\n                &quot;Tags&quot;: [],\r\n                &quot;InstanceId&quot;: &quot;i-0414083bef5e91d94&quot;,\r\n                &quot;BlockDurationMinutes&quot;: 60,\r\n                &quot;SpotInstanceRequestId&quot;: &quot;sir-r5bh7skq&quot;,\r\n                &quot;State&quot;: &quot;closed&quot;,\r\n                &quot;ProductDescription&quot;: &quot;Linux/UNIX&quot;,\r\n                &quot;LaunchedAvailabilityZone&quot;: &quot;eu-north-1a&quot;,\r\n                &quot;LaunchSpecification&quot;: {\r\n                    &quot;Placement&quot;: {\r\n                        &quot;Tenancy&quot;: &quot;default&quot;,\r\n                        &quot;AvailabilityZone&quot;: &quot;eu-north-1a&quot;\r\n                    },\r\n                    &quot;ImageId&quot;: &quot;ami-6d27a913&quot;,\r\n                    &quot;BlockDeviceMappings&quot;: [\r\n                        {\r\n                            &quot;DeviceName&quot;: &quot;/dev/sda1&quot;,\r\n                            &quot;VirtualName&quot;: &quot;root&quot;,\r\n                            &quot;NoDevice&quot;: &quot;&quot;,\r\n                            &quot;Ebs&quot;: {\r\n                                &quot;Encrypted&quot;: false,\r\n                                &quot;DeleteOnTermination&quot;: true,\r\n                                &quot;VolumeType&quot;: &quot;gp2&quot;,\r\n                                &quot;VolumeSize&quot;: 8\r\n                            }\r\n                        }\r\n                    ],\r\n                    &quot;EbsOptimized&quot;: false,\r\n                    &quot;SecurityGroups&quot;: [\r\n                        {\r\n                            &quot;GroupName&quot;: &quot;default&quot;\r\n                        }\r\n                    ],\r\n                    &quot;Monitoring&quot;: {\r\n                        &quot;Enabled&quot;: false\r\n                    },\r\n                    &quot;InstanceType&quot;: &quot;t3.nano&quot;,\r\n                    &quot;AddressingType&quot;: &quot;public&quot;,\r\n                    &quot;NetworkInterfaces&quot;: [\r\n                        {\r\n                            &quot;DeviceIndex&quot;: 0,\r\n                            &quot;Description&quot;: &quot;eth-zero&quot;,\r\n                            &quot;NetworkInterfaceId&quot;: &quot;&quot;,\r\n                            &quot;DeleteOnTermination&quot;: true,\r\n                            &quot;SubnetId&quot;: &quot;subnet-420ffc2b&quot;,\r\n                            &quot;AssociatePublicIpAddress&quot;: true\r\n                        }\r\n                    ]\r\n                },\r\n                &quot;Type&quot;: &quot;one-time&quot;,\r\n                &quot;CreateTime&quot;: &quot;2019-02-24T15:21:36.000Z&quot;,\r\n                &quot;SpotPrice&quot;: &quot;0.008000&quot;\r\n            },\r\n            {\r\n                &quot;Status&quot;: {\r\n                    &quot;Message&quot;: &quot;Your Spot request failed due to bad parameters.&quot;,\r\n                    &quot;Code&quot;: &quot;bad-parameters&quot;,\r\n                    &quot;UpdateTime&quot;: &quot;2019-02-24T14:51:48.000Z&quot;\r\n                },\r\n                &quot;ActualBlockHourlyPrice&quot;: &quot;0.002000&quot;,\r\n                &quot;ValidUntil&quot;: &quot;2019-03-03T14:51:47.000Z&quot;,\r\n                &quot;InstanceInterruptionBehavior&quot;: &quot;terminate&quot;,\r\n                &quot;Tags&quot;: [],\r\n                &quot;Fault&quot;: {\r\n                    &quot;Message&quot;: &quot;Invalid device name /dev/sda&quot;,\r\n                    &quot;Code&quot;: &quot;InvalidBlockDeviceMapping&quot;\r\n                },\r\n                &quot;BlockDurationMinutes&quot;: 60,\r\n                &quot;SpotInstanceRequestId&quot;: &quot;sir-1k9s5h3m&quot;,\r\n                &quot;State&quot;: &quot;cancelled&quot;,\r\n                &quot;ProductDescription&quot;: &quot;Linux/UNIX&quot;,\r\n                &quot;LaunchedAvailabilityZone&quot;: &quot;eu-north-1a&quot;,\r\n                &quot;LaunchSpecification&quot;: {\r\n                    &quot;Placement&quot;: {\r\n                        &quot;Tenancy&quot;: &quot;default&quot;,\r\n                        &quot;AvailabilityZone&quot;: &quot;eu-north-1a&quot;\r\n                    },\r\n                    &quot;ImageId&quot;: &quot;ami-6d27a913&quot;,\r\n                    &quot;BlockDeviceMappings&quot;: [\r\n                        {\r\n                            &quot;DeviceName&quot;: &quot;/dev/sda&quot;,\r\n                            &quot;VirtualName&quot;: &quot;root&quot;,\r\n                            &quot;NoDevice&quot;: &quot;&quot;,\r\n                            &quot;Ebs&quot;: {\r\n                                &quot;Encrypted&quot;: false,\r\n                                &quot;DeleteOnTermination&quot;: true,\r\n                                &quot;VolumeType&quot;: &quot;gp2&quot;,\r\n                                &quot;VolumeSize&quot;: 8\r\n                            }\r\n                        }\r\n                    ],\r\n                    &quot;EbsOptimized&quot;: false,\r\n                    &quot;SecurityGroups&quot;: [\r\n                        {\r\n                            &quot;GroupName&quot;: &quot;default&quot;\r\n                        }\r\n                    ],\r\n                    &quot;Monitoring&quot;: {\r\n                        &quot;Enabled&quot;: false\r\n                    },\r\n                    &quot;InstanceType&quot;: &quot;t3.nano&quot;,\r\n                    &quot;AddressingType&quot;: &quot;public&quot;,\r\n                    &quot;NetworkInterfaces&quot;: [\r\n                        {\r\n                            &quot;DeviceIndex&quot;: 0,\r\n                            &quot;Description&quot;: &quot;eth-zero&quot;,\r\n                            &quot;NetworkInterfaceId&quot;: &quot;&quot;,\r\n                            &quot;DeleteOnTermination&quot;: true,\r\n                            &quot;SubnetId&quot;: &quot;subnet-420ffc2b&quot;,\r\n                            &quot;AssociatePublicIpAddress&quot;: true\r\n                        }\r\n                    ]\r\n                },\r\n                &quot;Type&quot;: &quot;one-time&quot;,\r\n                &quot;CreateTime&quot;: &quot;2019-02-24T14:51:47.000Z&quot;,\r\n                &quot;SpotPrice&quot;: &quot;0.011600&quot;\r\n            },\r\n            {\r\n                &quot;Status&quot;: {\r\n                    &quot;Message&quot;: &quot;2019-02-24T15:02:17+0000 : 2019-02-24T15:02:17+0000 : Spot Instance terminated due to user-initiated termination.&quot;,\r\n                    &quot;Code&quot;: &quot;instance-terminated-by-user&quot;,\r\n                    &quot;UpdateTime&quot;: &quot;2019-02-24T15:03:34.000Z&quot;\r\n                },\r\n                &quot;ActualBlockHourlyPrice&quot;: &quot;0.002000&quot;,\r\n                &quot;ValidUntil&quot;: &quot;2019-03-03T14:55:26.000Z&quot;,\r\n                &quot;InstanceInterruptionBehavior&quot;: &quot;terminate&quot;,\r\n                &quot;Tags&quot;: [],\r\n                &quot;InstanceId&quot;: &quot;i-010442ac3cc85ec08&quot;,\r\n                &quot;BlockDurationMinutes&quot;: 60,\r\n                &quot;SpotInstanceRequestId&quot;: &quot;sir-43x16b6n&quot;,\r\n                &quot;State&quot;: &quot;closed&quot;,\r\n                &quot;ProductDescription&quot;: &quot;Linux/UNIX&quot;,\r\n                &quot;LaunchedAvailabilityZone&quot;: &quot;eu-north-1a&quot;,\r\n                &quot;LaunchSpecification&quot;: {\r\n                    &quot;Placement&quot;: {\r\n                        &quot;Tenancy&quot;: &quot;default&quot;,\r\n                        &quot;AvailabilityZone&quot;: &quot;eu-north-1a&quot;\r\n                    },\r\n                    &quot;ImageId&quot;: &quot;ami-6d27a913&quot;,\r\n                    &quot;BlockDeviceMappings&quot;: [\r\n                        {\r\n                            &quot;DeviceName&quot;: &quot;/dev/sda1&quot;,\r\n                            &quot;VirtualName&quot;: &quot;root&quot;,\r\n                            &quot;NoDevice&quot;: &quot;&quot;,\r\n                            &quot;Ebs&quot;: {\r\n                                &quot;Encrypted&quot;: false,\r\n                                &quot;DeleteOnTermination&quot;: true,\r\n                                &quot;VolumeType&quot;: &quot;gp2&quot;,\r\n                                &quot;VolumeSize&quot;: 8\r\n                            }\r\n                        }\r\n                    ],\r\n                    &quot;EbsOptimized&quot;: false,\r\n                    &quot;SecurityGroups&quot;: [\r\n                        {\r\n                            &quot;GroupName&quot;: &quot;default&quot;\r\n                        }\r\n                    ],\r\n                    &quot;Monitoring&quot;: {\r\n                        &quot;Enabled&quot;: false\r\n                    },\r\n                    &quot;InstanceType&quot;: &quot;t3.nano&quot;,\r\n                    &quot;AddressingType&quot;: &quot;public&quot;,\r\n                    &quot;NetworkInterfaces&quot;: [\r\n                        {\r\n                            &quot;DeviceIndex&quot;: 0,\r\n                            &quot;Description&quot;: &quot;eth-zero&quot;,\r\n                            &quot;NetworkInterfaceId&quot;: &quot;&quot;,\r\n                            &quot;DeleteOnTermination&quot;: true,\r\n                            &quot;SubnetId&quot;: &quot;subnet-420ffc2b&quot;,\r\n                            &quot;AssociatePublicIpAddress&quot;: true\r\n                        }\r\n                    ]\r\n                },\r\n                &quot;Type&quot;: &quot;one-time&quot;,\r\n                &quot;CreateTime&quot;: &quot;2019-02-24T14:55:26.000Z&quot;,\r\n                &quot;SpotPrice&quot;: &quot;0.011600&quot;\r\n            },\r\n            {\r\n                &quot;Status&quot;: {\r\n                    &quot;Message&quot;: &quot;Your Spot request failed due to bad parameters.&quot;,\r\n                    &quot;Code&quot;: &quot;bad-parameters&quot;,\r\n                    &quot;UpdateTime&quot;: &quot;2019-02-24T14:29:24.000Z&quot;\r\n                },\r\n                &quot;ActualBlockHourlyPrice&quot;: &quot;0.002000&quot;,\r\n                &quot;ValidUntil&quot;: &quot;2019-03-03T14:29:23.000Z&quot;,\r\n                &quot;InstanceInterruptionBehavior&quot;: &quot;terminate&quot;,\r\n                &quot;Tags&quot;: [],\r\n                &quot;Fault&quot;: {\r\n                    &quot;Message&quot;: &quot;Addressing type must be &#39;public&#39;&quot;,\r\n                    &quot;Code&quot;: &quot;InvalidParameterCombination&quot;\r\n                },\r\n                &quot;BlockDurationMinutes&quot;: 60,\r\n                &quot;SpotInstanceRequestId&quot;: &quot;sir-2jsh5brn&quot;,\r\n                &quot;State&quot;: &quot;cancelled&quot;,\r\n                &quot;ProductDescription&quot;: &quot;Linux/UNIX&quot;,\r\n                &quot;LaunchedAvailabilityZone&quot;: &quot;eu-north-1a&quot;,\r\n                &quot;LaunchSpecification&quot;: {\r\n                    &quot;Placement&quot;: {\r\n                        &quot;Tenancy&quot;: &quot;default&quot;,\r\n                        &quot;AvailabilityZone&quot;: &quot;eu-north-1a&quot;\r\n                    },\r\n                    &quot;ImageId&quot;: &quot;ami-6d27a913&quot;,\r\n                    &quot;BlockDeviceMappings&quot;: [\r\n                        {\r\n                            &quot;DeviceName&quot;: &quot;/dev/sda&quot;,\r\n                            &quot;VirtualName&quot;: &quot;root&quot;,\r\n                            &quot;NoDevice&quot;: &quot;&quot;,\r\n                            &quot;Ebs&quot;: {\r\n                                &quot;Encrypted&quot;: false,\r\n                                &quot;DeleteOnTermination&quot;: true,\r\n                                &quot;VolumeType&quot;: &quot;gp2&quot;,\r\n                                &quot;VolumeSize&quot;: 8\r\n                            }\r\n                        }\r\n                    ],\r\n                    &quot;EbsOptimized&quot;: false,\r\n                    &quot;SecurityGroups&quot;: [\r\n                        {\r\n                            &quot;GroupName&quot;: &quot;default&quot;\r\n                        }\r\n                    ],\r\n                    &quot;Monitoring&quot;: {\r\n                        &quot;Enabled&quot;: false\r\n                    },\r\n                    &quot;InstanceType&quot;: &quot;t3.nano&quot;,\r\n                    &quot;AddressingType&quot;: &quot;&quot;,\r\n                    &quot;NetworkInterfaces&quot;: [\r\n                        {\r\n                            &quot;DeviceIndex&quot;: 0,\r\n                            &quot;Description&quot;: &quot;eth-zero&quot;,\r\n                            &quot;NetworkInterfaceId&quot;: &quot;&quot;,\r\n                            &quot;DeleteOnTermination&quot;: true,\r\n                            &quot;SubnetId&quot;: &quot;subnet-420ffc2b&quot;,\r\n                            &quot;AssociatePublicIpAddress&quot;: true\r\n                        }\r\n                    ]\r\n                },\r\n                &quot;Type&quot;: &quot;one-time&quot;,\r\n                &quot;CreateTime&quot;: &quot;2019-02-24T14:29:23.000Z&quot;,\r\n                &quot;SpotPrice&quot;: &quot;0.011600&quot;\r\n            },\r\n            {\r\n                &quot;Status&quot;: {\r\n                    &quot;Message&quot;: &quot;Your spot request is fulfilled.&quot;,\r\n                    &quot;Code&quot;: &quot;fulfilled&quot;,\r\n                    &quot;UpdateTime&quot;: &quot;2019-02-24T15:37:28.000Z&quot;\r\n                },\r\n                &quot;ActualBlockHourlyPrice&quot;: &quot;0.002000&quot;,\r\n                &quot;ValidUntil&quot;: &quot;2019-03-03T15:37:26.000Z&quot;,\r\n                &quot;InstanceInterruptionBehavior&quot;: &quot;terminate&quot;,\r\n                &quot;Tags&quot;: [],\r\n                &quot;InstanceId&quot;: &quot;i-0a29e9de6d59d433f&quot;,\r\n                &quot;BlockDurationMinutes&quot;: 60,\r\n                &quot;SpotInstanceRequestId&quot;: &quot;sir-z1e9591m&quot;,\r\n                &quot;State&quot;: &quot;active&quot;,\r\n                &quot;ProductDescription&quot;: &quot;Linux/UNIX&quot;,\r\n                &quot;LaunchedAvailabilityZone&quot;: &quot;eu-north-1a&quot;,\r\n                &quot;LaunchSpecification&quot;: {\r\n                    &quot;Placement&quot;: {\r\n                        &quot;Tenancy&quot;: &quot;default&quot;,\r\n                        &quot;AvailabilityZone&quot;: &quot;eu-north-1a&quot;\r\n                    },\r\n                    &quot;ImageId&quot;: &quot;ami-6d27a913&quot;,\r\n                    &quot;BlockDeviceMappings&quot;: [\r\n                        {\r\n                            &quot;DeviceName&quot;: &quot;/dev/sda1&quot;,\r\n                            &quot;VirtualName&quot;: &quot;root&quot;,\r\n                            &quot;NoDevice&quot;: &quot;&quot;,\r\n                            &quot;Ebs&quot;: {\r\n                                &quot;Encrypted&quot;: false,\r\n                                &quot;DeleteOnTermination&quot;: true,\r\n                                &quot;VolumeType&quot;: &quot;gp2&quot;,\r\n                                &quot;VolumeSize&quot;: 8\r\n                            }\r\n                        }\r\n                    ],\r\n                    &quot;EbsOptimized&quot;: false,\r\n                    &quot;SecurityGroups&quot;: [\r\n                        {\r\n                            &quot;GroupName&quot;: &quot;default&quot;\r\n                        }\r\n                    ],\r\n                    &quot;Monitoring&quot;: {\r\n                        &quot;Enabled&quot;: false\r\n                    },\r\n                    &quot;InstanceType&quot;: &quot;t3.nano&quot;,\r\n                    &quot;AddressingType&quot;: &quot;public&quot;,\r\n                    &quot;NetworkInterfaces&quot;: [\r\n                        {\r\n                            &quot;DeviceIndex&quot;: 0,\r\n                            &quot;Description&quot;: &quot;eth-zero&quot;,\r\n                            &quot;NetworkInterfaceId&quot;: &quot;&quot;,\r\n                            &quot;DeleteOnTermination&quot;: true,\r\n                            &quot;SubnetId&quot;: &quot;subnet-420ffc2b&quot;,\r\n                            &quot;AssociatePublicIpAddress&quot;: true\r\n                        }\r\n                    ]\r\n                },\r\n                &quot;Type&quot;: &quot;one-time&quot;,\r\n                &quot;CreateTime&quot;: &quot;2019-02-24T15:37:26.000Z&quot;,\r\n                &quot;SpotPrice&quot;: &quot;0.008000&quot;\r\n            },\r\n            {\r\n                &quot;Status&quot;: {\r\n                    &quot;Message&quot;: &quot;Your Spot request failed due to bad parameters.&quot;,\r\n                    &quot;Code&quot;: &quot;bad-parameters&quot;,\r\n                    &quot;UpdateTime&quot;: &quot;2019-02-24T14:33:43.000Z&quot;\r\n                },\r\n                &quot;ActualBlockHourlyPrice&quot;: &quot;0.002000&quot;,\r\n                &quot;ValidUntil&quot;: &quot;2019-03-03T14:33:42.000Z&quot;,\r\n                &quot;InstanceInterruptionBehavior&quot;: &quot;terminate&quot;,\r\n                &quot;Tags&quot;: [],\r\n                &quot;Fault&quot;: {\r\n                    &quot;Message&quot;: &quot;Invalid device name /dev/sda&quot;,\r\n                    &quot;Code&quot;: &quot;InvalidBlockDeviceMapping&quot;\r\n                },\r\n                &quot;BlockDurationMinutes&quot;: 60,\r\n                &quot;SpotInstanceRequestId&quot;: &quot;sir-n7c15y5p&quot;,\r\n                &quot;State&quot;: &quot;cancelled&quot;,\r\n                &quot;ProductDescription&quot;: &quot;Linux/UNIX&quot;,\r\n                &quot;LaunchedAvailabilityZone&quot;: &quot;eu-north-1a&quot;,\r\n                &quot;LaunchSpecification&quot;: {\r\n                    &quot;Placement&quot;: {\r\n                        &quot;Tenancy&quot;: &quot;default&quot;,\r\n                        &quot;AvailabilityZone&quot;: &quot;eu-north-1a&quot;\r\n                    },\r\n                    &quot;ImageId&quot;: &quot;ami-6d27a913&quot;,\r\n                    &quot;BlockDeviceMappings&quot;: [\r\n                        {\r\n                            &quot;DeviceName&quot;: &quot;/dev/sda&quot;,\r\n                            &quot;VirtualName&quot;: &quot;root&quot;,\r\n                            &quot;NoDevice&quot;: &quot;&quot;,\r\n                            &quot;Ebs&quot;: {\r\n                                &quot;Encrypted&quot;: false,\r\n                                &quot;DeleteOnTermination&quot;: true,\r\n                                &quot;VolumeType&quot;: &quot;gp2&quot;,\r\n                                &quot;VolumeSize&quot;: 8\r\n                            }\r\n                        }\r\n                    ],\r\n                    &quot;EbsOptimized&quot;: false,\r\n                    &quot;SecurityGroups&quot;: [\r\n                        {\r\n                            &quot;GroupName&quot;: &quot;default&quot;\r\n                        }\r\n                    ],\r\n                    &quot;Monitoring&quot;: {\r\n                        &quot;Enabled&quot;: false\r\n                    },\r\n                    &quot;InstanceType&quot;: &quot;t3.nano&quot;,\r\n                    &quot;AddressingType&quot;: &quot;public&quot;,\r\n                    &quot;NetworkInterfaces&quot;: [\r\n                        {\r\n                            &quot;DeviceIndex&quot;: 0,\r\n                            &quot;Description&quot;: &quot;eth-zero&quot;,\r\n                            &quot;NetworkInterfaceId&quot;: &quot;&quot;,\r\n                            &quot;DeleteOnTermination&quot;: true,\r\n                            &quot;SubnetId&quot;: &quot;subnet-420ffc2b&quot;,\r\n                            &quot;AssociatePublicIpAddress&quot;: true\r\n                        }\r\n                    ]\r\n                },\r\n                &quot;Type&quot;: &quot;one-time&quot;,\r\n                &quot;CreateTime&quot;: &quot;2019-02-24T14:33:42.000Z&quot;,\r\n                &quot;SpotPrice&quot;: &quot;0.011600&quot;\r\n            }\r\n        ]\r\n    }\r\n\r\n",
                "title": "How to format a JSON string as a table using jq?"
            },
            {
                "up_vote_count": 24,
                "is_accepted": false,
                "score": 24,
                "last_activity_date": 1655842115,
                "last_edit_date": 1655842115,
                "creation_date": 1608099878,
                "answer_id": 65318277,
                "question_id": 39139107,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The problem with the answers above is they only work if the fields are all about the same width.\r\n\r\nTo avoid this issue, the Linux `column` command could be used:\r\n\r\n```json\r\n// input.json\r\n[\r\n  {\r\n    &quot;name&quot;: &quot;George&quot;,\r\n    &quot;id&quot;: &quot;a very very long field&quot;,\r\n    &quot;email&quot;: &quot;george@domain.example&quot;\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;Jack&quot;,\r\n    &quot;id&quot;: 18,\r\n    &quot;email&quot;: &quot;jack@domain.example&quot;\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;Joe&quot;,\r\n    &quot;id&quot;: 19,\r\n    &quot;email&quot;: &quot;joe@domain.example&quot;\r\n  }\r\n]\r\n```\r\n\r\nThen:\r\n\r\n```text\r\n▶ jq -r &#39;.[] | [.id, .name] | @tsv&#39; input.json | column -ts $&#39;\\t&#39;\r\na very very long field  George\r\n18                      Jack\r\n19                      Joe\r\n```",
                "title": "How to format a JSON string as a table using jq?"
            },
            {
                "up_vote_count": 8,
                "is_accepted": false,
                "score": 8,
                "last_activity_date": 1616748945,
                "creation_date": 1616748945,
                "answer_id": 66813728,
                "question_id": 39139107,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I made a mix with all responses to get all this behaviours\r\n- create header table\r\n- handle long fields\r\n- create a function to reuse\r\n\r\n**function bash** \r\n\r\n    function jsonArrayToTable(){\r\n         jq -r &#39;(.[0] | ([keys[] | .] |(., map(length*&quot;-&quot;)))), (.[] | ([keys[] as $k | .[$k]])) | @tsv&#39; | column -t -s $&#39;\\t&#39;   \r\n    }\r\n\r\n**Sample use**\r\n\r\n    echo &#39;[{&quot;key1&quot;:&quot;V1.1&quot;, &quot;key2&quot;:&quot;V2.1&quot;}, {&quot;keyA&quot;:&quot;V1.2&quot;, &quot;key2&quot;:&quot;V2.2&quot;}]&#39; | jsonArrayToTable\r\n\r\n**output**\r\n\r\n    key1  key2\r\n    ----  ----\r\n    V1.1  V2.1\r\n    V2.2  V1.2\r\n   ",
                "title": "How to format a JSON string as a table using jq?"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1656101947,
                "last_edit_date": 1656101947,
                "creation_date": 1626557472,
                "answer_id": 68424420,
                "question_id": 39139107,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you want to generate an *HTML* table instead of a table for terminal output:\r\n\r\n```shell\r\necho &#39;[{\r\n    &quot;name&quot;: &quot;George&quot;,\r\n    &quot;id&quot;: 12,\r\n    &quot;email&quot;: &quot;george@domain.example&quot;\r\n}, {\r\n    &quot;name&quot;: &quot;Jack&quot;,\r\n    &quot;id&quot;: 18,\r\n    &quot;email&quot;: &quot;jack@domain.example&quot;\r\n}, {\r\n    &quot;name&quot;: &quot;Joe&quot;,\r\n    &quot;id&quot;: 19,\r\n    &quot;email&quot;: &quot;joe@domain.example&quot;\r\n}]&#39; | jq -r &#39;map(&quot;&lt;tr&gt;&lt;td&gt;&quot; + .name + &quot;&lt;/td&gt;&lt;td&gt;&quot; + (.id | tostring) + &quot;&lt;/td&gt;&lt;/tr&gt;&quot;) | [&quot;&lt;table&gt;&quot;] + . + [&quot;&lt;/table&gt;&quot;] | .[]&#39;\r\n```\r\n\r\nOutput:\r\n\r\n```html\r\n&lt;table&gt;\r\n&lt;tr&gt;&lt;td&gt;George&lt;/td&gt;&lt;td&gt;12&lt;/td&gt;&lt;/tr&gt;\r\n&lt;tr&gt;&lt;td&gt;Jack&lt;/td&gt;&lt;td&gt;18&lt;/td&gt;&lt;/tr&gt;\r\n&lt;tr&gt;&lt;td&gt;Joe&lt;/td&gt;&lt;td&gt;19&lt;/td&gt;&lt;/tr&gt;\r\n&lt;/table&gt;\r\n```",
                "title": "How to format a JSON string as a table using jq?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1635426831,
                "creation_date": 1635426831,
                "answer_id": 69754759,
                "question_id": 39139107,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "More simple implement:\r\n```\r\njq -r &#39;(.[0]|keys_unsorted|(.,map(length*&quot;-&quot;))),.[]|map(.)|@tsv&#39;|column -ts $&#39;\\t&#39;\r\n```\r\nyou can add the following jq function into `~/.jq`:\r\n```\r\ndef pretty_table:\r\n (.[0]|keys_unsorted|(.,map(length*&quot;-&quot;))),.[]|map(.)|@tsv\r\n ;\r\n```\r\nand then run:\r\n```\r\ncat apps.json | jq -r pretty_table | column -ts $&#39;\\t&#39;\r\n```",
                "title": "How to format a JSON string as a table using jq?"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1694022729,
                "creation_date": 1694022729,
                "answer_id": 77054233,
                "question_id": 39139107,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Generic oneliner that works with any *JSON array of objects* (`[{..}, {..}, ...]`) on *stdin*:\r\n\r\n```\r\njq -r &#39;map( with_entries(  .value |= tostring  ) ) | (map(keys) | add | unique) as $cols | map(. as $row | $cols | map($row[.])) as $rows | $cols, $rows[] | @tsv&#39; | column -ts $&#39;\\t&#39;\r\n```\r\n\r\n(inspired by [*How to Convert from JSON to CSV at The Command Line*](https://earthly.dev/blog/convert-to-from-json/#convert-json-to-csv-via-the-command-line-using-jq)).\r\n\r\nIt is robust enough to handle the following corner cases:\r\n* array values are fine\r\n* objects with missing keys are fine\r\n* identifies all keys (== table columns) from all objects (== table rows) (no requirement for the first object to contain all keys)\r\n* keys can appear in arbitrary order within the object\r\n* handles space (e.g. strings with spaces) gracefully without incorrectly misplacing cells in the wrong column as the separator is a tab character\r\n  * therefore may need additional escaping if tab characters are part of the input\r\n\r\n## Examples:\r\nHere document:\r\n```\r\ncat &lt;&lt;&#39;EOF&#39; | jq -r &#39;map( with_entries(  .value |= tostring  ) ) | (map(keys) | add | unique) as $cols | map(. as $row | $cols | map($row[.])) as $rows | $cols, $rows[] | @tsv&#39; | column -ts $&#39;\\t&#39;\r\n[\r\n  { &quot;id&quot;: 12, &quot;email&quot;: &quot;george@domain.example&quot; },\r\n  { &quot;fullname&quot;: &quot;Jack Foo&quot;, &quot;id&quot;: 18, &quot;email&quot;: &quot;jack@domain.example&quot; },\r\n  { &quot;fullname&quot;: &quot;Joe Bar Baz&quot;, &quot;email&quot;: &quot;joe@domain.example&quot;, &quot;list&quot;: [554, &quot;hello world&quot;, &quot;another string&quot;] },\r\n  { &quot;list&quot;: [], &quot;id&quot;: 949, &quot;fullname&quot;: &quot;&quot; },\r\n  { &quot;zzz&quot;: 35.4 }\r\n]\r\nEOF\r\n\r\n## output:\r\n# email                  fullname     id   list                                  zzz\r\n# george@domain.example               12                                         \r\n# jack@domain.example    Jack Foo     18                                         \r\n# joe@domain.example     Joe Bar Baz       [554,&quot;hello world&quot;,&quot;another string&quot;]  \r\n#                                     949  []                                    \r\n#                                                                                35.4\r\n```\r\n\r\n`ip route` (leveraging the `-j` JSON format option):\r\n```\r\nip -j route | jq -r &#39;map( with_entries(  .value |= tostring  ) ) | (map(keys) | add | unique) as $cols | map(. as $row | $cols | map($row[.])) as $rows | $cols, $rows[] | @tsv&#39; | column -ts $&#39;\\t&#39;\r\n\r\n## sample output:\r\n# dev     dst          flags  gateway   metric  prefsrc    protocol  scope\r\n# enp0s3  default      []     10.0.2.2  1024    10.0.2.15  dhcp      \r\n# enp0s3  10.0.2.0/24  []                       10.0.2.15  kernel    link\r\n# enp0s3  10.0.2.2     []               1024    10.0.2.15  dhcp      link\r\n# lxcbr0  10.0.3.0/24  []                       10.0.3.1   kernel    link\r\n```\r\n",
                "title": "How to format a JSON string as a table using jq?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1731464898,
                "creation_date": 1731464898,
                "answer_id": 79183228,
                "question_id": 39139107,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s an extension of [Abdul&#39;s answer](https://stackoverflow.com/a/77054233/2613780) that also adds a line of dashed separators to help guide the eye for column widths. It was much more complicated to write than I expected, but that&#39;s why it was fun (? &#129396;).\r\n\r\nSaved into `table.jq`:\r\n\r\n```jq\r\n# Convert a list of similar objects into a table of values\r\n# Modified from: https://stackoverflow.com/a/77054233/2613780\r\n# Example usage:\r\n#   jq --raw-output --from-file table.jq &lt;&lt;&lt; &#39;[ {&quot;a&quot;: &quot;able&quot;}, {&quot;b&quot;: &quot;bacon&quot;}, {&quot;c&quot;: &quot;cradle&quot;} ]&#39; | column -ts $&#39;\\t&#39;\r\n\r\n# Convert all values to strings\r\nmap( map_values(tostring) )\r\n# Get column headings\r\n| ( map(keys) | add | unique ) as $column_titles\r\n# Create an object from column_titles where all values are set to null\r\n| ( reduce $column_titles[] as $title ({}; . + {$title: null}) ) as $null_object\r\n# Add all &quot;columns&quot; to all objects (the order is important, we want any actual values to override nulls)\r\n| map($null_object + .)\r\n# Create column separators\r\n| (\r\n  # Add an object with the column headings as values\r\n  . + [reduce $column_titles[] as $column ({}; . + {$column: $column})]\r\n  # Sort all object keys alphabetically\r\n  | map(to_entries | sort_by(.key) | from_entries)\r\n  # Create a row of dashes matched to max column widths\r\n  | ( map(map(length)) | transpose | map(max * &quot;-&quot;) )\r\n) as $seps\r\n# Convert all values to table rows\r\n| map(. as $row | $column_titles | map($row[.])) as $rows\r\n# Output table\r\n| $column_titles, $seps, $rows[]\r\n| @tsv\r\n```\r\n\r\nAlso here in [this GitHub Gust](https://gist.github.com/ElectricWarr/d753d36b7b840cdc5d117b3dbd50127f).\r\n\r\nThis is too long for a &quot;one-liner&quot; now but I enjoyed working on it. It&#39;s probably a little inefficient (I just love using variables) so I&#39;d love to hear some feedback - it seems like it works roughly on O(n) time as far as I can tell!\r\n\r\nAdding `| column -ts $&#39;\\t&#39;` to the end of every usage is annoying enough that I&#39;ve made a whole script just to use it called `json-list-to-table` you can also find in the Gist above.\r\n\r\nTested with a few &quot;interesting&quot; cases:\r\n\r\n 1. The example above:\r\n\r\n    ```shell\r\n    jq --raw-output --from-file table.jq &lt;&lt;&lt; &#39;[ {&quot;a&quot;: &quot;able&quot;}, {&quot;b&quot;: &quot;bacon&quot;}, {&quot;c&quot;: &quot;cradle&quot;} ]&#39; | column -ts $&#39;\\t&#39;\r\n    ```\r\n\r\n 2. Using the reqres.in test API:\r\n\r\n    ```shell\r\n    curl https://reqres.in/api/users?per_page=12 | jq &#39;.data&#39; | jq --raw-output --from-file table.jq | column -ts $&#39;\\t&#39;\r\n    ```\r\n\r\n 3. A bunch of image layers from the DockerHub API:\r\n\r\n    ```shell\r\n    curl --location --silent --show-error &quot;https://registry.hub.docker.com/v2/namespaces/library/repositories/python/tags&quot; | jq &#39;[.results[].images[]]&#39; | jq --raw-output --from-file table.jq | column -ts $&#39;\\t&#39;\r\n    ```",
                "title": "How to format a JSON string as a table using jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 10,
        "score": 161,
        "last_activity_date": 1731464898,
        "creation_date": 1472109899,
        "last_edit_date": 1655842000,
        "question_id": 39139107,
        "body_markdown": "Just started out with Bash scripting and stumbled upon jq to work with JSON.\r\n\r\nI need to transform a JSON string like below to a table for output in the terminal.\r\n\r\n    [{\r\n        &quot;name&quot;: &quot;George&quot;,\r\n        &quot;id&quot;: 12,\r\n        &quot;email&quot;: &quot;george@domain.example&quot;\r\n    }, {\r\n        &quot;name&quot;: &quot;Jack&quot;,\r\n        &quot;id&quot;: 18,\r\n        &quot;email&quot;: &quot;jack@domain.example&quot;\r\n    }, {\r\n        &quot;name&quot;: &quot;Joe&quot;,\r\n        &quot;id&quot;: 19,\r\n        &quot;email&quot;: &quot;joe@domain.example&quot;\r\n    }]\r\n\r\nWhat I want to display in the terminal:\r\n\r\n    ID        Name\r\n    =================\r\n    12        George\r\n    18        Jack\r\n    19        Joe\r\n\r\nNotice how I don&#39;t want to display the email property for each row, so the jq command should involve some filtering. The following gives me a plain list of names and id&#39;s:\r\n\r\n    list=$(echo &quot;$data&quot; | jq -r &#39;.[] | .name, .id&#39;)\r\n    printf &quot;$list&quot;\r\n\r\nThe problem with that is, I cannot display it like a table. I know jq has some formatting options, but not nearly as good as the options I have when using `printf`. I think I want to get these values in an array which I can then loop through myself to do the formatting...? The things I tried give me varying results, but never what I really want.\r\n\r\nCan someone point me in the right direction?",
        "link": "https://stackoverflow.com/questions/39139107/how-to-format-a-json-string-as-a-table-using-jq",
        "title": "How to format a JSON string as a table using jq?"
    },
    {
        "tags": [
            "arrays",
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 24,
                "is_accepted": true,
                "score": 24,
                "last_activity_date": 1683630082,
                "last_edit_date": 1683630082,
                "creation_date": 1472468978,
                "answer_id": 39204803,
                "question_id": 39204158,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It seems to me that you want to output the two values (`VolumeId` and `Tags[].Value`) on the same line?\r\n\r\nIf that&#39;s the case, then a simple string concatenation should be enough: \r\n\r\n    $ jq -r &#39;.Volumes[] | .VolumeId + &quot; &quot; + .Tags[].Value&#39; volumes.json\r\n    vol-00112233 vol-rescue-system\r\n    vol-00112234 vol-rescue-swap\r\n    vol-00112235 vol-rescue-storage\r\n\r\nThe above can then be used in a pipeline with `while-read`:\r\n\r\n    jq -r &#39;.Volumes[] | .VolumeId + &quot; &quot; + .Tags[].Value&#39; volumes.json \\\r\n    | while read -r volumeId tagValue; do\r\n      other_command &quot;$volumeId&quot; &quot;$tagValue&quot;\r\n    done\r\n\r\nYou should note that if there is more than one element in `Tags` the result will reflect that. This can however be avoided by referring the first element in `Tags`: `.Tags[0].Value`",
                "title": "Loop through json using jq to get multiple value"
            },
            {
                "up_vote_count": 9,
                "is_accepted": false,
                "score": 9,
                "last_activity_date": 1472488008,
                "last_edit_date": 1472488008,
                "creation_date": 1472482396,
                "answer_id": 39209215,
                "question_id": 39204158,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "As @andlrc observed, you may need to decide what you really want in the event that any Tags array has more or less than one element.  Assuming you want `Tags[0]` in all cases, I would recommend considering the use of @tsv as follows:\r\n\r\n    jq -r &#39;.Volumes[] | [.VolumeId, .Tags[0].Value] | @tsv&#39; volumes.json\r\n\r\nThis would be especially appropriate if any of the `.VolumeId` or `.Tags[0].Value` values contained spaces, tabs, newlines, etc.  The point is that @tsv will handle these in a standard way, so that handling the pair of values can be done in a standard way as well.  E.g. using awk, you could read in the pair with `awk -F\\\\t`; using bash, `IFS=$&#39;\\t&#39;`, etc.",
                "title": "Loop through json using jq to get multiple value"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1475240366,
                "last_edit_date": 1475240366,
                "creation_date": 1472504238,
                "answer_id": 39215082,
                "question_id": 39204158,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "I know the question is about how to get the information using `jq` but its also possible to directly get the expected parameter directly from aws cli using the `--query` flag.\r\n\r\n    aws ec2 describe-volumes --query &quot;Volumes[].[VolumeId, Tags[].Value]&quot; --output text\r\n",
                "title": "Loop through json using jq to get multiple value"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 13,
        "last_activity_date": 1683630082,
        "creation_date": 1472466981,
        "last_edit_date": 1476461612,
        "question_id": 39204158,
        "body_markdown": "Here is volumes.json :\r\n\r\n    {\r\n    &quot;Volumes&quot;: [\r\n        {\r\n            &quot;AvailabilityZone&quot;: &quot;us-east-1a&quot;,\r\n            &quot;Tags&quot;: [\r\n                {\r\n                    &quot;Value&quot;: &quot;vol-rescue-system&quot;,\r\n                    &quot;Key&quot;: &quot;Name&quot;\r\n                }\r\n            ],\r\n            &quot;VolumeId&quot;: &quot;vol-00112233&quot;,\r\n        },\r\n        {\r\n            &quot;AvailabilityZone&quot;: &quot;us-east-1a&quot;,\r\n            &quot;Tags&quot;: [\r\n                {\r\n                    &quot;Value&quot;: &quot;vol-rescue-swap&quot;,\r\n                    &quot;Key&quot;: &quot;Name&quot;\r\n                }\r\n            ],\r\n            &quot;VolumeId&quot;: &quot;vol-00112234&quot;,\r\n        },\r\n        {\r\n            &quot;AvailabilityZone&quot;: &quot;us-east-1a&quot;,\r\n            &quot;Tags&quot;: [\r\n                {\r\n                    &quot;Value&quot;: &quot;vol-rescue-storage&quot;,\r\n                    &quot;Key&quot;: &quot;Name&quot;\r\n                }\r\n            ],\r\n            &quot;VolumeId&quot;: &quot;vol-00112235&quot;,\r\n        }\r\n    ]\r\n    }\r\n\r\n\r\nI need to get both the value of `VolumeId` and `Tags.Value` to be used as the input to invoke another command. It is easy to get a single value from the json array, but I am not able to extract **multiple value** from it and pass it to another bash command. \r\n\r\nI can get a single value using this:\r\n\r\n    cat volumes.json |jq -r &#39;.Volumes[].VolumeId&#39; |while read v; do another_bash_command $v; done\r\n\r\nbut I am not able to get multiple value cause this is wrong:\r\n\r\n     cat volumes.json |jq -r &#39;.Volumes[].VolumeId, .Volumes[].Tags[].Value&#39; |while read v w; do another_bash_command $v $w; done\r\n\r\nas it will then loop 6 times of the outcome instead of 3.\r\n\r\n**And**, how do I pass those multiple json value in the loop to a bash array so I can use the value in a better way ? Like `VolumeId-&gt; $arr[0][0]`, `Tags.Value-&gt; $arr[0][1]`, `AvailabilityZone-&gt; $arr[0][2]`...etc.  I have searched through SO and the jq docs, and tried `readarray`, but still not able to find out the solution :( Thanks for any help given. \r\n",
        "link": "https://stackoverflow.com/questions/39204158/loop-through-json-using-jq-to-get-multiple-value",
        "title": "Loop through json using jq to get multiple value"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 176,
                "is_accepted": true,
                "score": 176,
                "last_activity_date": 1540475078,
                "last_edit_date": 1540475078,
                "creation_date": 1472563337,
                "answer_id": 39228718,
                "question_id": 39228500,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you just want to extract the `name` fields, the command you&#39;re looking for is `jq &#39;.example.&quot;sub-example&quot; | .[] | .name&#39;`. If you want to keep the names in an array, wrap the whole `jq` expression in square brackets.",
                "title": "Extract a specific field from JSON output using jq"
            },
            {
                "up_vote_count": 53,
                "is_accepted": false,
                "score": 53,
                "last_activity_date": 1675288722,
                "last_edit_date": 1675288722,
                "creation_date": 1472569740,
                "answer_id": 39231150,
                "question_id": 39228500,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using jq 1.3 (and later), you can use the filter to extract the values:\r\n\r\n    .example[&quot;sub-example&quot;] | .[] | .name\r\n\r\nOr more compactly:\r\n\r\n    .example[&quot;sub-example&quot;][].name\r\n\r\nThese of course also work with later versions of jq as well.\r\n\r\n## Reading into shell variables\r\nRather than populating separate shell variables (which would require knowing in advance how many values there are), consider populating a shell array.  For example, using a bash shell with `mapfile` (aka `readarray`):\r\n```\r\nmapfile -t ary &lt; &lt;(&lt; json_file jq &#39;.example.&quot;sub-example&quot;[].name&#39;)\r\n```\r\n\r\nYou could alternatively use a shell `while` loop. Etc etc. There are many SO Qs on this topic.\r\n\r\n",
                "title": "Extract a specific field from JSON output using jq"
            },
            {
                "up_vote_count": 10,
                "is_accepted": false,
                "score": 10,
                "last_activity_date": 1573510905,
                "creation_date": 1573510905,
                "answer_id": 58809456,
                "question_id": 39228500,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It&#39;s been a few years and I recently had to do this myself so thought I should post another way here. \r\n\r\nYou can also use `map()` to extract specific fields. e.g.\r\n```\r\n.example.&quot;sub-example&quot;|map(.name)\r\n```\r\nRef: https://jqplay.org/s/N6TboUkELM",
                "title": "Extract a specific field from JSON output using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 155,
        "last_activity_date": 1675288722,
        "creation_date": 1472562791,
        "last_edit_date": 1525709428,
        "question_id": 39228500,
        "body_markdown": "I have a JSON output as follows:\r\n\r\n    {\r\n      &quot;example&quot;: {\r\n        &quot;sub-example&quot;: [\r\n          {\r\n            &quot;name&quot;: &quot;123-345&quot;,\r\n            &quot;tag&quot; : 100\r\n          },\r\n          {\r\n            &quot;name&quot;: &quot;234-456&quot;,\r\n            &quot;tag&quot; : 100\r\n          },\r\n          {\r\n            &quot;name&quot;: &quot;4a7-a07a5&quot;,\r\n            &quot;tag&quot; : 100\r\n          }\r\n        ]\r\n      }\r\n    }\r\n\r\nI want to extract the values of the three &quot;name&quot; fields and store it in three variables.\r\n\r\nI tried `cat json_file | jq &#39;.[&quot;example.sub-example.name&quot;]&#39;` to extract the value of the &quot;name&quot; field but that doesn&#39;t work.\r\n\r\nCan anyone tell me how to achieve this using jq (or some other method)?",
        "link": "https://stackoverflow.com/questions/39228500/extract-a-specific-field-from-json-output-using-jq",
        "title": "Extract a specific field from JSON output using jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1524543341,
                "last_edit_date": 1524543341,
                "creation_date": 1472579745,
                "answer_id": 39234104,
                "question_id": 39232060,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "(1) The vanilla filter you would use would be as follows:\r\n\r\n    jq -r -c &#39;.results[0].data[].row&#39;\r\n\r\n(2) One way to use the streaming parser here would be to use it to process the output of `.results[0].data`, but the combination of the two steps will probably be slower than the vanilla approach. \r\n\r\n(3) To produce the output you want, you could run:\r\n\r\n    jq -nc --stream &#39;\r\n      fromstream(inputs\r\n        | select( [.[0][0,2,4]] == [&quot;results&quot;, &quot;data&quot;, &quot;row&quot;])\r\n        | del(.[0][0:5]) )&#39;\r\n\r\n\r\n(4) Alternatively, you may wish to try something along these lines:\r\n\r\n    jq -nc --stream &#39;inputs\r\n          | select(length==2)\r\n          | select( [.[0][0,2,4]] == [&quot;results&quot;, &quot;data&quot;, &quot;row&quot;])\r\n          | [ .[0][6], .[1]] &#39;\r\n\r\nFor the illustrative input, the output from the last invocation would be:\r\n\r\n```\r\n[&quot;key1&quot;,&quot;row1&quot;]\r\n[&quot;key2&quot;,&quot;row1&quot;]\r\n[&quot;key1&quot;,&quot;row2&quot;]\r\n[&quot;key2&quot;,&quot;row2&quot;]\r\n```",
                "title": "Process large JSON stream with jq"
            },
            {
                "up_vote_count": 10,
                "is_accepted": false,
                "score": 10,
                "last_activity_date": 1572021188,
                "last_edit_date": 1572021188,
                "creation_date": 1518609095,
                "answer_id": 48786559,
                "question_id": 39232060,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To get:\r\n\r\n```\r\n{&quot;key1&quot;: &quot;row1&quot;, &quot;key2&quot;: &quot;row1&quot;}\r\n{&quot;key1&quot;: &quot;row2&quot;, &quot;key2&quot;: &quot;row2&quot;}\r\n```\r\n\r\nFrom:\r\n\r\n```\r\n{\r\n  &quot;results&quot;:[\r\n    {\r\n      &quot;columns&quot;: [&quot;n&quot;],\r\n      &quot;data&quot;: [    \r\n        {&quot;row&quot;: [{&quot;key1&quot;: &quot;row1&quot;, &quot;key2&quot;: &quot;row1&quot;}], &quot;meta&quot;: [{&quot;key&quot;: &quot;value&quot;}]},\r\n        {&quot;row&quot;: [{&quot;key1&quot;: &quot;row2&quot;, &quot;key2&quot;: &quot;row2&quot;}], &quot;meta&quot;: [{&quot;key&quot;: &quot;value&quot;}]}\r\n      ]\r\n    }\r\n  ],\r\n  &quot;errors&quot;: []\r\n}\r\n```\r\n\r\nDo the following, which is equivalent to `jq -c &#39;.results[].data[].row[]&#39;`, but using streaming:\r\n\r\n```\r\njq -cn --stream &#39;fromstream(1|truncate_stream(inputs | select(.[0][0] == &quot;results&quot; and .[0][2] == &quot;data&quot; and .[0][4] == &quot;row&quot;) | del(.[0][0:5])))&#39;\r\n```\r\n\r\nWhat this does is:\r\n\r\n* Turn the JSON into a stream (with `--stream`)\r\n* Select the path `.results[].data[].row[]` (with `select(.[0][0] == &quot;results&quot; and .[0][2] == &quot;data&quot; and .[0][4] == &quot;row&quot;`)\r\n* Discard those initial parts of the path, like `&quot;results&quot;,0,&quot;data&quot;,0,&quot;row&quot;` (with `del(.[0][0:5])`)\r\n* And finally turn the resulting jq stream back into the expected JSON with the `fromstream(1|truncate_stream(…))` pattern from the [jq FAQ](https://github.com/stedolan/jq/wiki/FAQ#streaming-json-parser)\r\n\r\nFor example:\r\n\r\n```\r\necho &#39;\r\n  {\r\n    &quot;results&quot;:[\r\n      {\r\n        &quot;columns&quot;: [&quot;n&quot;],\r\n        &quot;data&quot;: [    \r\n          {&quot;row&quot;: [{&quot;key1&quot;: &quot;row1&quot;, &quot;key2&quot;: &quot;row1&quot;}], &quot;meta&quot;: [{&quot;key&quot;: &quot;value&quot;}]},\r\n          {&quot;row&quot;: [{&quot;key1&quot;: &quot;row2&quot;, &quot;key2&quot;: &quot;row2&quot;}], &quot;meta&quot;: [{&quot;key&quot;: &quot;value&quot;}]}\r\n        ]\r\n      }\r\n    ],\r\n    &quot;errors&quot;: []\r\n  }\r\n&#39; | jq -cn --stream &#39;\r\n  fromstream(1|truncate_stream(\r\n    inputs | select(\r\n      .[0][0] == &quot;results&quot; and \r\n      .[0][2] == &quot;data&quot; and \r\n      .[0][4] == &quot;row&quot;\r\n    ) | del(.[0][0:5])\r\n  ))&#39;\r\n```\r\n\r\nProduces the desired output.",
                "title": "Process large JSON stream with jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1670599601,
                "last_edit_date": 1670599601,
                "creation_date": 1665810524,
                "answer_id": 74076846,
                "question_id": 39232060,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Thanks to the &quot;[JSON Machine&quot;][1] library, there&#39;s a simple and relatively fast solution to the original problem that avoids the disadvantages (*) of jq&#39;s streaming parser (jq --stream), though it does entail installing more software.\r\n\r\nTo make it trivial to use, I wrote a script named `jm` (which can be found [here][2]).  With this script, one has only to write:\r\n```\r\ncurl ... | jm --pointer /results/0/data\r\n```\r\n\r\nOr, if you want to stream the .data from all objects in the .results array:\r\n```\r\ncurl ... | jm --pointer /results/-/data\r\n```\r\n\r\n---\r\n\r\n(*) The main disadvantages being slowness and obscurity.\r\n\r\n  [1]: https://github.com/halaxa/json-machine\r\n  [2]: https://github.com/pkoppstein/jm\r\n",
                "title": "Process large JSON stream with jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1715507896,
                "creation_date": 1715507896,
                "answer_id": 78467404,
                "question_id": 39232060,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "**jq streaming** is critical when dealing with a huge array as input (via file or standard input) or when performance is critical.\r\n\r\nA simplification while using jq streams is to recreate each individual object and apply the vanilla implementation (when performnce is not so relevant - e.g.: small streamed objects).\r\n\r\nThe vanilla solution pointed out by [@peak](https://stackoverflow.com/users/997358/peak):\r\n```sh\r\necho &#39;{...}&#39; | jq -r -c &#39;.results[0].data[].row&#39;\r\n```\r\n*Note: This also works with indenpendent streammed objects (not in an array)*\r\n\r\nUsing jq streams &amp; recreating the object (independent streamed objects)\r\n```sh\r\necho &#39;{...}&#39; | jq --stream -nc &#39;fromstream(0|truncate_stream(inputs))|.results[0].data[].row&#39;\r\n```\r\n\r\nUsing jq streams &amp; recreating the object (streamed objects in a huge array)\r\n```sh\r\necho &#39;[{...}]&#39; | jq --stream -nc &#39;fromstream(1|truncate_stream(inputs))|.results[0].data[].row&#39;\r\n```",
                "title": "Process large JSON stream with jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1742316711,
                "creation_date": 1742316711,
                "answer_id": 79518164,
                "question_id": 39232060,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I believe that you need to use no buffer `-N` or `--no-buffer` in curl for this.\r\n\r\n```\r\ncurl -N XYZ | jq -r -c &#39;.results[0].data[0].row[]&#39;\r\n```",
                "title": "Process large JSON stream with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 5,
        "score": 13,
        "last_activity_date": 1742316711,
        "creation_date": 1472572287,
        "last_edit_date": 1472598891,
        "question_id": 39232060,
        "body_markdown": "I get a very large JSON stream (several GB) from `curl` and try to process it with `jq`.\r\n\r\nThe relevant output I want to parse with `jq` is packed in a document representing the result structure:\r\n\r\n\r\n    {\r\n      &quot;results&quot;:[\r\n        {\r\n          &quot;columns&quot;: [&quot;n&quot;],\r\n         \r\n          // get this\r\n          &quot;data&quot;: [    \r\n            {&quot;row&quot;: [{&quot;key1&quot;: &quot;row1&quot;, &quot;key2&quot;: &quot;row1&quot;}], &quot;meta&quot;: [{&quot;key&quot;: &quot;value&quot;}]},\r\n            {&quot;row&quot;: [{&quot;key1&quot;: &quot;row2&quot;, &quot;key2&quot;: &quot;row2&quot;}], &quot;meta&quot;: [{&quot;key&quot;: &quot;value&quot;}]}\r\n          //  ... millions of rows      \r\n          \r\n          ]\r\n        }\r\n      ],\r\n      &quot;errors&quot;: []\r\n    }\r\n\r\n\r\nI want to extract the `row` data with `jq`. This is simple:\r\n\r\n    curl XYZ | jq -r -c &#39;.results[0].data[0].row[]&#39;\r\n\r\nResult:\r\n\r\n    {&quot;key1&quot;: &quot;row1&quot;, &quot;key2&quot;: &quot;row1&quot;}\r\n    {&quot;key1&quot;: &quot;row2&quot;, &quot;key2&quot;: &quot;row2&quot;}\r\n\r\nHowever, this always waits until `curl` is completed.\r\n\r\nI played with the `--stream` option which is made for dealing with this. I tried the following command but is also waits until the full object is returned from `curl`:\r\n\r\n    curl XYZ | jq -n --stream &#39;fromstream(1|truncate_stream(inputs)) | .[].data[].row[]&#39;\r\n\r\nIs there a way to &#39;jump&#39; to the `data` field and start parsing `row` one by one without waiting for closing tags?",
        "link": "https://stackoverflow.com/questions/39232060/process-large-json-stream-with-jq",
        "title": "Process large JSON stream with jq"
    },
    {
        "tags": [
            "json",
            "sed",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1472654269,
                "last_edit_date": 1472654269,
                "creation_date": 1472625750,
                "answer_id": 39242461,
                "question_id": 39236501,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "If your input is always that regular:\r\n\r\n    $ awk &#39;{ORS=(/},|\\]/?RS:&quot;&quot;); gsub(/[[:blank:]]+/,&quot;&quot;); sub(/}$/,&quot;},&quot;)}1&#39; file\r\n    [{&quot;server&quot;:&quot;servename1&quot;,&quot;i.p&quot;:127.0.0.1,&quot;domain&quot;:&quot;generic&quot;,&quot;OS&quot;:&quot;RHEL&quot;,&quot;Version&quot;:7.0},\r\n    {&quot;server&quot;:&quot;servename2&quot;,&quot;i.p&quot;:127.0.0.1,&quot;domain&quot;:&quot;generic&quot;,&quot;OS&quot;:&quot;RHEL&quot;,&quot;Version&quot;:7.0},\r\n    {&quot;server&quot;:&quot;servename3&quot;,&quot;i.p&quot;:127.0.0.1,&quot;domain&quot;:&quot;generic&quot;,&quot;OS&quot;:&quot;RHEL&quot;,&quot;Version&quot;:7.0},]\r\n\r\nIf that doesn&#39;t work for your real input then edit your question to include more truly representative sample input.\r\n\r\nTo skip the `[` and `]` lines:\r\n\r\n    $ awk &#39;!/^[][]/{ORS=(/},/?RS:&quot;&quot;); gsub(/[[:blank:]]+/,&quot;&quot;); sub(/}$/,&quot;},\\n&quot;); print}&#39; file\r\n    {&quot;server&quot;:&quot;servename1&quot;,&quot;i.p&quot;:127.0.0.1,&quot;domain&quot;:&quot;generic&quot;,&quot;OS&quot;:&quot;RHEL&quot;,&quot;Version&quot;:7.0},\r\n    {&quot;server&quot;:&quot;servename2&quot;,&quot;i.p&quot;:127.0.0.1,&quot;domain&quot;:&quot;generic&quot;,&quot;OS&quot;:&quot;RHEL&quot;,&quot;Version&quot;:7.0},\r\n    {&quot;server&quot;:&quot;servename3&quot;,&quot;i.p&quot;:127.0.0.1,&quot;domain&quot;:&quot;generic&quot;,&quot;OS&quot;:&quot;RHEL&quot;,&quot;Version&quot;:7.0},\r\n\r\n",
                "title": "Parsing JSON &quot;Pretty&quot; format to one liner"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1472626405,
                "creation_date": 1472626405,
                "answer_id": 39242668,
                "question_id": 39236501,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You can try this in jq if you&#39;re OK with newline-delimited JSON:\r\n\r\n    $ jq -c &quot;.[]&quot; test.json\r\n    {&quot;server&quot;:&quot;servename1&quot;,&quot;i.p&quot;:&quot;127.0.0.1&quot;,&quot;domain&quot;:&quot;generic&quot;,&quot;OS&quot;:&quot;RHEL&quot;,&quot;Version&quot;:7}\r\n    {&quot;server&quot;:&quot;servename2&quot;,&quot;i.p&quot;:&quot;127.0.0.1&quot;,&quot;domain&quot;:&quot;generic&quot;,&quot;OS&quot;:&quot;RHEL&quot;,&quot;Version&quot;:7}\r\n    {&quot;server&quot;:&quot;servename3&quot;,&quot;i.p&quot;:&quot;127.0.0.1&quot;,&quot;domain&quot;:&quot;generic&quot;,&quot;OS&quot;:&quot;RHEL&quot;,&quot;Version&quot;:7}\r\n\r\nNote that I had to quote the IP addresses from your sample, since the JSON you posted is not valid JSON.\r\n",
                "title": "Parsing JSON &quot;Pretty&quot; format to one liner"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1472654269,
        "creation_date": 1472588700,
        "last_edit_date": 1472626115,
        "question_id": 39236501,
        "body_markdown": "I run a command on one of my systems and it spits out JSON &quot;pretty&quot; format like so:\r\n\r\n\r\n\r\n    [\r\n        {\r\n            &quot;server&quot;: &quot;servename1&quot;,\r\n            &quot;i.p&quot;: 127.0.0.1,\r\n            &quot;domain&quot;: &quot;generic&quot;,\r\n            &quot;OS&quot;: &quot;RHEL&quot;,\r\n            &quot;Version&quot;: 7.0\r\n        },\r\n        {\r\n            &quot;server&quot;: &quot;servename2&quot;,\r\n            &quot;i.p&quot;: 127.0.0.1,\r\n            &quot;domain&quot;: &quot;generic&quot;,\r\n            &quot;OS&quot;: &quot;RHEL&quot;,\r\n            &quot;Version&quot;: 7.0\r\n       },\r\n        {\r\n            &quot;server&quot;: &quot;servename3&quot;,\r\n            &quot;i.p&quot;: 127.0.0.1,\r\n            &quot;domain&quot;: &quot;generic&quot;,\r\n            &quot;OS&quot;: &quot;RHEL&quot;,\r\n            &quot;Version&quot;: 7.0\r\n        }\r\n    ]\r\n\r\nI need to parse these paragraphs in one liners like so:\r\n\r\n    [{&quot;server&quot;:&quot;servename1&quot;,&quot;i.p&quot;:127.0.0.1,&quot;domain&quot;:&quot;generic&quot;,&quot;OS&quot;:&quot;RHEL&quot;,&quot;Version&quot;:7.0},\r\n    {&quot;server&quot;:&quot;servename2&quot;,&quot;i.p&quot;:127.0.0.1,&quot;domain&quot;:&quot;generic&quot;,&quot;OS&quot;:&quot;RHEL&quot;,&quot;Version&quot;:7.0},\r\n    {&quot;server&quot;:&quot;servename3&quot;,&quot;i.p&quot;:127.0.0.1,&quot;domain&quot;:&quot;generic&quot;,&quot;OS&quot;:&quot;RHEL&quot;,&quot;Version&quot;:7.0},]\r\n\r\nWhat is the easiest way to do this? I am tried using SED and JQ but couldn&#39;t get it.\r\n",
        "link": "https://stackoverflow.com/questions/39236501/parsing-json-pretty-format-to-one-liner",
        "title": "Parsing JSON &quot;Pretty&quot; format to one liner"
    },
    {
        "tags": [
            "stream",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1472698441,
                "creation_date": 1472698441,
                "answer_id": 39261983,
                "question_id": 39261762,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "If your goal is just to count the number of objects in the file full of lists, you could do this:\r\n\r\n    $ jq -n &#39;reduce inputs as $i (0; . + ($i | length))&#39; file.nsj",
                "title": "How do I invoke --stream in the middle of a jq query?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1502000405,
                "creation_date": 1502000405,
                "answer_id": 45529185,
                "question_id": 39261762,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here&#39;s a variation of [Jeff](https://stackoverflow.com/users/390278/jeff-mercado)&#39;s solution which uses `-n`, **inputs** and **length** and **add**.\r\n    \r\n    jq -n &#39;[ inputs | length ] | add&#39;  file.nsj",
                "title": "How do I invoke --stream in the middle of a jq query?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1502000405,
        "creation_date": 1472696568,
        "last_edit_date": 1473269068,
        "question_id": 39261762,
        "body_markdown": "I have a file of newline-separated JSON lists, the total of which I would like to count. I can do this with two invocations of jq as such:\r\n\r\n    cat file.nsj | jq -s &quot;.[] | length&quot; | jq -s &quot;add&quot;\r\n\r\nBut I would prefer to do it in a single jq invocation. Is this possible?",
        "link": "https://stackoverflow.com/questions/39261762/how-do-i-invoke-stream-in-the-middle-of-a-jq-query",
        "title": "How do I invoke --stream in the middle of a jq query?"
    },
    {
        "tags": [
            "json",
            "shell",
            "command-line",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1472785266,
                "last_edit_date": 1472785266,
                "creation_date": 1472761087,
                "answer_id": 39280234,
                "question_id": 39269967,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You can use `to_entries` to convert an object to an array of key/value pairs of properties/values.  You could then group those pairs to construct your result.\r\n\r\n    [..|.vhosts?|..|.postgresql?|objects|to_entries[]]\r\n        | reduce group_by(.key)[] as $g ({};\r\n            .[$g[0].key] = [$g[].value]\r\n        )\r\n\r\nThis yields the following result:\r\n\r\n    {\r\n      &quot;bdd1&quot;: [\r\n        {\r\n          &quot;db_aaa&quot;: {\r\n            &quot;user_aaa&quot;: { &quot;password&quot;: &quot;xxx&quot; }\r\n          }\r\n        },\r\n        {\r\n          &quot;db_ccc&quot;: {\r\n            &quot;user_ccc&quot;: { &quot;password&quot;: &quot;xxx&quot; }\r\n          }\r\n        },\r\n        {\r\n          &quot;db_bbb&quot;: {\r\n            &quot;user_bbb&quot;: { &quot;password&quot;: &quot;xxx&quot; },\r\n            &quot;user_bbb_ro&quot;: { &quot;password&quot;: &quot;xxx&quot; }\r\n          }\r\n        }\r\n      ],\r\n      &quot;bdd2&quot;: [\r\n        {\r\n          &quot;db_aaa&quot;: {\r\n            &quot;user_aaa&quot;: { &quot;password&quot;: &quot;xxx&quot; }\r\n          }\r\n        }\r\n      ]\r\n    }\r\n\r\n",
                "title": "How to select and merge objects data with jq?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1472795530,
                "creation_date": 1472795530,
                "answer_id": 39285164,
                "question_id": 39269967,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "It might be safer (i.e. more robust) to avoid using `..`.  If the data is structured as you have indicated, then the following filter would be appropriate to perform the &quot;select&quot; part of your task:\r\n\r\n    to_entries[] | .value.vhosts\r\n    | to_entries[] | .value.postgresql // empty\r\n\r\nYou could then use this along the lines Jeff suggested:\r\n\r\n````\r\n[to_entries[] | .value.vhosts\r\n | to_entries[] | .value.postgresql // empty\r\n | to_entries[]]\r\n| group_by(.key)\r\n| reduce .[] as $g ({}; .[$g[0].key] = [$g[].value] )\r\n````\r\n\r\n",
                "title": "How to select and merge objects data with jq?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1504139794,
                "creation_date": 1504139794,
                "answer_id": 45971574,
                "question_id": 39269967,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is another solution which [reduce](https://stedolan.github.io/jq/manual/#Reduce)s [Sylvain](https://stackoverflow.com/users/6782760/sylvain)&#39;s filter using [* object multiplication](https://stedolan.github.io/jq/manual/#Multiplication,division,modulo:*,/,and%)\r\n\r\n    reduce ((..|.vhosts?|..|.postgresql?)|objects) as $i({}; . *= $i)\r\n\r\nwith the sample data it produces\r\n\r\n    {\r\n      &quot;bdd1&quot;: {\r\n        &quot;db_aaa&quot;: {\r\n          &quot;user_aaa&quot;: {\r\n            &quot;password&quot;: &quot;xxx&quot;\r\n          }\r\n        },\r\n        &quot;db_bbb&quot;: {\r\n          &quot;user_bbb&quot;: {\r\n            &quot;password&quot;: &quot;xxx&quot;\r\n          },\r\n          &quot;user_bbb_ro&quot;: {\r\n            &quot;password&quot;: &quot;xxx&quot;\r\n          }\r\n        },\r\n        &quot;db_ccc&quot;: {\r\n          &quot;user_ccc&quot;: {\r\n            &quot;password&quot;: &quot;xxx&quot;\r\n          }\r\n        }\r\n      },\r\n      &quot;bdd2&quot;: {\r\n        &quot;db_aaa&quot;: {\r\n          &quot;user_aaa&quot;: {\r\n            &quot;password&quot;: &quot;xxx&quot;\r\n          }\r\n        }\r\n      }\r\n    }",
                "title": "How to select and merge objects data with jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1504139794,
        "creation_date": 1472728218,
        "question_id": 39269967,
        "body_markdown": "After some hours playing with jq, I need your help for selecting and merging objects.\r\n\r\nI have this kind of JSON :\r\n\r\n    {\r\n        &quot;cluster-1&quot;: {\r\n            &quot;vhosts&quot;: {\r\n                &quot;vhost_aaa&quot;: {\r\n                    &quot;postgresql&quot;: {\r\n                        &quot;bdd1&quot;: {\r\n                            &quot;db_aaa&quot;: {\r\n                                &quot;user_aaa&quot;: {\r\n                                    &quot;password&quot;: &quot;xxx&quot;\r\n                                }\r\n                            }\r\n                        },\r\n                        &quot;bdd2&quot;: {\r\n                            &quot;db_aaa&quot;: {\r\n                                &quot;user_aaa&quot;: {\r\n                                    &quot;password&quot;: &quot;xxx&quot;\r\n                                }\r\n                            }\r\n                        }\r\n                    }\r\n                }\r\n            }\r\n        },\r\n        &quot;cluster-2&quot;: {\r\n            &quot;vhosts&quot;: {\r\n                &quot;vhost_bbb&quot;: {\r\n                    &quot;postgresql&quot;: {\r\n                        &quot;bdd1&quot;: {\r\n                            &quot;db_bbb&quot;: {\r\n                                &quot;user_bbb&quot;: {\r\n                                    &quot;password&quot;: &quot;xxx&quot;\r\n                                },\r\n                                &quot;user_bbb_ro&quot;: {\r\n                                    &quot;password&quot;: &quot;xxx&quot;\r\n                                }\r\n                            }\r\n                        }\r\n                    }\r\n                },\r\n                &quot;vhost_ccc&quot;: {\r\n                    &quot;postgresql&quot;: {\r\n                        &quot;bdd1&quot;: {\r\n                            &quot;db_ccc&quot;: {\r\n                                &quot;user_ccc&quot;: {\r\n                                    &quot;password&quot;: &quot;xxx&quot;\r\n                                }\r\n                            }\r\n                        }\r\n                    }\r\n                }\r\n            }\r\n        }\r\n    }\r\n\r\nThis is a deep JSON which tell me that, on *cluster-x* there is vhosts (*vhosts_xxx*) which may use a kind of database (here *postgresql*) which is hosted by a server (here *bdd1* or *bdd2*) which contains databases (*db_xxx*) where i want to create specified users (*user_xxx*)  with credentials details. Ouf !\r\n\r\nMy goal is to select part of data to make specific actions, so for databases servers, I want all actions to do on the same server so this is what I try to generate with jq :\r\n\r\n    &quot;bdd1&quot;: {\r\n        &quot;db_aaa&quot;: {\r\n            &quot;user_aaa&quot;: {\r\n                &quot;password&quot;: &quot;xxx&quot;\r\n            }\r\n        },\r\n        &quot;db_bbb&quot;: {\r\n            &quot;user_bbb&quot;: {\r\n                &quot;password&quot;: &quot;xxx&quot;\r\n            },\r\n            &quot;user_bbb_ro&quot;: {\r\n                &quot;password&quot;: &quot;xxx&quot;\r\n            }\r\n        },\r\n        &quot;db_ccc&quot;: {\r\n            &quot;user_ccc&quot;: {\r\n                &quot;password&quot;: &quot;xxx&quot;\r\n            }\r\n        }\r\n    },\r\n    &quot;bdd2&quot;: {\r\n        &quot;db_aaa&quot;: {\r\n            &quot;user_aaa&quot;: {\r\n                &quot;password&quot;: &quot;xxx&quot;\r\n            }\r\n        }\r\n    }\r\n\r\nWith this filter `(..|.vhosts?|..|.postgresql?)|objects`, I can isolate data I need.\r\n\r\n    {\r\n      &quot;bdd1&quot;: {\r\n        &quot;db_aaa&quot;: {\r\n          &quot;user_aaa&quot;: {\r\n            &quot;password&quot;: &quot;xxx&quot;\r\n          }\r\n        }\r\n      },\r\n      &quot;bdd2&quot;: {\r\n        &quot;db_aaa&quot;: {\r\n          &quot;user_aaa&quot;: {\r\n            &quot;password&quot;: &quot;xxx&quot;\r\n          }\r\n        }\r\n      }\r\n    }\r\n    {\r\n      &quot;bdd1&quot;: {\r\n        &quot;db_bbb&quot;: {\r\n          &quot;user_bbb&quot;: {\r\n            &quot;password&quot;: &quot;xxx&quot;\r\n          },\r\n          &quot;user_bbb_ro&quot;: {\r\n            &quot;password&quot;: &quot;xxx&quot;\r\n          }\r\n        }\r\n      }\r\n    }\r\n    {\r\n      &quot;bdd1&quot;: {\r\n        &quot;db_ccc&quot;: {\r\n          &quot;user_ccc&quot;: {\r\n            &quot;password&quot;: &quot;xxx&quot;\r\n          }\r\n        }\r\n      }\r\n    }\r\n\r\nNext step is to merge all of theses data grouped by *bddx*.\r\nAny help or advice will be welcome :)",
        "link": "https://stackoverflow.com/questions/39269967/how-to-select-and-merge-objects-data-with-jq",
        "title": "How to select and merge objects data with jq?"
    },
    {
        "tags": [
            "json",
            "shell",
            "command-line",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1476217296,
                "last_edit_date": 1476217296,
                "creation_date": 1473019557,
                "answer_id": 39321021,
                "question_id": 39320865,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Try this filter:\r\n\r\n    map( {name, \r\n          &quot;expire&quot;: (.expire | if type == &quot;object&quot; then .[&quot;$value&quot;] elif type == &quot;number&quot; then . else null end) } )\r\n\r\nor (with significantly different semantics in edge cases):\r\n\r\n    map(.expire |= if type == &quot;object&quot; then .[&quot;$value&quot;]\r\n                   elif type == &quot;number&quot; then . else null end)",
                "title": "Modify object properties conditionally with jq"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1473026585,
                "creation_date": 1473026585,
                "answer_id": 39321881,
                "question_id": 39320865,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You can think of it another way as updating each object&#39;s `expire` property with the `&quot;$value&quot;` if present, or the current value.  If the value doesn&#39;t exist, it&#39;s just simply `null`.\r\n\r\n    .[].expire |= (.&quot;$value&quot;? // .)",
                "title": "Modify object properties conditionally with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 8,
        "last_activity_date": 1476217296,
        "creation_date": 1473018469,
        "last_edit_date": 1473026487,
        "question_id": 39320865,
        "body_markdown": "I have this sample of JSON:\r\n\r\n    [\r\n        {\r\n            &quot;name&quot;: &quot;val1&quot;,\r\n            &quot;expire&quot;: { &quot;$value&quot;: 10 }\r\n        },\r\n        {\r\n            &quot;name&quot;: &quot;val2&quot;,\r\n            &quot;expire&quot;: 20\r\n        },\r\n        {\r\n            &quot;name&quot;: &quot;val3&quot;\r\n        }\r\n    ]\r\n\r\nAnd I want to transform it to this form with jq:\r\n\r\n    [\r\n        {\r\n            &quot;name&quot;: &quot;val1&quot;,\r\n            &quot;expire&quot;: 10\r\n        },\r\n        {\r\n            &quot;name&quot;: &quot;val2&quot;,\r\n            &quot;expire&quot;: 20\r\n        },\r\n        {\r\n            &quot;name&quot;: &quot;val3&quot;,\r\n            &quot;expire&quot;: null\r\n        }\r\n    ]\r\n\r\nAll that I&#39;ve found it&#39;s if-then-else, but it looks like I have no clue how to build right expression.\r\n\r\nCondition based on type check, it looks like a right way, but just return &quot;compile&quot;-time error, I don&#39;t know how to fix it:\r\n\r\n    .[] | { name, expire: (if .expire then (if type(.expire) == &quot;number&quot; then .expire else .expire.&quot;$value&quot; end) else null end) }\r\n\r\nCondition based on `&quot;$value&quot;` check, somehow filter out second object:\r\n\r\n    .[] | { name, expire: (if .expire then (if .expire.&quot;$value&quot;? then .expire.&quot;$value&quot; else .expire end) else null end) }\r\n\r\nAs I understand, the problem here in internal if, where second object checked with `.expire.&quot;$value&quot;?`, error was thrown and object removed from result because of error.",
        "link": "https://stackoverflow.com/questions/39320865/modify-object-properties-conditionally-with-jq",
        "title": "Modify object properties conditionally with jq"
    },
    {
        "tags": [
            "json",
            "export-to-csv",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1473094836,
                "creation_date": 1473094836,
                "answer_id": 39334968,
                "question_id": 39334801,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You could always collect the values you want from the parent objects separately from the child objects and combine them later.\r\n\r\ne.g.,\r\n\r\n    $ jq -r &#39;[.data] + (.stores[] | [.name, .lat, .lng, .dist]) | @csv&#39; input.json\r\n\r\nyields\r\n\r\n    &quot;MFR-L&quot;,&quot;KOLL&quot;,52.93128,6.962956,1\r\n    &quot;MFR-L&quot;,&quot;Takst&quot;,52.9523773,6.981644,1.3\r\n\r\n",
                "title": "Convert complex JSON (with arrays and different data types) to CSV using JQ?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1473271055,
                "creation_date": 1473271055,
                "answer_id": 39376452,
                "question_id": 39334801,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "\r\nThere are several ways in which the illustrative JSON might be &quot;flattened&quot; (e.g. to CSV), but the following two approaches may be of interest. (I&#39;ve omitted the invocation of @csv for ease-of-reading.)\r\n```\r\n$ jq &#39;[.data, .stores[][]]&#39; in.json\r\n[\r\n  &quot;MFR-L&quot;,\r\n  &quot;KOLL&quot;,\r\n  52.93128,\r\n  6.962956,\r\n  1,\r\n  1.129,\r\n  true,\r\n  &quot;Takst&quot;,\r\n  52.9523773,\r\n  6.981644,\r\n  1.3,\r\n  1.809,\r\n  false\r\n]\r\n```\r\n\r\n```\r\n$ jq &#39;.data as $data | .stores[] | [$data, .[]]&#39; in.json\r\n[\r\n  &quot;MFR-L&quot;,\r\n  &quot;KOLL&quot;,\r\n  52.93128,\r\n  6.962956,\r\n  1,\r\n  1.129,\r\n  true\r\n]\r\n[\r\n  &quot;MFR-L&quot;,\r\n  &quot;Takst&quot;,\r\n  52.9523773,\r\n  6.981644,\r\n  1.3,\r\n  1.809,\r\n  false\r\n]\r\n```",
                "title": "Convert complex JSON (with arrays and different data types) to CSV using JQ?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1503896667,
                "creation_date": 1503896667,
                "answer_id": 45912053,
                "question_id": 39334801,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is another approach which uses jq variables and string interpolation:\r\n\r\n       .data as $data\r\n     | .stores[]\r\n     | &quot;\\($data),\\(.name),\\(.lat),\\(.lng),\\(.dist),\\(.x10),\\(.isOpen)&quot;\r\n\r\noutput with sample data:\r\n\r\n    &quot;MFR-L,KOLL,52.93128,6.962956,1,1.129,true&quot;\r\n    &quot;MFR-L,Takst,52.9523773,6.981644,1.3,1.809,false&quot;",
                "title": "Convert complex JSON (with arrays and different data types) to CSV using JQ?"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1576349593,
        "creation_date": 1473094050,
        "last_edit_date": 1576349593,
        "question_id": 39334801,
        "body_markdown": "I have the following JSON data:\r\n\r\n       {\r\n        \t&quot;status&quot;: &quot;ok&quot;,\r\n        \t&quot;ok&quot;: true,\r\n        \t&quot;data&quot;: &quot;MFR-L&quot;,\r\n        \t&quot;stores&quot;: [{\r\n        \t\t&quot;name&quot;: &quot;KOLL&quot;,\r\n        \t\t&quot;lat&quot;: 52.93128,\r\n        \t\t&quot;lng&quot;: 6.962956,\r\n        \t\t&quot;dist&quot;: 1,\r\n        \t\t&quot;x10&quot;: 1.129,\r\n        \t\t&quot;isOpen&quot;: true\r\n        \t},\r\n        \t{\r\n        \t\t&quot;name&quot;: &quot;Takst&quot;,\r\n        \t\t&quot;lat&quot;: 52.9523773,\r\n        \t\t&quot;lng&quot;: 6.981644,\r\n        \t\t&quot;dist&quot;: 1.3,\r\n        \t\t&quot;x10&quot;: 1.809,\r\n        \t\t&quot;isOpen&quot;: false\r\n        \t}]\r\n        }\r\n\r\nI&#39;m trying to convert it to a flat file using JQ, but I keep running into all sorts of problems, especially because of the file types (&quot;cannot index boolean with string&quot;, etc).\r\n\r\n[This post][1] has helped me flatten the contents of the array so far, like this:\r\n\r\n    jq -r -s &#39;map(.stores | map({nm: .name, lt: .lat} | [.nm, .lt])) | add [] | @csv\r\n\r\nHow can I get the contents higher up in the hierarchy to map to the array contents?\r\n\r\n  [1]: https://stackoverflow.com/questions/29764836/how-to-convert-complex-json-to-csv-using-jq-1-4\r\n",
        "link": "https://stackoverflow.com/questions/39334801/convert-complex-json-with-arrays-and-different-data-types-to-csv-using-jq",
        "title": "Convert complex JSON (with arrays and different data types) to CSV using JQ?"
    },
    {
        "tags": [
            "module",
            "shared-libraries",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 8,
                "is_accepted": true,
                "score": 8,
                "last_activity_date": 1473190703,
                "creation_date": 1473190703,
                "answer_id": 39356599,
                "question_id": 39355940,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "From the [Modules section of the manual](https://stedolan.github.io/jq/manual/#Modules):\r\n\r\n&gt; [...]\r\n&gt;\r\n&gt; The default search path is the search path given to the -L command-line option, else [&quot;~/.jq&quot;, &quot;$ORIGIN/../lib/jq&quot;, &quot;$ORIGIN/../lib&quot;]\r\n&gt;\r\n&gt; [...]\r\n&gt;\r\n&gt;If “$HOME/.jq” is a file, it is sourced into the main program.\r\n\r\n`$ORIGIN` appears to refer to the directory containing the `jq` binary itself.",
                "title": "Where to put custom JQ functions?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 7,
        "last_activity_date": 1473269959,
        "creation_date": 1473187809,
        "last_edit_date": 1473269959,
        "question_id": 39355940,
        "body_markdown": "I found a good set of definitions I would like to use in jq(https://github.com/stedolan/jq/blob/master/src/builtin.jq). The version I have to use don&#39;t have them built in. The page mentions that use these definition for the new functions. \r\n\r\nI would like to know where to put these definitions so my local jq can access them. ",
        "link": "https://stackoverflow.com/questions/39355940/where-to-put-custom-jq-functions",
        "title": "Where to put custom JQ functions?"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 166270,
                    "reputation": 135171,
                    "user_id": 390278,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/84715fec547362389d02f5be0ed12814?s=256&d=identicon&r=PG",
                    "display_name": "Jeff Mercado",
                    "link": "https://stackoverflow.com/users/390278/jeff-mercado"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1473201683,
                "post_id": 39358804,
                "comment_id": 66047383,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 2233694,
                    "reputation": 431,
                    "user_id": 1970684,
                    "user_type": "registered",
                    "accept_rate": 62,
                    "profile_image": "https://www.gravatar.com/avatar/8647d12bf57ac8c94934ea5f50e61a5e?s=256&d=identicon&r=PG",
                    "display_name": "RagePwn",
                    "link": "https://stackoverflow.com/users/1970684/ragepwn"
                },
                "reply_to_user": {
                    "account_id": 166270,
                    "reputation": 135171,
                    "user_id": 390278,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/84715fec547362389d02f5be0ed12814?s=256&d=identicon&r=PG",
                    "display_name": "Jeff Mercado",
                    "link": "https://stackoverflow.com/users/390278/jeff-mercado"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1473202267,
                "post_id": 39358804,
                "comment_id": 66047539,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 166270,
                    "reputation": 135171,
                    "user_id": 390278,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/84715fec547362389d02f5be0ed12814?s=256&d=identicon&r=PG",
                    "display_name": "Jeff Mercado",
                    "link": "https://stackoverflow.com/users/390278/jeff-mercado"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1473215411,
                "post_id": 39358804,
                "comment_id": 66050232,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1474297260,
                "creation_date": 1474297260,
                "answer_id": 39576325,
                "question_id": 39358804,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "How about this?\r\n\r\n    jq &#39;.[]|map(select(.ClusterIdentifier==&quot;dev-cluster&quot;))\r\n        |max_by(.SnapshotCreateTime)|.SnapshotIdentifier&#39;",
                "title": "Using jq select to filter json not working"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1474297260,
        "creation_date": 1473201471,
        "question_id": 39358804,
        "body_markdown": "I&#39;m trying to grab a property from a json document using jq. I want to get the latest snapshot with a specific name. Here is the jq statment in bash, which works fine until I add the select with filter\r\n\r\n    snapid=aws redshift describe-cluster-snapshots --region us-west-2 | jq&#39;.[] | select(.ClusterIdentifier==&quot;dev-cluster&quot;) | max_by(.SnapshotCreateTime) | .SnapshotIdentifier&#39;\r\n\r\nHere is the json doc I&#39;m pulling from. There are more than one snapshot entries but this is the one I&#39;m targeting.\r\n\r\n    {\r\n        &quot;Snapshots&quot;: [        \r\n            {\r\n                    &quot;EstimatedSecondsToCompletion&quot;: 0, \r\n                    &quot;OwnerAccount&quot;: &quot;45645641155&quot;, \r\n                    &quot;CurrentBackupRateInMegaBytesPerSecond&quot;: 6.2857, \r\n                    &quot;ActualIncrementalBackupSizeInMegaBytes&quot;: 22.0, \r\n                    &quot;NumberOfNodes&quot;: 3, \r\n                    &quot;Status&quot;: &quot;available&quot;, \r\n                    &quot;VpcId&quot;: &quot;myvpc&quot;, \r\n                    &quot;ClusterVersion&quot;: &quot;1.0&quot;, \r\n                    &quot;Tags&quot;: [], \r\n                    &quot;MasterUsername&quot;: &quot;ayxbizops&quot;, \r\n                    &quot;TotalBackupSizeInMegaBytes&quot;: 192959.0, \r\n                    &quot;DBName&quot;: &quot;dev&quot;, \r\n                    &quot;BackupProgressInMegaBytes&quot;: 22.0, \r\n                    &quot;ClusterCreateTime&quot;: &quot;2016-09-06T15:56:08.170Z&quot;, \r\n                    &quot;RestorableNodeTypes&quot;: [\r\n                        &quot;dc1.large&quot;\r\n                    ], \r\n                    &quot;EncryptedWithHSM&quot;: false, \r\n                    &quot;ClusterIdentifier&quot;: &quot;dev-cluster&quot;, \r\n                    &quot;SnapshotCreateTime&quot;: &quot;2016-09-06T16:00:25.595Z&quot;, \r\n                    &quot;AvailabilityZone&quot;: &quot;us-west-2c&quot;, \r\n                    &quot;NodeType&quot;: &quot;dc1.large&quot;, \r\n                    &quot;Encrypted&quot;: false, \r\n                    &quot;ElapsedTimeInSeconds&quot;: 3, \r\n                    &quot;SnapshotType&quot;: &quot;manual&quot;, \r\n                    &quot;Port&quot;: 5439, \r\n                    &quot;SnapshotIdentifier&quot;: &quot;thismorning&quot;\r\n            }\r\n        ]\r\n    }\r\n\r\nI get the error, Cannot index array with string &quot;ClusterIdentifier&quot;.\r\n",
        "link": "https://stackoverflow.com/questions/39358804/using-jq-select-to-filter-json-not-working",
        "title": "Using jq select to filter json not working"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 7,
                "is_accepted": false,
                "score": 7,
                "last_activity_date": 1473215270,
                "last_edit_date": 1473215270,
                "creation_date": 1473210694,
                "answer_id": 39359893,
                "question_id": 39359651,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "1.  `max_by` expects an array as input.  Thus the following variant of your filter would work:\r\n\r\n        [.Snapshots[] | select(.ClusterIdentifier == &quot;dev-cluster&quot;)]\r\n        | max_by(.SnapshotCreateTime)\r\n        | .SnapshotIdentifier\r\n\r\n2. Based on your verbal description, it would seem you want to run `max_by` before `select`:\r\n\r\n        .Snapshots\r\n        | max_by(.SnapshotCreateTime)\r\n        | select(.ClusterIdentifier == &quot;dev-cluster&quot;)\r\n        | .SnapshotIdentifier\r\n\r\n3. If there is possibly more than one maximal object, you might want to use `maximal_by` rather than `max_by`:\r\n\r\n        def maximal_by(f):\r\n          (map(f) | max) as $mx\r\n          | .[] | select(f == $mx);\r\n\r\n",
                "title": "Chain select and max_by on json doc with jq in bash"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1480629377,
        "creation_date": 1473208202,
        "last_edit_date": 1480629377,
        "question_id": 39359651,
        "body_markdown": "I want to get the SnapshotIdentifier of the snapshot with the maximum SnapshotCreateTime, and filter it by ClusterIdentifier. Here is the command I&#39;m using:\r\n\r\n    aws redshift describe-cluster-snapshots --region us-west-2 |\r\n      jq -r &#39;.Snapshots[]\r\n             | select(.ClusterIdentifier == &quot;dev-cluster&quot;)\r\n             | max_by(.SnapshotCreateTime) \r\n             | .SnapshotIdentifier &#39;\r\n\r\nHere is the json\r\n\r\n    {\r\n        &quot;Snapshots&quot;: [        \r\n            {\r\n                    &quot;EstimatedSecondsToCompletion&quot;: 0, \r\n                    &quot;OwnerAccount&quot;: &quot;45645641155&quot;, \r\n                    &quot;CurrentBackupRateInMegaBytesPerSecond&quot;: 6.2857, \r\n                    &quot;ActualIncrementalBackupSizeInMegaBytes&quot;: 22.0, \r\n                    &quot;NumberOfNodes&quot;: 3, \r\n                    &quot;Status&quot;: &quot;available&quot;, \r\n                    &quot;VpcId&quot;: &quot;myvpc&quot;, \r\n                    &quot;ClusterVersion&quot;: &quot;1.0&quot;, \r\n                    &quot;Tags&quot;: [], \r\n                    &quot;MasterUsername&quot;: &quot;ayxbizops&quot;, \r\n                    &quot;TotalBackupSizeInMegaBytes&quot;: 192959.0, \r\n                    &quot;DBName&quot;: &quot;dev&quot;, \r\n                    &quot;BackupProgressInMegaBytes&quot;: 22.0, \r\n                    &quot;ClusterCreateTime&quot;: &quot;2016-09-06T15:56:08.170Z&quot;, \r\n                    &quot;RestorableNodeTypes&quot;: [\r\n                        &quot;dc1.large&quot;\r\n                    ], \r\n                    &quot;EncryptedWithHSM&quot;: false, \r\n                    &quot;ClusterIdentifier&quot;: &quot;dev-cluster&quot;, \r\n                    &quot;SnapshotCreateTime&quot;: &quot;2016-09-06T16:00:25.595Z&quot;, \r\n                    &quot;AvailabilityZone&quot;: &quot;us-west-2c&quot;, \r\n                    &quot;NodeType&quot;: &quot;dc1.large&quot;, \r\n                    &quot;Encrypted&quot;: false, \r\n                    &quot;ElapsedTimeInSeconds&quot;: 3, \r\n                    &quot;SnapshotType&quot;: &quot;manual&quot;, \r\n                    &quot;Port&quot;: 5439, \r\n                    &quot;SnapshotIdentifier&quot;: &quot;thismorning&quot;\r\n            }\r\n        ]\r\n    }\r\n\r\n",
        "link": "https://stackoverflow.com/questions/39359651/chain-select-and-max-by-on-json-doc-with-jq-in-bash",
        "title": "Chain select and max_by on json doc with jq in bash"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1473444268,
                "creation_date": 1473444268,
                "answer_id": 39417338,
                "question_id": 39416318,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Not a `jq`-only answer, but you can get a list of all the `type` fields, then pipe that through `uniq -c` to get a count.\r\n\r\n    $ jq &#39;.logs[] | .type&#39; tmp.json | uniq -c\r\n        1 signup\r\n        1 welcome\r\n        2 vote",
                "title": "access fields in json object with unique identifiers"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1473532338,
                "last_edit_date": 1473532338,
                "creation_date": 1473448491,
                "answer_id": 39418338,
                "question_id": 39416318,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "To obtain a stream of all the &quot;type&quot; values of all objects, no matter how deeply nested:\r\n\r\n     .. | select(.type?) | .type\r\n\r\nIn your particular case, the following would suffice:\r\n\r\n    .[] | select(type == &quot;object&quot;) | .[].type\r\n\r\nTo produce a tabulation:\r\n\r\n    def tabulate: reduce .[] as $i ({}; .[$i] += 1 );\r\n\r\n    [.[] | select(type == &quot;object&quot;) | .[].type] | tabulate\r\n\r\nGiven your input, the output would be:\r\n```\r\n{\r\n  &quot;signup&quot;: 1,\r\n  &quot;welcome&quot;: 1,\r\n  &quot;vote&quot;: 2\r\n}\r\n```",
                "title": "access fields in json object with unique identifiers"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1503897078,
                "creation_date": 1503897078,
                "answer_id": 45912103,
                "question_id": 39416318,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a solution which uses **tostream** and **reduce**\r\n\r\n    reduce (tostream|select(length==2)) as [$p,$v] (\r\n      {}\r\n    ; if $p[-1] == &quot;type&quot; then .[$v] += 1 else . end  \r\n    )\r\n\r\noutput with sample data\r\n\r\n    {\r\n      &quot;signup&quot;: 1,\r\n      &quot;welcome&quot;: 1,\r\n      &quot;vote&quot;: 2\r\n    }",
                "title": "access fields in json object with unique identifiers"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1503897078,
        "creation_date": 1473439764,
        "last_edit_date": 1473439952,
        "question_id": 39416318,
        "body_markdown": "I&#39;m having trouble understanding jq.  I&#39;m even having trouble articulating what I want to learn.\r\n\r\nI think I want a wildcard?  my desire is, given a json snippet like this:\r\n\r\n    {\r\n      &quot;logs&quot;: {\r\n        &quot;-MnpQaRONGXz9tff-W&quot;: {\r\n          &quot;points&quot;: 10,\r\n          &quot;type&quot;: &quot;signup&quot;\r\n        },\r\n        &quot;-N5qlX1mQ3SYA9RXdE&quot;: {\r\n          &quot;points&quot;: 15,\r\n          &quot;type&quot;: &quot;welcome&quot;\r\n        },\r\n        &quot;-N5rx8PAcNgWu25zRf&quot;: {\r\n          &quot;points&quot;: 5,\r\n          &quot;type&quot;: &quot;vote&quot;\r\n        },\r\n        &quot;-N5s29TyZ33snUqC5X&quot;: {\r\n          &quot;points&quot;: 5,\r\n          &quot;type&quot;: &quot;vote&quot;\r\n        }\r\n      },\r\n      &quot;total&quot;: 35\r\n    }\r\n\r\nCount how many times a certain type appears, or even just output all the types into a file.\r\n\r\nThis totally doesn&#39;t work (and in the simplified example doesn&#39;t make sense):\r\n\r\n    cat test.json | jq &#39;.logs | * | .type&#39;\r\n\r\nwould get me a simple object or listing of the types .",
        "link": "https://stackoverflow.com/questions/39416318/access-fields-in-json-object-with-unique-identifiers",
        "title": "access fields in json object with unique identifiers"
    },
    {
        "tags": [
            "iteration",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1473488607,
                "last_edit_date": 1473488607,
                "creation_date": 1473460280,
                "answer_id": 39420551,
                "question_id": 39420412,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Assuming your jq has regex support:\r\n\r\n    map(select(test(&quot;a|d|h&quot;)))\r\n\r\n\r\nOr if you want a stream of values:\r\n\r\n    .[] | select(test(&quot;a|d|h&quot;))\r\n\r\nIf your jq does not have regex support, then if it has any/2, the following will produce a stream of values:\r\n\r\n    .[] | select( any( index( &quot;a&quot;, &quot;d&quot;, &quot;h&quot;); . != null ) )\r\n\r\nAll else failing, the following will do the job but is inefficient:\r\n\r\n     .[] | select( [index(&quot;a&quot;, &quot;d&quot;, &quot;h&quot;)] | any )",
                "title": "jq test if any of several substrings is in a string"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1502000940,
                "creation_date": 1502000940,
                "answer_id": 45529245,
                "question_id": 39420412,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a solution using **index**\r\n\r\n      .[]\r\n    | if index(&quot;a&quot;) or index(&quot;d&quot;) or index(&quot;h&quot;) then . else empty end",
                "title": "jq test if any of several substrings is in a string"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1502000940,
        "creation_date": 1473459190,
        "last_edit_date": 1473557896,
        "question_id": 39420412,
        "body_markdown": "Let&#39;s say I have a list of items like this:\r\n\r\n    [\r\n      &quot;abcdef&quot;,\r\n      &quot;defghi&quot;,\r\n      &quot;euskdh&quot;\r\n    ]\r\n\r\nI want to write a filter that returns all of the items that contain an &quot;a&quot;, &quot;d&quot;, or &quot;h&quot;. This is the best I could come up with:\r\n\r\n    . as $val | select(any([&quot;a&quot;, &quot;d&quot;, &quot;h&quot;]; inside($val)))\r\n\r\nIs there any way to do it without using a variable?",
        "link": "https://stackoverflow.com/questions/39420412/jq-test-if-any-of-several-substrings-is-in-a-string",
        "title": "jq test if any of several substrings is in a string"
    },
    {
        "tags": [
            "json",
            "mongodb",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": false,
                "score": 5,
                "last_activity_date": 1473677343,
                "creation_date": 1473677343,
                "answer_id": 39448625,
                "question_id": 39447749,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "this is caused because mongo uses BSON in the backend [see this][1]\r\n\r\nusing mongoexport with `json` option will allow to generate clean json files:\r\n\r\n     &quot;CreatedDate&quot;:{&quot;$date&quot;:&quot;2016-08-13T01:01:20.833Z&quot;}\r\n\r\ninstead of:\r\n\r\n     &quot;CreatedDate&quot; : ISODate(&quot;2016-08-13T01:01:20.833Z&quot;),\r\n\r\n\r\n  [1]: https://docs.mongodb.com/manual/reference/bson-types/",
                "title": "Jq cannot parse MongoDB output document"
            },
            {
                "up_vote_count": 8,
                "is_accepted": false,
                "score": 8,
                "last_activity_date": 1473679972,
                "creation_date": 1473679972,
                "answer_id": 39449355,
                "question_id": 39447749,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "A workaround that could be sufficient for certain use is to transform the output of the mongo shell command. I use this pattern for a workaround:\r\n\r\n    mongo --quiet --eval &quot;rs.config()&quot; | sed -e &#39;s/: [a-zA-Z]*(\\(.*\\))/: &quot;\\1&quot;/&#39; | jq &#39;.&#39;\r\n\r\nIt removes all functions call after the &#39;:&#39; and keep only the value.",
                "title": "Jq cannot parse MongoDB output document"
            },
            {
                "up_vote_count": 28,
                "is_accepted": true,
                "score": 28,
                "last_activity_date": 1483219789,
                "creation_date": 1483219789,
                "answer_id": 41411832,
                "question_id": 39447749,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "I know I am a little too late here but Mongo shell has built-in JavaScript support. So you can use `JSON.stringify`.\r\n\r\nFor the specific example above, you can use below\r\n\r\n`mongo --quiet --eval &quot;JSON.stringify(rs.config())&quot;`",
                "title": "Jq cannot parse MongoDB output document"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 13,
        "last_activity_date": 1483219789,
        "creation_date": 1473674269,
        "question_id": 39447749,
        "body_markdown": "Jq is a wonderfull tool to deals with JS document in bash. But I can&#39;t use to parse some MongoDB output documents due to function like added by Mongodb.\r\nExample of MongoDB Json return:\r\n\r\n    {\r\n    \t&quot;_id&quot; : &quot;example&quot;,\r\n    \t&quot;version&quot; : 23,\r\n    \t&quot;members&quot; : [\r\n    \t\t{\r\n    \t\t\t&quot;_id&quot; : 0,\r\n    \t\t\t&quot;host&quot; : &quot;192.168.0.1:27017&quot;,\r\n    \t\t\t&quot;slaveDelay&quot; : NumberLong(0),   &lt;---- Here jq failed to parse this line\r\n    \t\t\t&quot;votes&quot; : 1\r\n    \t\t}\r\n    ]}\r\n\r\nThe error given by jq is:\r\n\r\n    parse error: Invalid numeric literal at line 15, column 32\r\n\r\nAny help would be greatly appreciated.\r\n",
        "link": "https://stackoverflow.com/questions/39447749/jq-cannot-parse-mongodb-output-document",
        "title": "Jq cannot parse MongoDB output document"
    },
    {
        "tags": [
            "amazon-s3",
            "jq",
            "aws-cli"
        ],
        "answers": [
            {
                "up_vote_count": 36,
                "is_accepted": true,
                "score": 36,
                "last_activity_date": 1473708618,
                "creation_date": 1473708618,
                "answer_id": 39457459,
                "question_id": 39457458,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Assuming you have your `awscli` all setup and it&#39;ll output JSON you can use `jq` to project the needed keys with:\r\n\r\n    BUCKETNAME=&lt;xxx&gt;\r\n    aws s3api list-multipart-uploads --bucket $BUCKETNAME \\\r\n    | jq -r &#39;.Uploads[] | &quot;--key \\&quot;\\(.Key)\\&quot; --upload-id \\(.UploadId)&quot;&#39; \\\r\n    | while read -r line; do\r\n        eval &quot;aws s3api abort-multipart-upload --bucket $BUCKETNAME $line&quot;;\r\n    done",
                "title": "howto abort all incomplete multipart uploads for a bucket"
            },
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1473721316,
                "last_edit_date": 1473721316,
                "creation_date": 1473720227,
                "answer_id": 39459831,
                "question_id": 39457458,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You can set up lifecycle rules to automatically purge those after some amount of time. Here&#39;s a blog post demonstrating how to do it in the console:\r\n\r\nhttps://aws.amazon.com/blogs/aws/s3-lifecycle-management-update-support-for-multipart-uploads-and-delete-markers/\r\n\r\nTo do this in boto3:\r\n\r\n    import boto3\r\n    \r\n    \r\n    s3 = boto3.client(&#39;s3&#39;)\r\n    try:\r\n        lifecycle = s3.get_bucket_lifecycle(Bucket=&#39;bucket&#39;)\r\n    except ClientError:\r\n        lifecycle = {&#39;Rules&#39;: []}\r\n    lifecycle[&#39;Rules&#39;].append({\r\n        &#39;ID&#39;: &#39;PruneAbandonedMultipartUploads&#39;,\r\n        &#39;Status&#39;: &#39;Enabled&#39;,\r\n        &#39;Prefix&#39;: &#39;&#39;,\r\n        &#39;AbortIncompleteMultipartUpload&#39;: {\r\n            &#39;DaysAfterInitiation&#39;: 7\r\n        }\r\n    })\r\n    s3.put_bucket_lifecycle(Bucket=&#39;bucket&#39;, LifecycleConfiguration=lifecycle)\r\n\r\nAdding that configuration in the cli would be much the same:\r\n\r\n    $ aws s3api get-bucket-lifecycle --bucket bucket &gt; lifecycle.json\r\n    # Edit the lifecycle, adding the same configuration as in the boto3 sample\r\n    $ aws s3api put-bucket-lifecycle --bucket bucket --lifecycle-configuration file://lifecycle.json\r\n\r\nIf you have no lifecycle policy on your bucket, `get-bucket-lifecycle` will raise a `ClientError`. A robust implementation would make sure the right error is returned.\r\n\r\nA policy only with that configuration would look like so:\r\n\r\n    {\r\n        &quot;Rules&quot;: [\r\n            {\r\n                &quot;ID&quot;: &quot;PruneAbandonedMultipartUpload&quot;,\r\n                &quot;Status&quot;: &quot;Enabled&quot;,\r\n                &quot;AbortIncompleteMultipartUpload&quot;: {\r\n                    &quot;DaysAfterInitiation&quot;: 7\r\n                }\r\n            }\r\n        ]\r\n    }",
                "title": "howto abort all incomplete multipart uploads for a bucket"
            },
            {
                "up_vote_count": 6,
                "is_accepted": false,
                "score": 6,
                "last_activity_date": 1476085811,
                "last_edit_date": 1476085811,
                "creation_date": 1476084426,
                "answer_id": 39953195,
                "question_id": 39457458,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You can alternatively use [Minio Client aka mc][1] It is Open Source and compatible with AWS S3. \r\n\r\nTo list all the incomplete upload on a associated bucket.\r\n\r\n    $ mc ls -I s3/mybucketname\r\n\r\nTo remove all incomplete uploads to a associated S3 bucket.\r\n\r\n    $ mc rm -I -r --force s3/mybucketname\r\n\r\nI = incomplete\r\nr = recursive\r\nf = with force option\r\n\r\nHope it helps.\r\n\r\nDisclaimer : I work for [Minio][2].\r\n  \r\n\r\n\r\n  [1]: https://github.com/minio/mc\r\n  [2]: https://minio.io\r\n",
                "title": "howto abort all incomplete multipart uploads for a bucket"
            },
            {
                "up_vote_count": 25,
                "is_accepted": false,
                "score": 25,
                "last_activity_date": 1544018854,
                "creation_date": 1544018854,
                "answer_id": 53634176,
                "question_id": 39457458,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you are doing multipart uploading, you can do the cleanup form S3 Management console too. \r\n\r\na) Open your S3 bucket\r\n\r\nb) Switch to **Management Tab**\r\n\r\nc) Click **Add Lifecycle Rule**\r\n\r\nd) Now type **rule name** on first step and check the **Clean up incomplete multipart uploads** checkbox. Now you an type the number of days to keep incomplete parts too.\r\n\r\nThat&#39;s it. You can see these steps in attached screen shot too.\r\n\r\n[![Steps to add rule][1]][1]\r\n\r\n\r\n  [1]: https://i.sstatic.net/x4ZOU.jpg",
                "title": "howto abort all incomplete multipart uploads for a bucket"
            },
            {
                "up_vote_count": 7,
                "is_accepted": false,
                "score": 6,
                "last_activity_date": 1570831704,
                "creation_date": 1570831704,
                "answer_id": 58349001,
                "question_id": 39457458,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is my oneliner, that will abort ALL multipart uploads regardless of status, assuming that you don&#39;t have any spaces in your key / filename. \r\n\r\n    BUCKETNAME=&lt;xxx&gt;;aws s3api list-multipart-uploads --bucket $BUCKETNAME --query &#39;Uploads[].[Key, UploadId]&#39; --output text | awk  &#39;{print &quot;aws s3api abort-multipart-upload --upload-id &quot;$2&quot; --bucket $BUCKETNAME --key &quot; $1 &quot; &amp; wait&quot;}{}&#39; | bash",
                "title": "howto abort all incomplete multipart uploads for a bucket"
            }
        ],
        "is_answered": true,
        "answer_count": 5,
        "score": 29,
        "last_activity_date": 1657748824,
        "creation_date": 1473708618,
        "last_edit_date": 1551077544,
        "question_id": 39457458,
        "body_markdown": "Sometimes multipart uploads hang or don&#39;t complete for some reason. In that case you are stuck with orphaned parts that are tricky to remove. You can list them with:\r\n\r\n    aws s3api list-multipart-uploads --bucket $BUCKETNAME\r\n\r\nI am looking for way to abort them all.",
        "link": "https://stackoverflow.com/questions/39457458/howto-abort-all-incomplete-multipart-uploads-for-a-bucket",
        "title": "howto abort all incomplete multipart uploads for a bucket"
    },
    {
        "tags": [
            "curl",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1473721077,
                "last_edit_date": 1473721077,
                "creation_date": 1473719099,
                "answer_id": 39459675,
                "question_id": 39459308,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The problem is evidently your `select` filter:\r\n\r\n     select(.relation == next)\r\n\r\nI think you meant:\r\n\r\n    select(.relation == &quot;next&quot;)\r\n\r\nSafer would be:\r\n\r\n    select(.relation? == &quot;next&quot;)\r\n\r\n\r\n",
                "title": "jq with curl fails if select filter is used"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1473721077,
        "creation_date": 1473716985,
        "question_id": 39459308,
        "body_markdown": "I&#39;m piping curl output to jq: https://stedolan.github.io/jq/ and everything works great until I try to use a select filter.\r\n\r\nThis very filter works fine when in their online tool: https://jqplay.org/ and in my command line experiments after having downloaded the file.\r\n\r\nThis issue occurs only when I try to directly pipe the curl output into jq.\r\n\r\nThis fails:\r\n\r\n    i71178@SLCITS-L2222:~/next-gen/mongodb$ curl &#39;http://fhirtest.uhn.ca/baseDstu3/Patient?_format=json&amp;_count=50&amp;_pretty=false&amp;_summary=data&#39; | jq-linux64 --unbuffered -r -c &#39;.link[] | select(.relation == next) | .url&#39; | head -3\r\n    jq: error: next/0 is not defined at &lt;top-level&gt;, line 1:\r\n    .link[] | select(.relation == next) | .url                              \r\n    jq: 1 compile error\r\n      % Total    % Received % Xferd  Average Speed   Time    Time     Time  Current\r\n                                     Dload  Upload   Total   Spent    Left  Speed\r\n    100  2421    0  2421    0     0   2413      0 --:--:--  0:00:01 --:--:--  2413\r\n    curl: (23) Failed writing body (1675 != 2736)\r\n    i71178@SLCITS-L2222:~/next-gen/mongodb$ \r\n\r\nThis works fine:\r\n\r\n    i71178@SLCITS-L2222:~/next-gen/mongodb$ curl &#39;http://fhirtest.uhn.ca/baseDstu3/Patient?_format=json&amp;_count=50&amp;_pretty=false&amp;_summary=data&#39; | jq-linux64 --unbuffered -r -c &#39;.link[] | .url&#39; | head -3  % Total    % Received % Xferd  Average Speed   Time    Time     Time  Current\r\n                                     Dload  Upload   Total   Spent    Left  Speed\r\n    100 46801    0 46801    0     0  66256      0 --:--:-- --:--:-- --:--:-- 66290\r\n    http://fhirtest.uhn.ca/baseDstu3/Patient?_count=50&amp;_format=json&amp;_pretty=false&amp;_summary=data\r\n    http://fhirtest.uhn.ca/baseDstu3?_getpages=e73ba3b4-cc7e-4028-8679-b5da1f9cbdd1&amp;_getpagesoffset=50&amp;_count=50&amp;_format=json&amp;_bundletype=searchset\r\n    i71178@SLCITS-L2222:~/next-gen/mongodb$ \r\n\r\nFor context, this is the what is being pipes into the select filter:\r\n\r\n    i71178@SLCITS-L2222:~/next-gen/mongodb$ curl &#39;http://fhirtest.uhn.ca/baseDstu3/Patient?_format=json&amp;_count=50&amp;_pretty=false&amp;_summary=data&#39; | jq-linux64 --unbuffered -r -c &#39;.link[]&#39; | head -3\r\n      % Total    % Received % Xferd  Average Speed   Time    Time     Time  Current\r\n                                     Dload  Upload   Total   Spent    Left  Speed\r\n    100 46801    0 46801    0     0  64411      0 --:--:-- --:--:-- --:--:-- 64375\r\n    {&quot;relation&quot;:&quot;self&quot;,&quot;url&quot;:&quot;http://fhirtest.uhn.ca/baseDstu3/Patient?_count=50&amp;_format=json&amp;_pretty=false&amp;_summary=data&quot;}\r\n    {&quot;relation&quot;:&quot;next&quot;,&quot;url&quot;:&quot;http://fhirtest.uhn.ca/baseDstu3?_getpages=00952912-c9ab-47ca-826c-200bddffe617&amp;_getpagesoffset=50&amp;_count=50&amp;_format=json&amp;_bundletype=searchset&quot;}\r\n    i71178@SLCITS-L2222:~/next-gen/mongodb$ \r\n\r\n\r\nI would really appreciate any help here.\r\n\r\nThanks!\r\n",
        "link": "https://stackoverflow.com/questions/39459308/jq-with-curl-fails-if-select-filter-is-used",
        "title": "jq with curl fails if select filter is used"
    },
    {
        "tags": [
            "jq",
            "set-intersection"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1473819238,
                "last_edit_date": 1473819238,
                "creation_date": 1473786810,
                "answer_id": 39475571,
                "question_id": 39467025,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "When it comes to possibly changing inputs, you should make it a parameter to your filter, rather than hardcoding it in.  Also, using `contains` might not work for you in general.  It runs the filter recursively so even substrings will match which might not be preferred.\r\n\r\nFor example:\r\n\r\n    [&quot;10&quot;, &quot;20&quot;, &quot;30&quot;, &quot;40&quot;, &quot;50&quot;] | contains([&quot;0&quot;])\r\n\r\nis `true`\r\n\r\nI would write it like this:\r\n\r\n    $ jq --argjson ex &#39;[&quot;4210910 3a&quot;]&#39; &#39;map(select(all(.ou[]; $ex[]!=.)))&#39; input.json",
                "title": "jq select elements with array not containing string"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1473810682,
                "last_edit_date": 1473810682,
                "creation_date": 1473810142,
                "answer_id": 39480515,
                "question_id": 39467025,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "This response addresses the case where .ou is an array and we are given another array of forbidden strings.\r\n\r\nFor clarity, let&#39;s define a filter, `intersectq(a;b)`, that will return true iff the arrays have an element in common:\r\n\r\n    def intersectq(a;b):\r\n      any(a[]; . as $x | any( b[]; . == $x) );\r\n\r\nThis is effectively a loop-within-a-loop, but because of the semantics of `any/2`, the computation will stop once a match has been found.(*)\r\n\r\nAssuming $ex is the list of exceptions, then the filter we could use to solve the problem would be:\r\n\r\n    map(select(intersectq(.ou; $ex) | not))\r\n\r\nFor example, we could use an invocation along the lines suggested by Jeff: \r\n\r\n    $ jq --argjson ex &#39;[&quot;4210910 3a&quot;]&#39; -f myfilter.jq input.json\r\n\r\n\r\nNow you might ask: why use the any-within-any double loop rather than .[]-within-all double loop?  The answer is efficiency, as can be seen using `debug`:\r\n\r\n\r\n    $ jq -n &#39;[1,2,3] as $a | [1,1] as $b | all( $a[]; ($b[] | debug) != .)&#39;\r\n    [&quot;DEBUG:&quot;,1]\r\n    [&quot;DEBUG:&quot;,1]\r\n    false\r\n\r\n    $ jq -n &#39;[1,2,3] as $a | [1,1] as $b | all( $a[]; . as $x | all( $b[]; debug | $x != .))&#39;\r\n    [&quot;DEBUG:&quot;,1]\r\n    false\r\n\r\n(*) Footnote \r\n\r\nOf course `intersectq/2` as defined here is still O(m*n) and thus inefficient, but the main point of this post is to highlight the drawback of the .[]-within-all double loop. \r\n",
                "title": "jq select elements with array not containing string"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1505971196,
                "last_edit_date": 1505971196,
                "creation_date": 1502001987,
                "answer_id": 45529367,
                "question_id": 39467025,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a solution that checks the `.ou` member of each element of the input using **foreach** and **contains**.\r\n\r\n      [&quot;4210910 3a&quot;] as $list   # adjust as necessary\r\n\r\n    | .[]\r\n    | foreach $list[] as $e (\r\n        .; .; if .ou | contains([$e]) then . else empty end\r\n      )\r\n\r\nEDIT: I now realize a filter of the form `foreach E as $X (.; .; R)` can almost always be rewritten as `E as $X | R` so the above is really just\r\n\r\n      [&quot;4210910 3a&quot;] as $list\r\n    | .[]\r\n    | $list[] as $e\r\n    | if .ou | contains([$e]) then . else empty end\r\n",
                "title": "jq select elements with array not containing string"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 2,
        "last_activity_date": 1741190128,
        "creation_date": 1473760192,
        "last_edit_date": 1741190128,
        "question_id": 39467025,
        "body_markdown": "Now, this is somewhat similar to https://stackoverflow.com/questions/29429107/jq-select-only-an-array-which-contains-element-a-but-not-element-b but it somehow doesn&#39;t work for me (which is likely my fault)... ;-)\r\n\r\nSo here&#39;s what we have:\r\n\r\n&lt;!-- language: json --&gt;\r\n    [ {\r\n    \r\n            &quot;employeeType&quot;: &quot;student&quot;,\r\n            &quot;cn&quot;: &quot;dc8aff1&quot;,\r\n            &quot;uid&quot;: &quot;dc8aff1&quot;,\r\n            &quot;ou&quot;: [\r\n                &quot;4210910&quot;,\r\n                &quot;4210910 #Abg&quot;,\r\n                &quot;4210910 Abgang&quot;,\r\n                &quot;4240115&quot;,\r\n                &quot;4240115 5&quot;,\r\n                &quot;4240115 5\\/5&quot;\r\n            ]\r\n        },\r\n        {\r\n            &quot;employeeType&quot;: &quot;student&quot;,\r\n            &quot;cn&quot;: &quot;160f656&quot;,\r\n            &quot;uid&quot;: &quot;160f656&quot;,\r\n            &quot;ou&quot;: [\r\n                &quot;4210910&quot;,\r\n                &quot;4210910 3&quot;,\r\n                &quot;4210910 3a&quot;\r\n            ] } ]\r\n\r\nI&#39;d like to select all elements where ou does **not** contain a specific string, say &quot;4210910 3a&quot; or - which would be even better - where ou does not contain any member of a given list of strings.",
        "link": "https://stackoverflow.com/questions/39467025/jq-select-elements-with-array-not-containing-string",
        "title": "jq select elements with array not containing string"
    },
    {
        "tags": [
            "json",
            "bash",
            "null",
            "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": 1473892298,
                "post_id": 39500608,
                "comment_id": 66318626,
                "content_license": "CC BY-SA 3.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": 1473892529,
                "post_id": 39500608,
                "comment_id": 66318699,
                "content_license": "CC BY-SA 3.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": 1473892624,
                "post_id": 39500608,
                "comment_id": 66318728,
                "content_license": "CC BY-SA 3.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": 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": 1481828301,
                "post_id": 39500608,
                "comment_id": 69543106,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "reply_to_user": {
                    "account_id": 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": 1481835214,
                "post_id": 39500608,
                "comment_id": 69546704,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 24,
                "is_accepted": true,
                "score": 24,
                "last_activity_date": 1675110912,
                "last_edit_date": 1675110912,
                "creation_date": 1473894856,
                "answer_id": 39501001,
                "question_id": 39500608,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The following illustrates how to remove all the null-valued keys from a JSON object:\r\n\r\n    jq -n &#39;{&quot;a&quot;:1, &quot;b&quot;: null, &quot;c&quot;: null} | with_entries( select( .value != null ) )&#39;\r\n    {\r\n      &quot;a&quot;: 1\r\n    }\r\n\r\nAlternatively, `paths/0` can be used as follows:\r\n\r\n    . as $o | [paths[] | {(.) : ($o[.])} ] | add\r\n\r\n\r\n\r\nBy the way, `del/1` can also be used to achieve the same result, e.g. using this filter:\r\n\r\n    reduce keys[] as $k (.; if .[$k] == null then del(.[$k]) else . end)\r\n\r\nOr less obviously, but more succinctly:\r\n\r\n    del( .[ (keys - [paths[]])[] ] )\r\n\r\nAnd for the record, here are two ways to use `delpaths/1`:\r\n\r\n    jq -n &#39;{&quot;a&quot;:1, &quot;b&quot;: null, &quot;c&quot;: null, &quot;d&quot;:2} as $o\r\n      | $o\r\n      | delpaths( [  keys[] | select( $o[.] == null ) ] | map( [.]) )&#39;\r\n\r\n \r\n    $ jq -n &#39;{&quot;a&quot;:1, &quot;b&quot;: null, &quot;c&quot;: null, &quot;d&quot;:2}\r\n      | [delpaths((keys - paths) | map([.])) ] | add&#39;\r\n\r\nIn both these last two cases, the output is the same:\r\n    {\r\n      &quot;a&quot;: 1,\r\n      &quot;d&quot;: 2\r\n    }\r\n\r\n---\r\n\r\nFor reference, if you wanted to remove null-valued keys from all JSON objects in a JSON text (i.e., recursively), you could use `walk/1`, or:\r\n\r\n    del(.. | objects | (to_entries[] | select(.value==null) | .key) as $k | .[$k])",
                "title": "Remove all null values"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1568994168,
                "last_edit_date": 1568994168,
                "creation_date": 1473895789,
                "answer_id": 39501114,
                "question_id": 39500608,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "That&#39;s not what `del/1` was meant to be used for.  Given an object as input, if you wanted to remove the `.phones` property, you&#39;d do:\r\n\r\n    del(.phones)\r\n\r\nIn other words, the parameter to `del` is the path to the property you wish to remove.\r\n\r\nIf you wanted to use this, you would have to figure out all the paths to `null` values and pass it in to this.  That would be more of a hassle though.\r\n\r\n&lt;hr&gt;\r\n\r\nStreaming the input in could make this task even simpler.\r\n\r\n    fromstream(tostream | select(length == 1 or .[1] != null))\r\n\r\n&lt;hr&gt;\r\n\r\nOtherwise for a more straightforward approach, you&#39;ll have to walk through the object tree to find `null` values.  If found, filter it out.  Using `walk/1`, your filter could be applied recursively to exclude the `null` values.\r\n\r\n    walk(\r\n        (objects | with_entries(select(.value != null)))\r\n        // (arrays | map(select(. != null)))\r\n        // values\r\n    )\r\n\r\nSo if you had this for input:\r\n\r\n    {\r\n        &quot;foo&quot;: null,\r\n        &quot;bar&quot;: &quot;bar&quot;,\r\n        &quot;biz&quot;: [1,2,3,4,null],\r\n        &quot;baz&quot;: {\r\n            &quot;a&quot;: 1,\r\n            &quot;b&quot;: null,\r\n            &quot;c&quot;: [&quot;a&quot;,&quot;b&quot;,&quot;c&quot;,&quot;null&quot;,32,null]\r\n        }\r\n    }\r\n\r\nThis filter would yield:\r\n\r\n    {\r\n        &quot;bar&quot;: &quot;bar&quot;,\r\n        &quot;baz&quot;: {\r\n            &quot;a&quot;: 1,\r\n            &quot;c&quot;: [&quot;a&quot;,&quot;b&quot;,&quot;c&quot;,&quot;null&quot;,32]\r\n        },\r\n        &quot;biz&quot;: [1,2,3,4]\r\n    }\r\n",
                "title": "Remove all null values"
            },
            {
                "up_vote_count": 6,
                "is_accepted": false,
                "score": 5,
                "last_activity_date": 1542671307,
                "last_edit_date": 1542671307,
                "creation_date": 1481828026,
                "answer_id": 41171380,
                "question_id": 39500608,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "[WARNING: the definition of `walk/1` given in this response is problematic, not least for the reason given in the first comment; note also that jq 1.6 defines `walk/1` differently.]\r\n\r\nI am adding the new answer to emphasize the extended version of the script by @jeff-mercado. My version of the script assumes the empty values are as follows: \r\n\r\n - `null`;\r\n - `[]` - empty arrays;\r\n - `{}` - empty objects. \r\n\r\nRemoving of empty arrays and objects was borrowed from here https://stackoverflow.com/a/26196653/3627676.\r\n\r\n    def walk(f):\r\n\t\t. as $in | \r\n\t\tif type == &quot;object&quot; then\r\n\t\t\treduce keys[] as $key\r\n\t\t\t\t( {}; . + { ($key): ( $in[$key] | walk(f) ) } ) | f\r\n\t\telif type == &quot;array&quot; then \r\n\t\t\tselect(length &gt; 0) | map( walk(f) ) | f\r\n\t\telse \r\n\t\t\tf\r\n\t\tend;\r\n\r\n\twalk(\r\n\t\tif type == &quot;object&quot; then\r\n\t\t\twith_entries(select( .value != null and .value != {} and .value != [] ))\r\n\t\telif type == &quot;array&quot; then\r\n\t\t\tmap(select( . != null and . != {} and .!= [] ))\r\n\t\telse\r\n\t\t\t.\r\n\t\tend\r\n\t)\r\n",
                "title": "Remove all null values"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1542669426,
                "last_edit_date": 1542669426,
                "creation_date": 1501866376,
                "answer_id": 45512166,
                "question_id": 39500608,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "[WARNING: the response below has several problems, not least those arising from the fact that `0|length` is 0.]\r\n\r\nElaborating on an [earlier answer](/q/39500608/39501114#39501114), in addition to removing properties with `null` values, it&#39;s often helpful to remove JSON properties with empty array or object values (i.e., `[]` or `{}`), too.\r\n\r\n&gt; ℹ️ — jq&#39;s `walk()` function (`walk/1`) makes this easy.  `walk()` will be\r\n&gt; available in a future version of jq (&gt; `jq-1.5`), but [its\r\n&gt; definition](https://github.com/stedolan/jq/blob/master/src/builtin.jq#L284)\r\n&gt; can be added to current filters.\r\n\r\nThe condition to pass to `walk()` for removing nulls and empty structures is:\r\n\r\n    walk(\r\n      if type == &quot;object&quot; then with_entries(select(.value|length &gt; 0))\r\n      elif type == &quot;array&quot; then map(select(length &gt; 0))\r\n      else .\r\n      end\r\n    )\r\n\r\nGiven this JSON input:\r\n\r\n    {\r\n      &quot;notNullA&quot;: &quot;notNullA&quot;,\r\n      &quot;nullA&quot;: null,\r\n      &quot;objectA&quot;: {\r\n        &quot;notNullB&quot;: &quot;notNullB&quot;,\r\n        &quot;nullB&quot;: null,\r\n        &quot;objectB&quot;: {\r\n          &quot;notNullC&quot;: &quot;notNullC&quot;,\r\n          &quot;nullC&quot;: null\r\n        },\r\n        &quot;emptyObjectB&quot;: {},\r\n        &quot;arrayB&quot;: [\r\n          &quot;b&quot;\r\n        ],\r\n        &quot;emptyBrrayB&quot;: []\r\n      },\r\n      &quot;emptyObjectA&quot;: {},\r\n      &quot;arrayA&quot;: [\r\n        &quot;a&quot;\r\n      ],\r\n      &quot;emptyArrayA&quot;: []\r\n    }\r\n\r\nUsing this function gives the result:\r\n\r\n    {\r\n      &quot;notNullA&quot;: &quot;notNullA&quot;,\r\n      &quot;objectA&quot;: {\r\n        &quot;notNullB&quot;: &quot;notNullB&quot;,\r\n        &quot;objectB&quot;: {\r\n          &quot;notNullC&quot;: &quot;notNullC&quot;\r\n        },\r\n        &quot;arrayB&quot;: [\r\n          &quot;b&quot;\r\n        ]\r\n      },\r\n      &quot;arrayA&quot;: [\r\n        &quot;a&quot;\r\n      ]\r\n    }",
                "title": "Remove all null values"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1542672366,
                "last_edit_date": 1542672366,
                "creation_date": 1542670944,
                "answer_id": 53384235,
                "question_id": 39500608,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Elsewhere on this page, some interest has been expressed in\r\nusing jq to eliminate recursively occurrences of [] and {} as well as null.\r\n\r\nAlthough it is possible to use the built-in definition of `walk/1` to do\r\nthis, it is a bit tricky to do so correctly.  Here therefore is a variant version\r\nof `walk/1` which makes it trivial to do so:\r\n\r\n    def traverse(f):\r\n      if type == &quot;object&quot; then map_values(traverse(f)) | f\r\n      elif type == &quot;array&quot; then map( traverse(f) ) | f\r\n      else f\r\n      end;\r\n\r\nIn order to make it easy to modify the criterion for removing elements, \r\nwe define:\r\n\r\n    def isempty: .==null or ((type|(.==&quot;array&quot; or .==&quot;object&quot;)) and length==0);\r\n\r\nThe solution is now simply:\r\n\r\n    traverse(select(isempty|not))\r\n\r\n",
                "title": "Remove all null values"
            },
            {
                "up_vote_count": 9,
                "is_accepted": false,
                "score": 9,
                "last_activity_date": 1568959232,
                "creation_date": 1568959232,
                "answer_id": 58022572,
                "question_id": 39500608,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "All the other answers to date here are workarounds for old versions of `jq`, and it isn&#39;t clear how do do this simply in the latest released version. In JQ 1.6 or newer this will do the job to remove nulls recursively:\r\n\r\n```sh\r\n$ jq &#39;walk( if type == &quot;object&quot; then with_entries(select(.value != null)) else . end)&#39; input.json\r\n```\r\n\r\nSourced from [this comment](https://github.com/stedolan/jq/issues/104#issuecomment-289637207) on the issue where adding the `walk()` function was discussed upstream.",
                "title": "Remove all null values"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1609208471,
                "creation_date": 1609208471,
                "answer_id": 65486516,
                "question_id": 39500608,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "### With newer versions of jq (1.6 and later) \r\nYou can use this expression to remove null-valued keys recursively:\r\n\r\n    jq &#39;walk( if type == &quot;object&quot; then with_entries(select(.value != null)) else . end)&#39;\r\n\r\n[REF](https://github.com/stedolan/jq/issues/104#issuecomment-289637207)",
                "title": "Remove all null values"
            },
            {
                "up_vote_count": 48,
                "is_accepted": false,
                "score": 47,
                "last_activity_date": 1624985256,
                "last_edit_date": 1624985256,
                "creation_date": 1624962593,
                "answer_id": 68176981,
                "question_id": 39500608,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "[This answer](https://unix.stackexchange.com/a/654730) by [Michael Homer](https://unix.stackexchange.com/users/73093/michael-homer) on &lt;https://unix.stackexchange.com&gt; has a super concinse solution which works since jq 1.6:\r\n\r\n    del(..|nulls)\r\n\r\nIt deletes all null-valued properties (and values) from your JSON. Simple and sweet :)\r\n\r\n`nulls` is a builtin filter and can be replaced by custom selects:\r\n\r\n    del(..|select(. == &quot;value to delete&quot;))\r\n\r\nTo remove elements based on multiple conditions, e.g. remove all bools and all numbers:\r\n\r\n    del(..|booleans,numbers)\r\n\r\nor, to only delete nodes not matching a condition:\r\n\r\n    del(..|select(. == &quot;value to keep&quot; | not))\r\n\r\n(The last example is only illustrative – of course you could swap `==` for `!=`, but sometimes this is not possible. e.g. to _keep_ all truthy values: `del(..|select(.|not))`)",
                "title": "Remove all null values"
            }
        ],
        "is_answered": true,
        "answer_count": 8,
        "score": 33,
        "last_activity_date": 1675110912,
        "creation_date": 1473892166,
        "last_edit_date": 1481870991,
        "question_id": 39500608,
        "body_markdown": "I am trying to remove null values from a json object using jq. I found [this issue][1] on their github and so now I&#39;m trying to remove them with `del`.\r\nI have this:\r\n\r\n    &#39;{ id: $customerId, name, phones: ([{ original: .phone }, \r\n     { original: .otherPhone}]), email} | del(. | nulls)&#39;\r\nThis doesn&#39;t seem to do anything. However if I replace `nulls` with `.phones` it does remove the phone numbers.\r\n\r\n\r\n  [1]: https://github.com/stedolan/jq/issues/104 &quot;this&quot;",
        "link": "https://stackoverflow.com/questions/39500608/remove-all-null-values",
        "title": "Remove all null values"
    },
    {
        "tags": [
            "python",
            "json",
            "csv",
            "filtering",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2022758,
                    "reputation": 4161,
                    "user_id": 1808539,
                    "user_type": "registered",
                    "accept_rate": 89,
                    "profile_image": "https://www.gravatar.com/avatar/b3c0605ad8f3bb41c0a75f1d690eb4ce?s=256&d=identicon&r=PG",
                    "display_name": "JosephGarrone",
                    "link": "https://stackoverflow.com/users/1808539/josephgarrone"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1473917632,
                "post_id": 39503715,
                "comment_id": 66324626,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 986936,
                    "reputation": 16689,
                    "user_id": 1005215,
                    "user_type": "registered",
                    "accept_rate": 75,
                    "profile_image": "https://www.gravatar.com/avatar/33a92149e35c60382fa24bcc2b20722e?s=256&d=identicon&r=PG",
                    "display_name": "Nehal J Wani",
                    "link": "https://stackoverflow.com/users/1005215/nehal-j-wani"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1473918249,
                "post_id": 39503715,
                "comment_id": 66324835,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 8259152,
                    "reputation": 374,
                    "user_id": 6211276,
                    "user_type": "registered",
                    "accept_rate": 44,
                    "profile_image": "https://www.gravatar.com/avatar/6582ea732f7d38c98c086137da8e3897?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "SupposeXYZ",
                    "link": "https://stackoverflow.com/users/6211276/supposexyz"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1473918823,
                "post_id": 39503715,
                "comment_id": 66324995,
                "content_license": "CC BY-SA 3.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": 1473920307,
                "post_id": 39503715,
                "comment_id": 66325554,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1473920103,
                "last_edit_date": 1473920103,
                "creation_date": 1473919576,
                "answer_id": 39504085,
                "question_id": 39503715,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "1) Given your input (suitably elaborated to make it valid JSON), the following query generates the CSV output as shown:\r\n\r\n    $ jq -r &#39;.questions[] | [.question, .image_id, .question_id] | @csv&#39;\r\n    \r\n    &quot;What is the table made of?&quot;,350623,3506232\r\n    &quot;Is the food napping on the table?&quot;,350623,3506230\r\n    &quot;What has been upcycled to make lights?&quot;,350623,3506231\r\n    &quot;Is this an Spanish town?&quot;,8647,86472\r\n\r\nThe key thing to remember here is that @csv requires a flat array, but as with all jq filters, you can feed it a stream.\r\n\r\n2) To filter using the criterion `.image_id &lt;= 10000`, just interpose the appropriate `select/1` filter:\r\n\r\n\r\n    .questions[]\r\n    | select(.image_id &lt;= 10000)\r\n    | [.question, .image_id, .question_id]\r\n    | @csv\r\n\r\n3) To sort by image_id, use sort_by(.image_id)\r\n\r\n    .questions\r\n    | sort_by(.image_id)\r\n    |.[]\r\n    | [.question, .image_id, .question_id]\r\n    | @csv\r\n\r\n4) To group by `.image_id` you would pipe the output of the following pipeline into your own pipeline:\r\n\r\n    .questions | group_by(.image_id)\r\n\r\nYou will, however, have to decide exactly how you want to combine the grouped objects.\r\n",
                "title": "Convert json using jq based on specific constraints"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1503898289,
                "creation_date": 1503898289,
                "answer_id": 45912255,
                "question_id": 39503715,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "With the `-r` option, the following filter\r\n\r\n      .questions[] | [ .[] ] | @csv\r\n      \r\nproduces\r\n\r\n    &quot;What is the table made of?&quot;,350623,3506232\r\n    &quot;Is the food napping on the table?&quot;,350623,3506230\r\n    &quot;What has been upcycled to make lights?&quot;,350623,3506231\r\n    &quot;Is this an Spanish town?&quot;,8647,86472\r\n    \r\n\r\nTo filter the data, use **select**.  E.g. with the `-r` option the following filter \r\n\r\n      .questions[] | select(.image_id &lt;= 10000) | [ .[] ] | @csv\r\n\r\nproduces the subset\r\n\r\n    &quot;Is this an Spanish town?&quot;,8647,86472\r\n\r\nTo group the data use **group_by**. The following filter\r\n\r\n        .questions\r\n      | group_by(.image_id)[]\r\n      | [ .[] | [ .[] ] | @csv ]\r\n\r\nproduces grouped data\r\n\r\n    [\r\n      &quot;\\&quot;Is this an Spanish town?\\&quot;,8647,86472&quot;\r\n    ]\r\n    [\r\n      &quot;\\&quot;What is the table made of?\\&quot;,350623,3506232&quot;,\r\n      &quot;\\&quot;Is the food napping on the table?\\&quot;,350623,3506230&quot;,\r\n      &quot;\\&quot;What has been upcycled to make lights?\\&quot;,350623,3506231&quot;\r\n    ]\r\n\r\nThis isn&#39;t very useful in this form and is probably not exactly what you want but it demonstrates the basic approach.",
                "title": "Convert json using jq based on specific constraints"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1503898289,
        "creation_date": 1473917424,
        "last_edit_date": 1474142748,
        "question_id": 39503715,
        "body_markdown": "I have a json file &#39;OpenEnded_mscoco_val2014.json&#39;.The json file contains 121,512 questions.&lt;br&gt;\r\nHere is some sample :\r\n\r\n    &quot;questions&quot;: [\r\n    {\r\n      &quot;question&quot;: &quot;What is the table made of?&quot;,\r\n      &quot;image_id&quot;: 350623,\r\n      &quot;question_id&quot;: 3506232\r\n    },\r\n    {\r\n      &quot;question&quot;: &quot;Is the food napping on the table?&quot;,\r\n      &quot;image_id&quot;: 350623,\r\n      &quot;question_id&quot;: 3506230\r\n    },\r\n    {\r\n      &quot;question&quot;: &quot;What has been upcycled to make lights?&quot;,\r\n      &quot;image_id&quot;: 350623,\r\n      &quot;question_id&quot;: 3506231\r\n    },\r\n    {\r\n      &quot;question&quot;: &quot;Is this an Spanish town?&quot;,\r\n      &quot;image_id&quot;: 8647,\r\n      &quot;question_id&quot;: 86472\r\n    }\r\n]\r\n\r\nI used `jq -r &#39;.questions | [map(.question), map(.image_id), map(.question_id)] | @csv&#39; OpenEnded_mscoco_val2014_questions.json &gt;&gt; temp.csv` to convert json into csv. &lt;br&gt;\r\nBut here output in csv is question followed by image_id which is what above code does.&lt;br&gt;\r\nThe expected output is : \r\n\r\n    &quot;What is table made of&quot;,350623,3506232\r\n    &quot;Is the food napping on the table?&quot;,350623,3506230\r\n\r\nAlso is it possible to filter only results having`image_id &lt;= 10000` and to `group questions having same image_id`? e.g. 1,2,3 result of json can be combined  to have 3 questions, 1 image_id, 3 question_id.\r\n\r\nEDIT : The first problem is solved by `possible duplicate question`.I would like to know if is it possible to invoke comparison operator on command line in jq for converting json file. In this case get all fields from json if `image_id &lt;= 10000` only.",
        "link": "https://stackoverflow.com/questions/39503715/convert-json-using-jq-based-on-specific-constraints",
        "title": "Convert json using jq based on specific constraints"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1474290408,
                "post_id": 39568286,
                "comment_id": 66457639,
                "content_license": "CC BY-SA 3.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": 1474290459,
                "post_id": 39568286,
                "comment_id": 66457686,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1474456929,
                "last_edit_date": 1474456929,
                "creation_date": 1474287708,
                "answer_id": 39573060,
                "question_id": 39568286,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "With one minor exception, you can readily achieve the stated goals using jq as follows:\r\n\r\n    jq -scr &#39;map({id,url,file})\r\n      | group_by(.file)\r\n      | .[]\r\n      | ((map(.id) | @csv) , (map(.url) | @csv), (.[0] | .file))&#39;\r\n\r\nGiven your input, the output would be:\r\n\r\n    4496,4497\r\n    &quot;http://xxx/yyy&quot;,&quot;http://xxx/yyy/zzz&quot;\r\n    /home/build/branches/mmm/file1\r\n    4498\r\n    &quot;http://xxx/yyy/zzz&quot;\r\n    /home/build/branches/mmm/otherfile.c\r\n\r\nYou could then eliminate the quotation marks using a text-editing tool such as `sed`; using another invocation of `jq`; or as described below.  However, this might not be such a great idea if there&#39;s ever any chance that any of the URLs contains a comma.\r\n\r\nHere&#39;s the filter for eliminating the quotation marks with just one invocation of jq:\r\n\r\n    map({id,url,file})\r\n    | group_by(.file)\r\n    | .[]\r\n    | ((map(.id) | @csv),\r\n       ([map(.url) | join(&quot;,&quot;)] | @csv | .[1:-1]),\r\n       (.[0] | .file))\r\n",
                "title": "Bash with JQ grouping"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1502051939,
                "creation_date": 1502051939,
                "answer_id": 45536414,
                "question_id": 39568286,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a solution which uses **group_by** and the `-r`, `-s` jq options:\r\n\r\n      group_by(.file)[]\r\n\r\n    | ([ &quot;\\(.[].id)&quot; ] | join(&quot;,&quot;)),\r\n      ([ .[].url     ] | join(&quot;,&quot;)),\r\n         .[0].file",
                "title": "Bash with JQ grouping"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1502051939,
        "creation_date": 1474272692,
        "last_edit_date": 1474456434,
        "question_id": 39568286,
        "body_markdown": "I have a file with a stream of JSON objects as follows:\r\n\r\n    {&quot;id&quot;:4496,&quot;status&quot;:&quot;Analyze&quot;,&quot;severity&quot;:&quot;Critical&quot;,&quot;severityCode&quot;:1,&quot;state&quot;:&quot;New&quot;,&quot;code&quot;:&quot;RNPD.DEREF&quot;,&quot;title&quot;:&quot;Suspicious dereference of pointer before NULL check&quot;,&quot;message&quot;:&quot;Suspicious dereference of pointer \\u0027peer-\\u003esctSapCb\\u0027 before NULL check at line 516&quot;,&quot;file&quot;:&quot;/home/build/branches/mmm/file1&quot;,&quot;method&quot;:&quot;CzUiCztGpReq&quot;,&quot;owner&quot;:&quot;unowned&quot;,&quot;taxonomyName&quot;:&quot;C and C++&quot;,&quot;dateOriginated&quot;:1473991086512,&quot;url&quot;:&quot;http://xxx/yyy&quot;,&quot;issueIds&quot;:[4494]}\r\n    {&quot;id&quot;:4497,&quot;status&quot;:&quot;Analyze&quot;,&quot;severity&quot;:&quot;Critical&quot;,&quot;severityCode&quot;:1,&quot;state&quot;:&quot;New&quot;,&quot;code&quot;:&quot;NPD.GEN.CALL.MIGHT&quot;,&quot;title&quot;:&quot;Null pointer may be passed to function that may dereference it&quot;,&quot;message&quot;:&quot;Null pointer \\u0027tmpEncodedPdu\\u0027 that comes from line 346 may be passed to function and can be dereferenced there by passing argument 1 to function \\u0027SCpyMsgMsgF\\u0027 at line 537.&quot;,&quot;file&quot;:&quot;/home/build/branches/mmm/file1&quot;,&quot;method&quot;:&quot;CzUiCztGpReq&quot;,&quot;owner&quot;:&quot;unowned&quot;,&quot;taxonomyName&quot;:&quot;C and C++&quot;,&quot;dateOriginated&quot;:1473991086512,&quot;url&quot;:&quot;http://xxx/yyy/zzz&quot;,&quot;issueIds&quot;:[4495]}\r\n    {&quot;id&quot;:4498,&quot;status&quot;:&quot;Analyze&quot;,&quot;severity&quot;:&quot;Critical&quot;,&quot;severityCode&quot;:1,&quot;state&quot;:&quot;New&quot;,&quot;code&quot;:&quot;NPD.GEN.CALL.MIGHT&quot;,&quot;title&quot;:&quot;Null pointer may be passed to function that may dereference it&quot;,&quot;message&quot;:&quot;Null pointer \\u0027tmpEncodedPdu\\u0027 that comes from line 346 may be passed to function and can be dereferenced there by passing argument 1 to function \\u0027SCpyMsgMsgF\\u0027 at line 537.&quot;,&quot;file&quot;:&quot;/home/build/branches/mmm/otherfile.c&quot;,&quot;method&quot;:&quot;CzUiCztGpReq&quot;,&quot;owner&quot;:&quot;unowned&quot;,&quot;taxonomyName&quot;:&quot;C and C++&quot;,&quot;dateOriginated&quot;:1473991086512,&quot;url&quot;:&quot;http://xxx/yyy/zzz&quot;,&quot;issueIds&quot;:[4495]}\r\n\r\nI would like to get with JQ (or in some other way), three lines, one each for the ids, the URLs, and the file name:\r\n\r\nThis is what I have so far:\r\n\r\n    cat /tmp/file.json | ~/bin_compciv/jq --raw-output &#39;.id,.url,.file&#39;\r\n\r\nResult:\r\n\r\n    4496\r\n    http://xxx/yyy\r\n    /home/build/branches/mmm/file1\r\n    .\r\n    .\r\n    .\r\n**BUT** - I would like to group them by file name, so that I will get comma-separated lists of urls and ids on the same line, like this:\r\n\r\n    4496,4497\r\n    http://xxx/yyy,http://xxx/yyy/zzz\r\n    /home/build/branches/mmm/file1\r\n\r\n",
        "link": "https://stackoverflow.com/questions/39568286/bash-with-jq-grouping",
        "title": "Bash with JQ grouping"
    },
    {
        "tags": [
            "json",
            "export-to-csv",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 8696426,
                    "reputation": 1018,
                    "user_id": 6507620,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/nI75J.jpg?s=256",
                    "display_name": "Abhay Dixit",
                    "link": "https://stackoverflow.com/users/6507620/abhay-dixit"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1474471876,
                "post_id": 39620753,
                "comment_id": 66547310,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1474475420,
                "creation_date": 1474475420,
                "answer_id": 39621934,
                "question_id": 39620753,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You could do this:\r\n\r\n    $ jq -r --argjson cols &#39;[&quot;mykey1&quot;,&quot;mykey2&quot;]&#39; &#39;[to_entries[] | .key, (.value | from_entries[$cols[]])] | @csv&#39; input.json\r\n\r\nConverting an object to a list of entries is an easy way to access both the keys and values in the object for your filter.",
                "title": "jq: Forming CSV by selectively choosing values from object/embedded array"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1503899539,
                "creation_date": 1503899539,
                "answer_id": 45912479,
                "question_id": 39620753,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is another solution which generalizes [Surki](https://stackoverflow.com/users/144348/surki)&#39;s approach:\r\n\r\n      keys[] as $k\r\n    | .[$k]\r\n    | from_entries\r\n    | [$k, .mykey1, .mykey2]\r\n    | join(&quot;,&quot;)",
                "title": "jq: Forming CSV by selectively choosing values from object/embedded array"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1503899539,
        "creation_date": 1474471695,
        "last_edit_date": 1474517011,
        "question_id": 39620753,
        "body_markdown": "Input is:\r\n\r\n    {&quot;1.2.3.4&quot;:[{&quot;Value&quot;:&quot;myval1&quot;,&quot;Key&quot;:&quot;mykey1&quot;},   {&quot;Value&quot;:&quot;myval3&quot;,&quot;Key&quot;:&quot;mykey3&quot;},{&quot;Value&quot;:&quot;myval2&quot;,&quot;Key&quot;:&quot;mykey2&quot;},{&quot;Value&quot;:&quot;myval4&quot;,&quot;Key&quot;:&quot;mykey4&quot;}]}\r\n    {&quot;4.5.6.7&quot;:[{&quot;Value&quot;:&quot;myval1&quot;,&quot;Key&quot;:&quot;mykey1&quot;},   {&quot;Value&quot;:&quot;myval3&quot;,&quot;Key&quot;:&quot;mykey3&quot;},{&quot;Value&quot;:&quot;myval2&quot;,&quot;Key&quot;:&quot;mykey2&quot;},{&quot;Value&quot;:&quot;myval4&quot;,&quot;Key&quot;:&quot;mykey4&quot;}]}\r\n\r\nWhat I would like to get is:\r\n\r\n    &quot;1.2.3.4,myval1,myval3&quot;\r\n    &quot;4.5.6.7,myval1,myval3&quot;\r\n\r\nBasically extract the first field, and then values of &quot;mykey1&quot; and &quot;mykey2&quot; from the embedded value field.\r\n\r\nEdit:\r\n\r\nWhat I have tried:\r\n\r\nI could extract the values by doing something like below:\r\n\r\n    jq -c &#39;.&quot;1.2.3.4&quot; | .[]&#39; | jq -s &#39;from_entries | [.mykey1, .mykey2] | join(&quot;,&quot;)&#39;\r\n\r\nI would like to include my object name and as well my object name varies, so I can&#39;t really filter by hard coded value",
        "link": "https://stackoverflow.com/questions/39620753/jq-forming-csv-by-selectively-choosing-values-from-object-embedded-array",
        "title": "jq: Forming CSV by selectively choosing values from object/embedded array"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1474984481,
                "creation_date": 1474984481,
                "answer_id": 39726593,
                "question_id": 39726409,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You can use the following command:\r\n\r\n    jq -r &#39;&quot;Family Name: \\(.family_name)&quot;,(.members[]|&quot;Member Name: \\(.name)&quot;,&quot;Age: \\(.age)&quot;)&#39; file.json",
                "title": "jq - How do I print the entire index of a JSON array in the correct order, instead of printing all of one specific field one after each other?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1474984481,
        "creation_date": 1474984048,
        "question_id": 39726409,
        "body_markdown": "I have the following JSON:\r\n\r\n    {\r\n      &quot;family_name&quot;: &quot;The Brown Family&quot;,\r\n      &quot;members&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;James&quot;,\r\n          &quot;age&quot;: 42\r\n        },  \r\n        {\r\n          &quot;name&quot;: &quot;Sarah&quot;,\r\n          &quot;age&quot;: 43,\r\n        }\r\n      ]\r\n    }\r\n    {\r\n      &quot;family_name&quot;: &quot;The Smith Family&quot;,\r\n      &quot;members&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;Thomas&quot;,\r\n          &quot;age&quot;: 32\r\n        },  \r\n        {\r\n          &quot;name&quot;: &quot;Jane&quot;,\r\n          &quot;age&quot;: 30,\r\n        }\r\n      ]\r\n    } \r\n\r\nI would like to print the family name of each family, then after this print each index contained in &#39;members&#39;. I have tried the following in JQ.\r\n\r\n    echo $myJson | jq -r &#39;&quot;\\(&quot;Family Name: &quot;) \\(.family_name)&quot;, &quot;\\(&quot;Member Name: &quot;) \\(.members[].name)&quot;, &quot;\\(&quot;Age: &quot;) \\(.members[].age)&quot;, &quot;\\n&quot;&#39;\r\n\r\nMy hope was that this would print the following:\r\n\r\n    Family Name: The Brown Family   \r\n    Member Name: James\r\n    Age: 42\r\n    Member Name: Sarah\r\n    Age: 43\r\n    \r\n    Family Name: The Smith Family\r\n    Member Name: Thomas\r\n    Age: 32\r\n    Member Name: Jane\r\n    Age: 30\r\n\r\nHowever, instead it prints:\r\n\r\n    Family Name: The Brown Family   \r\n    Member Name: James\r\n    Member Name: Sarah\r\n    Age: 42\r\n    Age: 43\r\n    \r\n    Family Name: The Smith Family\r\n    Member Name: Thomas\r\n    Member Name: Jane\r\n    Age: 32\r\n    Age: 30\r\n\r\nHow do I change my jq script to produce the correct output in the right order? Thanks.",
        "link": "https://stackoverflow.com/questions/39726409/jq-how-do-i-print-the-entire-index-of-a-json-array-in-the-correct-order-inste",
        "title": "jq - How do I print the entire index of a JSON array in the correct order, instead of printing all of one specific field one after each other?"
    },
    {
        "tags": [
            "javascript",
            "error-handling",
            "type-conversion",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 7,
                "is_accepted": true,
                "score": 7,
                "last_activity_date": 1475002698,
                "last_edit_date": 1475002698,
                "creation_date": 1475001581,
                "answer_id": 39732063,
                "question_id": 39731356,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You can simply write: `tonumber? // .`\r\n\r\nOr as a function:\r\n\r\n    def tonumberq: tonumber? // .;\r\n\r\n",
                "title": "jq: how to convert to number if possible, but leave as is, if not?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1475002698,
        "creation_date": 1474999064,
        "question_id": 39731356,
        "body_markdown": "How can I create some_function in jq that will convert to number if possible, but leave as is if not? e.g.:\r\n\r\n    echo &#39;[&quot;123&quot;,&quot;12x3&quot;]&#39; | jq &#39;.[] | some_function&#39;\r\n\r\nwould return\r\n\r\n    123\r\n    &quot;12x3&quot;\r\n\r\nThe tonumber() function would work fine, if only I could have some fallback in the event of an error. A couple potential solutions could either be to allow error handling e.g. iferror(xxx, result_if_error), or to have some sort of &quot;safe&quot; tonumber() function, but I can&#39;t find a way to get either solution to work in jq. \r\n\r\nFor the error handling approach, I also tried:\r\n\r\n    echo &#39;[&quot;123&quot;,&quot;12x3&quot;]&#39; | jq &#39;map(try tonumber catch .) &#39;\r\n\r\n(as well as the equivalent as a user-defined function) to no avail. I&#39;m guessing there is an easy solution to this problem but I can&#39;t seem to find it.",
        "link": "https://stackoverflow.com/questions/39731356/jq-how-to-convert-to-number-if-possible-but-leave-as-is-if-not",
        "title": "jq: how to convert to number if possible, but leave as is, if not?"
    },
    {
        "tags": [
            "bash",
            "iteration",
            "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"
                },
                "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": 1475080159,
                "post_id": 39736840,
                "comment_id": 66802047,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "reply_to_user": {
                    "account_id": 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": 1475080299,
                "post_id": 39736840,
                "comment_id": 66802137,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "reply_to_user": {
                    "account_id": 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": 1475080881,
                "post_id": 39736840,
                "comment_id": 66802498,
                "content_license": "CC BY-SA 3.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": 1475082028,
                "post_id": 39736840,
                "comment_id": 66803202,
                "content_license": "CC BY-SA 3.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"
                },
                "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": 1475085278,
                "post_id": 39736840,
                "comment_id": 66804965,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1475034455,
                "last_edit_date": 1475034455,
                "creation_date": 1475030027,
                "answer_id": 39737121,
                "question_id": 39736840,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "1. I&#39;m afraid your question isn&#39;t very clear.  If you want to produce the values for consumption by some tool or application other than jq, then it would be helpful to know what that tool expects.  If you want to use the values in jq itself, then you could use `map` or `reduce`; alternatively, you could use a filter having the form: `.[] | ...` or `[.[] ...]`, where the `...` is some jq code that accesses the values of interest, e.g.\r\n\r\n        [.[] | [.OutputKey, .OutputValue] ]\r\n\r\n2.  If you want to perform some reduction operation, then you will probably want to use the form: `reduce .[] as $x (_; _)`\r\n\r\n3. There are other alternatives, depending on what it is you are trying to do. \r\n    \r\n",
                "title": "Loop through JSON object using jq"
            },
            {
                "up_vote_count": 13,
                "is_accepted": true,
                "score": 13,
                "last_activity_date": 1495225115,
                "last_edit_date": 1495225115,
                "creation_date": 1475033899,
                "answer_id": 39737623,
                "question_id": 39736840,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Assuming your content is coming from `in.json`:\r\n\r\n    #!/usr/bin/env bash\r\n    case $BASH_VERSION in (&quot;&quot;|[123].*) echo &quot;Bash 4.0 or newer required&quot; &gt;&amp;2; exit 1;; esac\r\n\r\n    declare -A values=( ) descriptions=( )\r\n\r\n    while IFS= read -r description &amp;&amp;\r\n          IFS= read -r key &amp;&amp;\r\n          IFS= read -r value; do\r\n      values[$key]=$value\r\n      descriptions[$key]=$description\r\n      echo &quot;Read key $key, with value $value and description $description&quot; &gt;&amp;2\r\n    done &lt; &lt;(jq -r &#39;.[] | (.Description, .OutputKey, .OutputValue)&#39; &lt;in.json)\r\n\r\nGiven your input, this emits the following to stderr:\r\n\r\n&lt;!-- language: none --&gt;\r\n\r\n    Read key OutputKey 1, with value OutputValue 1 and description Description 1\r\n    Read key OutputKey 2, with value OutputValue 2 and description Description 2\r\n    Read key OutputKey 3, with value OutputValue 3 and description Description 3\r\n    Read key OutputKey 4, with value OutputValue 4 and description Description 4\r\n    Read key OutputKey 5, with value OutputValue 5 and description Description 5\r\n    Read key OutputKey 6, with value OutputValue 6 and description Description 6\r\n\r\nMoreover, after this code is run, you can then execute:\r\n\r\n    key_to_look_up=&quot;OutputKey 1&quot;\r\n    echo &quot;${values[$key_to_look_up]}&quot;\r\n    echo &quot;${descriptions[$key_to_look_up]}&quot;\r\n\r\n...and get as output:\r\n\r\n&lt;!-- language: none --&gt;\r\n\r\n    OutputValue 1\r\n    Description 1",
                "title": "Loop through JSON object using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 3,
        "last_activity_date": 1495225115,
        "creation_date": 1475027746,
        "last_edit_date": 1475038678,
        "question_id": 39736840,
        "body_markdown": "This is what my JSON array of objects looks like:\r\n\r\n    [\r\n        {\r\n            &quot;Description&quot;: &quot;Description 1&quot;,\r\n            &quot;OutputKey&quot;: &quot;OutputKey 1&quot;,\r\n            &quot;OutputValue&quot;: &quot;OutputValue 1&quot;\r\n        },\r\n        {\r\n            &quot;Description&quot;: &quot;Description 2&quot;,\r\n            &quot;OutputKey&quot;: &quot;OutputKey 2&quot;,\r\n            &quot;OutputValue&quot;: &quot;OutputValue 2&quot;\r\n        },\r\n        {\r\n            &quot;Description&quot;: &quot;Description 3&quot;,\r\n            &quot;OutputKey&quot;: &quot;OutputKey 3&quot;,\r\n            &quot;OutputValue&quot;: &quot;OutputValue 3&quot;\r\n        },\r\n        {\r\n            &quot;Description&quot;: &quot;Description 4&quot;,\r\n            &quot;OutputKey&quot;: &quot;OutputKey 4&quot;,\r\n            &quot;OutputValue&quot;: &quot;OutputValue 4&quot;\r\n        },\r\n        {\r\n            &quot;Description&quot;: &quot;Description 5&quot;,\r\n            &quot;OutputKey&quot;: &quot;OutputKey 5&quot;,\r\n            &quot;OutputValue&quot;: &quot;OutputValue 5&quot;\r\n        },\r\n        {\r\n            &quot;Description&quot;: &quot;Description 6&quot;,\r\n            &quot;OutputKey&quot;: &quot;OutputKey 6&quot;,\r\n            &quot;OutputValue&quot;: &quot;OutputValue 6&quot;\r\n        }\r\n    ]\r\n\r\nHow do i iterate over this using jq so that i can use the values of OutputKey and OutputValue in other commands?\r\n",
        "link": "https://stackoverflow.com/questions/39736840/loop-through-json-object-using-jq",
        "title": "Loop through JSON object using jq"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3228322,
                    "reputation": 2431,
                    "user_id": 2724125,
                    "user_type": "registered",
                    "accept_rate": 80,
                    "profile_image": "https://i.sstatic.net/KlwGM.jpg?s=256",
                    "display_name": "Amit G",
                    "link": "https://stackoverflow.com/users/2724125/amit-g"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1475041730,
                "post_id": 39738230,
                "comment_id": 66775458,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1475041737,
                "creation_date": 1475041737,
                "answer_id": 39738959,
                "question_id": 39738230,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The fields that you&#39;re interested in are in the `data` objects of each of the `children`.  You&#39;ll want to keep them together so you should limit how many times you go through the child items, just do it once.  And it seems you&#39;re outputting in a CSV format, so you could use `@csv` for that.  Just put the properties in an array first.\r\n\r\n    $ curl ... | jq -r &#39;.data.children[].data | [.title, .url, .score] | @csv",
                "title": "Specifying the order of jq results"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1475041936,
        "creation_date": 1475037936,
        "last_edit_date": 1475041936,
        "question_id": 39738230,
        "body_markdown": "I want to process some json from reddit: https://www.reddit.com/r/videos/top.json?limit=3\r\n\r\n    {\r\n      &quot;kind&quot;: &quot;Listing&quot;,\r\n      &quot;data&quot;: {\r\n        &quot;modhash&quot;: &quot;&quot;,\r\n        &quot;children&quot;: [\r\n          {\r\n            &quot;kind&quot;: &quot;t3&quot;,\r\n            &quot;data&quot;: {\r\n              &quot;contest_mode&quot;: false,\r\n              &quot;banned_by&quot;: null,\r\n              &quot;domain&quot;: &quot;youtube.com&quot;,\r\n              &quot;subreddit&quot;: &quot;videos&quot;,\r\n              &quot;selftext_html&quot;: null,\r\n              &quot;selftext&quot;: &quot;&quot;,\r\n              &quot;likes&quot;: null,\r\n              &quot;suggested_sort&quot;: null,\r\n              &quot;user_reports&quot;: [],\r\n              &quot;secure_media&quot;: {\r\n                &quot;oembed&quot;: {\r\n                  &quot;provider_url&quot;: &quot;https://www.youtube.com/&quot;,\r\n                  &quot;version&quot;: &quot;1.0&quot;,\r\n                  &quot;title&quot;: &quot;SpaceX Interplanetary Transport System&quot;,\r\n                  &quot;thumbnail_width&quot;: 480,\r\n                  &quot;height&quot;: 338,\r\n                  &quot;width&quot;: 600,\r\n                  &quot;html&quot;: &quot;&amp;lt;iframe width=\\&quot;600\\&quot; height=\\&quot;338\\&quot; src=\\&quot;https://www.youtube.com/embed/0qo78R_yYFA?feature=oembed\\&quot; frameborder=\\&quot;0\\&quot; allowfullscreen&amp;gt;&amp;lt;/iframe&amp;gt;&quot;,\r\n                  &quot;author_name&quot;: &quot;SpaceX&quot;,\r\n                  &quot;thumbnail_height&quot;: 360,\r\n                  &quot;thumbnail_url&quot;: &quot;https://i.ytimg.com/vi/0qo78R_yYFA/hqdefault.jpg&quot;,\r\n                  &quot;type&quot;: &quot;video&quot;,\r\n                  &quot;provider_name&quot;: &quot;YouTube&quot;,\r\n                  &quot;author_url&quot;: &quot;https://www.youtube.com/user/spacexchannel&quot;\r\n                },\r\n                &quot;type&quot;: &quot;youtube.com&quot;\r\n              },\r\n              &quot;saved&quot;: false,\r\n              &quot;id&quot;: &quot;54rrjl&quot;,\r\n              &quot;gilded&quot;: 0,\r\n              &quot;secure_media_embed&quot;: {\r\n                &quot;content&quot;: &quot;&amp;lt;iframe width=\\&quot;600\\&quot; height=\\&quot;338\\&quot; src=\\&quot;https://www.youtube.com/embed/0qo78R_yYFA?feature=oembed\\&quot; frameborder=\\&quot;0\\&quot; allowfullscreen&amp;gt;&amp;lt;/iframe&amp;gt;&quot;,\r\n                &quot;width&quot;: 600,\r\n                &quot;scrolling&quot;: false,\r\n                &quot;height&quot;: 338\r\n              },\r\n              &quot;clicked&quot;: false,\r\n              &quot;report_reasons&quot;: null,\r\n              &quot;author&quot;: &quot;jclishman&quot;,\r\n              &quot;media&quot;: {\r\n                &quot;oembed&quot;: {\r\n                  &quot;provider_url&quot;: &quot;https://www.youtube.com/&quot;,\r\n                  &quot;version&quot;: &quot;1.0&quot;,\r\n                  &quot;title&quot;: &quot;SpaceX Interplanetary Transport System&quot;,\r\n                  &quot;thumbnail_width&quot;: 480,\r\n                  &quot;height&quot;: 338,\r\n                  &quot;width&quot;: 600,\r\n                  &quot;html&quot;: &quot;&amp;lt;iframe width=\\&quot;600\\&quot; height=\\&quot;338\\&quot; src=\\&quot;https://www.youtube.com/embed/0qo78R_yYFA?feature=oembed\\&quot; frameborder=\\&quot;0\\&quot; allowfullscreen&amp;gt;&amp;lt;/iframe&amp;gt;&quot;,\r\n                  &quot;author_name&quot;: &quot;SpaceX&quot;,\r\n                  &quot;thumbnail_height&quot;: 360,\r\n                  &quot;thumbnail_url&quot;: &quot;https://i.ytimg.com/vi/0qo78R_yYFA/hqdefault.jpg&quot;,\r\n                  &quot;type&quot;: &quot;video&quot;,\r\n                  &quot;provider_name&quot;: &quot;YouTube&quot;,\r\n                  &quot;author_url&quot;: &quot;https://www.youtube.com/user/spacexchannel&quot;\r\n                },\r\n                &quot;type&quot;: &quot;youtube.com&quot;\r\n              },\r\n              &quot;name&quot;: &quot;t3_54rrjl&quot;,\r\n              &quot;score&quot;: 4947,\r\n              &quot;approved_by&quot;: null,\r\n              &quot;over_18&quot;: false,\r\n              &quot;removal_reason&quot;: null,\r\n              &quot;hidden&quot;: false,\r\n              &quot;preview&quot;: {\r\n                &quot;images&quot;: [\r\n                  {\r\n                    &quot;source&quot;: {\r\n                      &quot;url&quot;: &quot;https://i.redditmedia.com/UmxPKXyvkXx8ap0ugxIgFu2yB00xZPrnR80zTb-kRlc.jpg?s=bdeffae704dbca1cf477f09608479cd9&quot;,\r\n                      &quot;width&quot;: 480,\r\n                      &quot;height&quot;: 360\r\n                    },\r\n                    &quot;resolutions&quot;: [\r\n                      {\r\n                        &quot;url&quot;: &quot;https://i.redditmedia.com/UmxPKXyvkXx8ap0ugxIgFu2yB00xZPrnR80zTb-kRlc.jpg?fit=crop&amp;amp;crop=faces%2Centropy&amp;amp;arh=2&amp;amp;w=108&amp;amp;s=45a9e73c27ba9d344b75793ac6951567&quot;,\r\n                        &quot;width&quot;: 108,\r\n                        &quot;height&quot;: 81\r\n                      },\r\n                      {\r\n                        &quot;url&quot;: &quot;https://i.redditmedia.com/UmxPKXyvkXx8ap0ugxIgFu2yB00xZPrnR80zTb-kRlc.jpg?fit=crop&amp;amp;crop=faces%2Centropy&amp;amp;arh=2&amp;amp;w=216&amp;amp;s=a59e97b76b1347e2f26333ec2c7d50c1&quot;,\r\n                        &quot;width&quot;: 216,\r\n                        &quot;height&quot;: 162\r\n                      },\r\n                      {\r\n                        &quot;url&quot;: &quot;https://i.redditmedia.com/UmxPKXyvkXx8ap0ugxIgFu2yB00xZPrnR80zTb-kRlc.jpg?fit=crop&amp;amp;crop=faces%2Centropy&amp;amp;arh=2&amp;amp;w=320&amp;amp;s=631ddd2156d83ee7fec1c6f4c98c5c4b&quot;,\r\n                        &quot;width&quot;: 320,\r\n                        &quot;height&quot;: 240\r\n                      }\r\n                    ],\r\n                    &quot;variants&quot;: {},\r\n                    &quot;id&quot;: &quot;0sz_ShT1IlShzb117hpblwELVvmEgpD3n_WCpw94VN4&quot;\r\n                  }\r\n                ]\r\n              },\r\n              &quot;thumbnail&quot;: &quot;http://b.thumbs.redditmedia.com/TLG2iK4WvyVntpjBcKPIyRinq2zKEvOuK8z0klQhmvY.jpg&quot;,\r\n              &quot;subreddit_id&quot;: &quot;t5_2qh1e&quot;,\r\n              &quot;edited&quot;: false,\r\n              &quot;link_flair_css_class&quot;: null,\r\n              &quot;author_flair_css_class&quot;: null,\r\n              &quot;downs&quot;: 0,\r\n              &quot;mod_reports&quot;: [],\r\n              &quot;archived&quot;: false,\r\n              &quot;media_embed&quot;: {\r\n                &quot;content&quot;: &quot;&amp;lt;iframe width=\\&quot;600\\&quot; height=\\&quot;338\\&quot; src=\\&quot;https://www.youtube.com/embed/0qo78R_yYFA?feature=oembed\\&quot; frameborder=\\&quot;0\\&quot; allowfullscreen&amp;gt;&amp;lt;/iframe&amp;gt;&quot;,\r\n                &quot;width&quot;: 600,\r\n                &quot;scrolling&quot;: false,\r\n                &quot;height&quot;: 338\r\n              },\r\n              &quot;post_hint&quot;: &quot;rich:video&quot;,\r\n              &quot;is_self&quot;: false,\r\n              &quot;hide_score&quot;: false,\r\n              &quot;permalink&quot;: &quot;/r/videos/comments/54rrjl/spacex_interplanetary_transport_system/&quot;,\r\n              &quot;locked&quot;: false,\r\n              &quot;stickied&quot;: false,\r\n              &quot;created&quot;: 1475026717,\r\n              &quot;url&quot;: &quot;https://www.youtube.com/watch?v=0qo78R_yYFA&quot;,\r\n              &quot;author_flair_text&quot;: null,\r\n              &quot;quarantine&quot;: false,\r\n              &quot;title&quot;: &quot;SpaceX Interplanetary Transport System&quot;,\r\n              &quot;created_utc&quot;: 1474997917,\r\n              &quot;link_flair_text&quot;: null,\r\n              &quot;distinguished&quot;: null,\r\n              &quot;num_comments&quot;: 1077,\r\n              &quot;visited&quot;: false,\r\n              &quot;num_reports&quot;: null,\r\n              &quot;ups&quot;: 4947\r\n            }\r\n          },\r\n          {\r\n            &quot;kind&quot;: &quot;t3&quot;,\r\n            &quot;data&quot;: {\r\n              &quot;contest_mode&quot;: false,\r\n              &quot;banned_by&quot;: null,\r\n              &quot;domain&quot;: &quot;youtube.com&quot;,\r\n              &quot;subreddit&quot;: &quot;videos&quot;,\r\n              &quot;selftext_html&quot;: null,\r\n              &quot;selftext&quot;: &quot;&quot;,\r\n              &quot;likes&quot;: null,\r\n              &quot;suggested_sort&quot;: null,\r\n              &quot;user_reports&quot;: [],\r\n              &quot;secure_media&quot;: {\r\n                &quot;type&quot;: &quot;youtube.com&quot;,\r\n                &quot;oembed&quot;: {\r\n                  &quot;provider_url&quot;: &quot;https://www.youtube.com/&quot;,\r\n                  &quot;title&quot;: &quot;35 years Backwards thru Time with Sam Klemke (Time Lapse)&quot;,\r\n                  &quot;type&quot;: &quot;video&quot;,\r\n                  &quot;html&quot;: &quot;&amp;lt;iframe width=\\&quot;459\\&quot; height=\\&quot;344\\&quot; src=\\&quot;https://www.youtube.com/embed/K2xTBHyfOks?feature=oembed\\&quot; frameborder=\\&quot;0\\&quot; allowfullscreen&amp;gt;&amp;lt;/iframe&amp;gt;&quot;,\r\n                  &quot;thumbnail_width&quot;: 480,\r\n                  &quot;height&quot;: 344,\r\n                  &quot;width&quot;: 459,\r\n                  &quot;version&quot;: &quot;1.0&quot;,\r\n                  &quot;author_name&quot;: &quot;MisterEsoteric&quot;,\r\n                  &quot;thumbnail_height&quot;: 360,\r\n                  &quot;thumbnail_url&quot;: &quot;https://i.ytimg.com/vi/K2xTBHyfOks/hqdefault.jpg&quot;,\r\n                  &quot;provider_name&quot;: &quot;YouTube&quot;,\r\n                  &quot;author_url&quot;: &quot;https://www.youtube.com/user/MisterEsoteric&quot;\r\n                }\r\n              },\r\n              &quot;saved&quot;: false,\r\n              &quot;id&quot;: &quot;54r1gh&quot;,\r\n              &quot;gilded&quot;: 0,\r\n              &quot;secure_media_embed&quot;: {\r\n                &quot;content&quot;: &quot;&amp;lt;iframe width=\\&quot;459\\&quot; height=\\&quot;344\\&quot; src=\\&quot;https://www.youtube.com/embed/K2xTBHyfOks?feature=oembed\\&quot; frameborder=\\&quot;0\\&quot; allowfullscreen&amp;gt;&amp;lt;/iframe&amp;gt;&quot;,\r\n                &quot;width&quot;: 459,\r\n                &quot;scrolling&quot;: false,\r\n                &quot;height&quot;: 344\r\n              },\r\n              &quot;clicked&quot;: false,\r\n              &quot;report_reasons&quot;: null,\r\n              &quot;author&quot;: &quot;a_shootin_star&quot;,\r\n              &quot;media&quot;: {\r\n                &quot;type&quot;: &quot;youtube.com&quot;,\r\n                &quot;oembed&quot;: {\r\n                  &quot;provider_url&quot;: &quot;https://www.youtube.com/&quot;,\r\n                  &quot;title&quot;: &quot;35 years Backwards thru Time with Sam Klemke (Time Lapse)&quot;,\r\n                  &quot;type&quot;: &quot;video&quot;,\r\n                  &quot;html&quot;: &quot;&amp;lt;iframe width=\\&quot;459\\&quot; height=\\&quot;344\\&quot; src=\\&quot;https://www.youtube.com/embed/K2xTBHyfOks?feature=oembed\\&quot; frameborder=\\&quot;0\\&quot; allowfullscreen&amp;gt;&amp;lt;/iframe&amp;gt;&quot;,\r\n                  &quot;thumbnail_width&quot;: 480,\r\n                  &quot;height&quot;: 344,\r\n                  &quot;width&quot;: 459,\r\n                  &quot;version&quot;: &quot;1.0&quot;,\r\n                  &quot;author_name&quot;: &quot;MisterEsoteric&quot;,\r\n                  &quot;thumbnail_height&quot;: 360,\r\n                  &quot;thumbnail_url&quot;: &quot;https://i.ytimg.com/vi/K2xTBHyfOks/hqdefault.jpg&quot;,\r\n                  &quot;provider_name&quot;: &quot;YouTube&quot;,\r\n                  &quot;author_url&quot;: &quot;https://www.youtube.com/user/MisterEsoteric&quot;\r\n                }\r\n              },\r\n              &quot;name&quot;: &quot;t3_54r1gh&quot;,\r\n              &quot;score&quot;: 4631,\r\n              &quot;approved_by&quot;: null,\r\n              &quot;over_18&quot;: false,\r\n              &quot;removal_reason&quot;: null,\r\n              &quot;hidden&quot;: false,\r\n              &quot;preview&quot;: {\r\n                &quot;images&quot;: [\r\n                  {\r\n                    &quot;source&quot;: {\r\n                      &quot;url&quot;: &quot;https://i.redditmedia.com/ff7YtFDYgwsOuge92mnUE4rUT2fnJOctQJ6nJgMZoj8.jpg?s=21cd790f369febedcece048a2dc33714&quot;,\r\n                      &quot;width&quot;: 480,\r\n                      &quot;height&quot;: 360\r\n                    },\r\n                    &quot;resolutions&quot;: [\r\n                      {\r\n                        &quot;url&quot;: &quot;https://i.redditmedia.com/ff7YtFDYgwsOuge92mnUE4rUT2fnJOctQJ6nJgMZoj8.jpg?fit=crop&amp;amp;crop=faces%2Centropy&amp;amp;arh=2&amp;amp;w=108&amp;amp;s=42827db4a8eef7d90c8fd35339f134c8&quot;,\r\n                        &quot;width&quot;: 108,\r\n                        &quot;height&quot;: 81\r\n                      },\r\n                      {\r\n                        &quot;url&quot;: &quot;https://i.redditmedia.com/ff7YtFDYgwsOuge92mnUE4rUT2fnJOctQJ6nJgMZoj8.jpg?fit=crop&amp;amp;crop=faces%2Centropy&amp;amp;arh=2&amp;amp;w=216&amp;amp;s=a33acbee6c5ea92382fa5c7c0f76979c&quot;,\r\n                        &quot;width&quot;: 216,\r\n                        &quot;height&quot;: 162\r\n                      },\r\n                      {\r\n                        &quot;url&quot;: &quot;https://i.redditmedia.com/ff7YtFDYgwsOuge92mnUE4rUT2fnJOctQJ6nJgMZoj8.jpg?fit=crop&amp;amp;crop=faces%2Centropy&amp;amp;arh=2&amp;amp;w=320&amp;amp;s=c7c2a52e55089b17da7fc0d35c57b484&quot;,\r\n                        &quot;width&quot;: 320,\r\n                        &quot;height&quot;: 240\r\n                      }\r\n                    ],\r\n                    &quot;variants&quot;: {},\r\n                    &quot;id&quot;: &quot;fLOkvXgiEKsZnefFoNcOTKy0x6dk9ODi6cLVi9MMHGo&quot;\r\n                  }\r\n                ]\r\n              },\r\n              &quot;thumbnail&quot;: &quot;http://b.thumbs.redditmedia.com/RZUqE22jXxl1xbkqptl99WMkyLwYxXOjTSgd-Uy7nAE.jpg&quot;,\r\n              &quot;subreddit_id&quot;: &quot;t5_2qh1e&quot;,\r\n              &quot;edited&quot;: false,\r\n              &quot;link_flair_css_class&quot;: null,\r\n              &quot;author_flair_css_class&quot;: null,\r\n              &quot;downs&quot;: 0,\r\n              &quot;mod_reports&quot;: [],\r\n              &quot;archived&quot;: false,\r\n              &quot;media_embed&quot;: {\r\n                &quot;content&quot;: &quot;&amp;lt;iframe width=\\&quot;459\\&quot; height=\\&quot;344\\&quot; src=\\&quot;https://www.youtube.com/embed/K2xTBHyfOks?feature=oembed\\&quot; frameborder=\\&quot;0\\&quot; allowfullscreen&amp;gt;&amp;lt;/iframe&amp;gt;&quot;,\r\n                &quot;width&quot;: 459,\r\n                &quot;scrolling&quot;: false,\r\n                &quot;height&quot;: 344\r\n              },\r\n              &quot;post_hint&quot;: &quot;rich:video&quot;,\r\n              &quot;is_self&quot;: false,\r\n              &quot;hide_score&quot;: false,\r\n              &quot;permalink&quot;: &quot;/r/videos/comments/54r1gh/there_is_a_man_who_filmed_himself_annually_for_35/&quot;,\r\n              &quot;locked&quot;: false,\r\n              &quot;stickied&quot;: false,\r\n              &quot;created&quot;: 1475018163,\r\n              &quot;url&quot;: &quot;https://www.youtube.com/watch?v=K2xTBHyfOks&quot;,\r\n              &quot;author_flair_text&quot;: null,\r\n              &quot;quarantine&quot;: false,\r\n              &quot;title&quot;: &quot;There is a man who filmed himself annually for 35 years and made a video going backwards to 1977. [ORIGINAL] - [06:31]&quot;,\r\n              &quot;created_utc&quot;: 1474989363,\r\n              &quot;link_flair_text&quot;: null,\r\n              &quot;distinguished&quot;: null,\r\n              &quot;num_comments&quot;: 1345,\r\n              &quot;visited&quot;: false,\r\n              &quot;num_reports&quot;: null,\r\n              &quot;ups&quot;: 4631\r\n            }\r\n          },\r\n          {\r\n            &quot;kind&quot;: &quot;t3&quot;,\r\n            &quot;data&quot;: {\r\n              &quot;contest_mode&quot;: false,\r\n              &quot;banned_by&quot;: null,\r\n              &quot;domain&quot;: &quot;youtube.com&quot;,\r\n              &quot;subreddit&quot;: &quot;videos&quot;,\r\n              &quot;selftext_html&quot;: null,\r\n              &quot;selftext&quot;: &quot;&quot;,\r\n              &quot;likes&quot;: null,\r\n              &quot;suggested_sort&quot;: null,\r\n              &quot;user_reports&quot;: [],\r\n              &quot;secure_media&quot;: {\r\n                &quot;type&quot;: &quot;youtube.com&quot;,\r\n                &quot;oembed&quot;: {\r\n                  &quot;provider_url&quot;: &quot;https://www.youtube.com/&quot;,\r\n                  &quot;version&quot;: &quot;1.0&quot;,\r\n                  &quot;title&quot;: &quot;How Patton Oswalt &amp;amp; His Daughter Are Coping With His Wife&#39;s Passing  - CONAN on TBS&quot;,\r\n                  &quot;author_name&quot;: &quot;Team Coco&quot;,\r\n                  &quot;height&quot;: 338,\r\n                  &quot;width&quot;: 600,\r\n                  &quot;html&quot;: &quot;&amp;lt;iframe width=\\&quot;600\\&quot; height=\\&quot;338\\&quot; src=\\&quot;https://www.youtube.com/embed/iuLKSvoK8KA?feature=oembed\\&quot; frameborder=\\&quot;0\\&quot; allowfullscreen&amp;gt;&amp;lt;/iframe&amp;gt;&quot;,\r\n                  &quot;thumbnail_width&quot;: 480,\r\n                  &quot;thumbnail_height&quot;: 360,\r\n                  &quot;thumbnail_url&quot;: &quot;https://i.ytimg.com/vi/iuLKSvoK8KA/hqdefault.jpg&quot;,\r\n                  &quot;type&quot;: &quot;video&quot;,\r\n                  &quot;provider_name&quot;: &quot;YouTube&quot;,\r\n                  &quot;author_url&quot;: &quot;https://www.youtube.com/user/teamcoco&quot;\r\n                }\r\n              },\r\n              &quot;saved&quot;: false,\r\n              &quot;id&quot;: &quot;54s0sm&quot;,\r\n              &quot;gilded&quot;: 0,\r\n              &quot;secure_media_embed&quot;: {\r\n                &quot;content&quot;: &quot;&amp;lt;iframe width=\\&quot;600\\&quot; height=\\&quot;338\\&quot; src=\\&quot;https://www.youtube.com/embed/iuLKSvoK8KA?feature=oembed\\&quot; frameborder=\\&quot;0\\&quot; allowfullscreen&amp;gt;&amp;lt;/iframe&amp;gt;&quot;,\r\n                &quot;width&quot;: 600,\r\n                &quot;scrolling&quot;: false,\r\n                &quot;height&quot;: 338\r\n              },\r\n              &quot;clicked&quot;: false,\r\n              &quot;report_reasons&quot;: null,\r\n              &quot;author&quot;: &quot;bruhfamsquad&quot;,\r\n              &quot;media&quot;: {\r\n                &quot;type&quot;: &quot;youtube.com&quot;,\r\n                &quot;oembed&quot;: {\r\n                  &quot;provider_url&quot;: &quot;https://www.youtube.com/&quot;,\r\n                  &quot;version&quot;: &quot;1.0&quot;,\r\n                  &quot;title&quot;: &quot;How Patton Oswalt &amp;amp; His Daughter Are Coping With His Wife&#39;s Passing  - CONAN on TBS&quot;,\r\n                  &quot;author_name&quot;: &quot;Team Coco&quot;,\r\n                  &quot;height&quot;: 338,\r\n                  &quot;width&quot;: 600,\r\n                  &quot;html&quot;: &quot;&amp;lt;iframe width=\\&quot;600\\&quot; height=\\&quot;338\\&quot; src=\\&quot;https://www.youtube.com/embed/iuLKSvoK8KA?feature=oembed\\&quot; frameborder=\\&quot;0\\&quot; allowfullscreen&amp;gt;&amp;lt;/iframe&amp;gt;&quot;,\r\n                  &quot;thumbnail_width&quot;: 480,\r\n                  &quot;thumbnail_height&quot;: 360,\r\n                  &quot;thumbnail_url&quot;: &quot;https://i.ytimg.com/vi/iuLKSvoK8KA/hqdefault.jpg&quot;,\r\n                  &quot;type&quot;: &quot;video&quot;,\r\n                  &quot;provider_name&quot;: &quot;YouTube&quot;,\r\n                  &quot;author_url&quot;: &quot;https://www.youtube.com/user/teamcoco&quot;\r\n                }\r\n              },\r\n              &quot;name&quot;: &quot;t3_54s0sm&quot;,\r\n              &quot;score&quot;: 3732,\r\n              &quot;approved_by&quot;: null,\r\n              &quot;over_18&quot;: false,\r\n              &quot;removal_reason&quot;: null,\r\n              &quot;hidden&quot;: false,\r\n              &quot;preview&quot;: {\r\n                &quot;images&quot;: [\r\n                  {\r\n                    &quot;source&quot;: {\r\n                      &quot;url&quot;: &quot;https://i.redditmedia.com/mY4uWOaN90_K5IMcDhz_FtmLtZFyGQZYiMNeSljv9xs.jpg?s=e0fa03c1cfbec29d8d4a2745fea0094c&quot;,\r\n                      &quot;width&quot;: 480,\r\n                      &quot;height&quot;: 360\r\n                    },\r\n                    &quot;resolutions&quot;: [\r\n                      {\r\n                        &quot;url&quot;: &quot;https://i.redditmedia.com/mY4uWOaN90_K5IMcDhz_FtmLtZFyGQZYiMNeSljv9xs.jpg?fit=crop&amp;amp;crop=faces%2Centropy&amp;amp;arh=2&amp;amp;w=108&amp;amp;s=c51d04dbef9f3121ec0955d6f7be6cbd&quot;,\r\n                        &quot;width&quot;: 108,\r\n                        &quot;height&quot;: 81\r\n                      },\r\n                      {\r\n                        &quot;url&quot;: &quot;https://i.redditmedia.com/mY4uWOaN90_K5IMcDhz_FtmLtZFyGQZYiMNeSljv9xs.jpg?fit=crop&amp;amp;crop=faces%2Centropy&amp;amp;arh=2&amp;amp;w=216&amp;amp;s=f0e15bfd6bc17745be698e670de399f9&quot;,\r\n                        &quot;width&quot;: 216,\r\n                        &quot;height&quot;: 162\r\n                      },\r\n                      {\r\n                        &quot;url&quot;: &quot;https://i.redditmedia.com/mY4uWOaN90_K5IMcDhz_FtmLtZFyGQZYiMNeSljv9xs.jpg?fit=crop&amp;amp;crop=faces%2Centropy&amp;amp;arh=2&amp;amp;w=320&amp;amp;s=648cdbd8af77fa7b6542a038e6f8fc86&quot;,\r\n                        &quot;width&quot;: 320,\r\n                        &quot;height&quot;: 240\r\n                      }\r\n                    ],\r\n                    &quot;variants&quot;: {},\r\n                    &quot;id&quot;: &quot;JAjE3xovazbxxz0FI8I3lwu2TWLLRVxOg6hPeoDPrWI&quot;\r\n                  }\r\n                ]\r\n              },\r\n              &quot;thumbnail&quot;: &quot;http://b.thumbs.redditmedia.com/R89XcpIkm4e6NqHhiNzE6JmPU6kxVibipzbesVYg6oY.jpg&quot;,\r\n              &quot;subreddit_id&quot;: &quot;t5_2qh1e&quot;,\r\n              &quot;edited&quot;: false,\r\n              &quot;link_flair_css_class&quot;: null,\r\n              &quot;author_flair_css_class&quot;: null,\r\n              &quot;downs&quot;: 0,\r\n              &quot;mod_reports&quot;: [],\r\n              &quot;archived&quot;: false,\r\n              &quot;media_embed&quot;: {\r\n                &quot;content&quot;: &quot;&amp;lt;iframe width=\\&quot;600\\&quot; height=\\&quot;338\\&quot; src=\\&quot;https://www.youtube.com/embed/iuLKSvoK8KA?feature=oembed\\&quot; frameborder=\\&quot;0\\&quot; allowfullscreen&amp;gt;&amp;lt;/iframe&amp;gt;&quot;,\r\n                &quot;width&quot;: 600,\r\n                &quot;scrolling&quot;: false,\r\n                &quot;height&quot;: 338\r\n              },\r\n              &quot;post_hint&quot;: &quot;rich:video&quot;,\r\n              &quot;is_self&quot;: false,\r\n              &quot;hide_score&quot;: false,\r\n              &quot;permalink&quot;: &quot;/r/videos/comments/54s0sm/how_patton_oswalt_his_daughter_are_coping_with/&quot;,\r\n              &quot;locked&quot;: false,\r\n              &quot;stickied&quot;: false,\r\n              &quot;created&quot;: 1475029674,\r\n              &quot;url&quot;: &quot;https://www.youtube.com/watch?v=iuLKSvoK8KA&quot;,\r\n              &quot;author_flair_text&quot;: null,\r\n              &quot;quarantine&quot;: false,\r\n              &quot;title&quot;: &quot;How Patton Oswalt &amp;amp; His Daughter Are Coping With His Wife&#39;s Passing&quot;,\r\n              &quot;created_utc&quot;: 1475000874,\r\n              &quot;link_flair_text&quot;: null,\r\n              &quot;distinguished&quot;: null,\r\n              &quot;num_comments&quot;: 565,\r\n              &quot;visited&quot;: false,\r\n              &quot;num_reports&quot;: null,\r\n              &quot;ups&quot;: 3732\r\n            }\r\n          }\r\n        ],\r\n        &quot;after&quot;: &quot;t3_54s0sm&quot;,\r\n        &quot;before&quot;: null\r\n      }\r\n    }\r\n\r\n&lt;!-- --&gt;\r\n\r\n    $ curl https://www.reddit.com/r/videos/top.json\\?limit\\=3 | \\\r\n    jq -r &#39;(.data.children|.[].data.title),(.data.children|.[].data.url),(.data.children|.[].data.score)&#39;\r\n\r\nIt produces the following output:\r\n\r\n    SpaceX Interplanetary Transport System\r\n    There is a man who filmed himself annually for 35 years and made a video going backwards to 1977. [ORIGINAL] - [06:31]\r\n    Japanese men trying to pronounce &quot;Massachusetts&quot;\r\n    https://www.youtube.com/watch?v=0qo78R_yYFA\r\n    https://www.youtube.com/watch?v=K2xTBHyfOks\r\n    https://www.youtube.com/watch?v=69iSXks1bes\r\n    4874\r\n    4644\r\n    5075\r\n\r\nI want to get the following output:\r\n\r\n    SpaceX Interplanetary Transport System, https://www.youtube.com/watch?v=0qo78R_yYFA, 4874\r\n    There is a man who filmed himself annually for 35 years and made a video going backwards to 1977. [ORIGINAL] - [06:31], https://www.youtube.com/watch?v=K2xTBHyfOks, 4644\r\n    Japanese men trying to pronounce &quot;Massachusetts&quot;, https://www.youtube.com/watch?v=69iSXks1bes, 5075\r\n\r\nHow can I adjust the way that the results are returned?\r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/39738230/specifying-the-order-of-jq-results",
        "title": "Specifying the order of jq results"
    },
    {
        "tags": [
            "javascript",
            "arrays",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1475047702,
                "creation_date": 1475047702,
                "answer_id": 39740762,
                "question_id": 39739195,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Is it doable? Of course!\r\n\r\nFirst you&#39;ll want to group the data by rows then columns.  Then with the groups, build your values/sources arrays.\r\n\r\n    .headers as $headers | .data\r\n        # make the data easier to access\r\n        | map({ row: .[0], col: .[1], val: .[2], src: .[3] })\r\n        # keep it sorted so they are in expected order in the end\r\n        | sort_by([.row,.col,.src])\r\n        # group by rows\r\n        | group_by(.row)\r\n        # create a map to each of the cols for easier access\r\n        | map(group_by(.col)\r\n            | reduce .[] as $col ({};\r\n                .[$col[0].col] = [$col[] | {val,src}]\r\n            )\r\n        )\r\n        # build the result\r\n        | {\r\n            headers: $headers,\r\n            values: map([.[$headers[]] | [.[]?.val]]),\r\n            sources: map([.[$headers[]] | [.[]?.src]])\r\n        }\r\n\r\nThis will produce the following result:\r\n\r\n    {\r\n      &quot;headers&quot;: [ &quot;col1&quot;, &quot;col2&quot;, &quot;col3&quot; ],\r\n      &quot;values&quot;: [\r\n        [\r\n          [ &quot;b&quot;, &quot;b&quot;, &quot;b&quot; ],\r\n          [ &quot;d&quot;, &quot;e&quot;, &quot;f&quot; ],\r\n          [ &quot;i&quot;, &quot;j&quot;, &quot;g&quot;, &quot;h&quot; ]\r\n        ],\r\n        [\r\n          [ &quot;j&quot;, &quot;k&quot;, &quot;l&quot; ],\r\n          [],\r\n          [ &quot;o&quot; ]\r\n        ]\r\n      ],\r\n      &quot;sources&quot;: [\r\n        [\r\n          [ &quot;src1&quot;, &quot;src2&quot;, &quot;src3&quot; ],\r\n          [ &quot;src4&quot;, &quot;src5&quot;, &quot;src6&quot; ],\r\n          [ &quot;src10&quot;, &quot;src7&quot;, &quot;src8&quot;, &quot;src9&quot; ]\r\n        ],\r\n        [\r\n          [ &quot;src11&quot;, &quot;src12&quot;, &quot;src13&quot; ],\r\n          [],\r\n          [ &quot;src15&quot; ]\r\n        ]\r\n      ]\r\n    }\r\n\r\n",
                "title": "using jq to break array of elements into multiple arrays of varying length"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1693939994,
                "last_edit_date": 1693939994,
                "creation_date": 1475094803,
                "answer_id": 39757147,
                "question_id": 39739195,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Since the primary data source here can be thought of as a\r\ntwo-dimensional matrix, it may be worth considering a\r\nmatrix-oriented approach to the problem, especially if it is\r\nintended that empty rows in the input matrix are not simply omitted, or if\r\nthe number of columns in the matrix is not initially known.\r\n\r\nTo spice things up a little, let&#39;s choose to represent an m x n\r\nmatrix, M, as a JSON array of the form [m, n, a] where a is an array\r\nof arrays, such that a[i][j] is the element of M in row i, column j.\r\n\r\nFirst, let&#39;s define some basic matrix-oriented operations:\r\n\r\n    def ij(i;j): .[2][i][j];\r\n\r\n    def set_ij(i;j;value):\r\n      def max(a;b): if a &lt; b then b else a end;\r\n      .[0] as $m | .[1] as $n\r\n      | [max(i+1;$m), max(j+1;$n), (.[2] | setpath([i,j];value)) ];\r\n\r\n\r\nThe data source uses strings of the form &quot;rowI&quot; for row i\r\nand &quot;colJ&quot; for row j, so we define a matrix-update function accordingly:\r\n\r\n    def update_row_col( row; col; value):\r\n      ((row|sub(&quot;^row&quot;;&quot;&quot;)|tonumber) - 1) as $r\r\n       | ((col|sub(&quot;^col&quot;;&quot;&quot;)|tonumber) - 1) as $c\r\n       | ij($r;$c) as $v\r\n       | set_ij($r; $c; if $v == null then [value] else $v + [value] end) ;\r\n\r\n\r\nGiven an array of items of the form [&quot;rowI&quot;,&quot;colJ&quot;, V, S],\r\ngenerate a matrix with the value {&quot;source&quot;: S, &quot;value&quot;: V} at row I\r\nand column J:\r\n\r\n    def generate:\r\n      reduce .[] as $x ([0,0,null];\r\n        update_row_col( $x[0];  $x[1]; { &quot;source&quot;: $x[3], &quot;value&quot;: $x[2] }) );\r\n\r\nNow we turn to the desired output.  The following filter will extract f from the input matrix, producing an array of arrays, replacing [] with null:\r\n\r\n    def extract(f):\r\n      . as $m\r\n      | (reduce range(0; $m[0]) as $i\r\n          ([];\r\n           . + ( reduce range(0; $m[1]) as $j\r\n                ([];\r\n\t         . + [ $m | ij($i;$j) // [] | map(f) ]) ) ))\r\n      | map( if length == 0 then null else . end );\r\n\r\nPutting it all together (generating the headers dynamically is left as an exercise for the interested reader):\r\n\r\n    {headers} +\r\n      (.data | generate\r\n       | { &quot;values&quot;: extract(.value), &quot;sources&quot;: extract(.source) } )\r\n\r\n\r\n\r\nOutput:\r\n  \r\n```json\r\n{\r\n  &quot;headers&quot;: [\r\n    &quot;col1&quot;,\r\n    &quot;col2&quot;,\r\n    &quot;col3&quot;\r\n  ],\r\n  &quot;values&quot;: [\r\n    [\r\n      &quot;b&quot;,\r\n      &quot;b&quot;,\r\n      &quot;b&quot;\r\n    ],\r\n    [\r\n      &quot;d&quot;,\r\n      &quot;e&quot;,\r\n      &quot;f&quot;\r\n    ],\r\n    [\r\n      &quot;j&quot;,\r\n      &quot;g&quot;,\r\n      &quot;h&quot;,\r\n      &quot;i&quot;\r\n    ],\r\n    [\r\n      &quot;l&quot;,\r\n      &quot;j&quot;,\r\n      &quot;k&quot;\r\n    ],\r\n    null,\r\n    [\r\n      &quot;o&quot;\r\n    ]\r\n  ],\r\n  &quot;sources&quot;: [\r\n    [\r\n      &quot;src2&quot;,\r\n      &quot;src1&quot;,\r\n      &quot;src3&quot;\r\n    ],\r\n    [\r\n      &quot;src4&quot;,\r\n      &quot;src5&quot;,\r\n      &quot;src6&quot;\r\n    ],\r\n    [\r\n      &quot;src7&quot;,\r\n      &quot;src8&quot;,\r\n      &quot;src9&quot;,\r\n      &quot;src10&quot;\r\n    ],\r\n    [\r\n      &quot;src13&quot;,\r\n      &quot;src11&quot;,\r\n      &quot;src12&quot;\r\n    ],\r\n    null,\r\n    [\r\n      &quot;src15&quot;\r\n    ]\r\n  ]\r\n}\r\n```\r\n",
                "title": "using jq to break array of elements into multiple arrays of varying length"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1503904647,
                "last_edit_date": 1503904647,
                "creation_date": 1503904330,
                "answer_id": 45913554,
                "question_id": 39739195,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a solution that uses **reduce**, **getpath** and **setpath**\r\n\r\n      .headers as $headers\r\n    | reduce .data[] as [$r,$c,$v,$s] (\r\n        {headers:$headers, values:{}, sources:{}}\r\n      ; setpath([&quot;values&quot;,  $r, $c]; (getpath([&quot;values&quot;, $r, $c])  // []) + [$v])\r\n      | setpath([&quot;sources&quot;, $r, $c]; (getpath([&quot;sources&quot;, $r, $c]) // []) + [$s])\r\n      )\r\n    | .values  = [ .values[]  | [ .[ $headers[] ] ] ]\r\n    | .sources = [ .sources[] | [ .[ $headers[] ] ] ]\r\n\r\n\r\n\r\nSample output (manually reformatted for readability)\r\n    \r\n    {\r\n     &quot;headers&quot;:[&quot;col1&quot;,&quot;col2&quot;,&quot;col3&quot;],\r\n     &quot;values&quot;:[[[&quot;b&quot;,&quot;b&quot;,&quot;b&quot;],[&quot;d&quot;,&quot;e&quot;,&quot;f&quot;],[&quot;j&quot;,&quot;g&quot;,&quot;h&quot;,&quot;i&quot;]],\r\n               [[&quot;l&quot;,&quot;j&quot;,&quot;k&quot;],null,[&quot;o&quot;]]],\r\n     &quot;sources&quot;:[[[&quot;src2&quot;,&quot;src1&quot;,&quot;src3&quot;],[&quot;src4&quot;,&quot;src5&quot;,&quot;src6&quot;],[&quot;src7&quot;,&quot;src8&quot;,&quot;src9&quot;,&quot;src10&quot;]],\r\n                [[&quot;src13&quot;,&quot;src11&quot;,&quot;src12&quot;],null,[&quot;src15&quot;]]]\r\n    }",
                "title": "using jq to break array of elements into multiple arrays of varying length"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1693939994,
        "creation_date": 1475042781,
        "last_edit_date": 1475215362,
        "question_id": 39739195,
        "body_markdown": "I have a JSON object that I&#39;d like to transform using jq from one form to another (of course, I could use javascript or python and iterate, but jq would be preferable). The issue is that the input contains long arrays that needs to be broken into multiple smaller arrays whenever data stops repeating within the first array. I&#39;m not really sure how to describe this problem so I&#39;ll just put an example out here which is hopefully more explanatory. The one safe assumption-- if it is of any help-- is that the input data is always pre-sorted on the first two elements (e.g. &quot;row_x&quot; and &quot;col_y&quot;):\r\n\r\ninput:\r\n\r\n    {\r\n      &quot;headers&quot;: [ &quot;col1&quot;, &quot;col2&quot;, &quot;col3&quot; ],\r\n      &quot;data&quot;: [\r\n        [ &quot;row1&quot;,&quot;col1&quot;,&quot;b&quot;,&quot;src2&quot; ],\r\n        [ &quot;row1&quot;,&quot;col1&quot;,&quot;b&quot;,&quot;src1&quot; ],\r\n        [ &quot;row1&quot;,&quot;col1&quot;,&quot;b&quot;,&quot;src3&quot; ],\r\n        [ &quot;row1&quot;,&quot;col2&quot;,&quot;d&quot;,&quot;src4&quot; ],\r\n        [ &quot;row1&quot;,&quot;col2&quot;,&quot;e&quot;,&quot;src5&quot; ],\r\n        [ &quot;row1&quot;,&quot;col2&quot;,&quot;f&quot;,&quot;src6&quot; ],\r\n        [ &quot;row1&quot;,&quot;col3&quot;,&quot;j&quot;,&quot;src7&quot; ],\r\n        [ &quot;row1&quot;,&quot;col3&quot;,&quot;g&quot;,&quot;src8&quot; ],\r\n        [ &quot;row1&quot;,&quot;col3&quot;,&quot;h&quot;,&quot;src9&quot; ],\r\n        [ &quot;row1&quot;,&quot;col3&quot;,&quot;i&quot;,&quot;src10&quot; ],\r\n        [ &quot;row2&quot;,&quot;col1&quot;,&quot;l&quot;,&quot;src13&quot; ],\r\n        [ &quot;row2&quot;,&quot;col1&quot;,&quot;j&quot;,&quot;src11&quot; ],\r\n        [ &quot;row2&quot;,&quot;col1&quot;,&quot;k&quot;,&quot;src12&quot; ],\r\n        [ &quot;row2&quot;,&quot;col3&quot;,&quot;o&quot;,&quot;src15&quot; ]\r\n      ]\r\n    }\r\n\r\ndesired output:\r\n\r\n    {\r\n      &quot;headers&quot;: [ &quot;col1&quot;, &quot;col2&quot;, &quot;col3&quot; ],\r\n      &quot;values&quot;: [\r\n        [[&quot;b&quot;,&quot;b&quot;,&quot;b&quot;],[&quot;d&quot;,&quot;e&quot;,&quot;f&quot;],[&quot;g&quot;,&quot;h&quot;,&quot;i&quot;,&quot;j&quot;]],\r\n        [[&quot;j&quot;,&quot;k&quot;,&quot;l&quot;],null,[&quot;o&quot;]]\r\n      ],\r\n      &quot;sources&quot;: [\r\n        [[&quot;src1&quot;,&quot;src2&quot;,&quot;src3&quot;],[&quot;src4&quot;,&quot;src5&quot;,&quot;src6&quot;],[&quot;src7&quot;,&quot;src8&quot;,&quot;src9&quot;,&quot;src10&quot;]],\r\n        [[&quot;src11&quot;,&quot;src12&quot;,&quot;src13&quot;],null,[&quot;src15&quot;]]\r\n      ]\r\n    }\r\n\r\nIs this doable at all in jq?\r\n\r\nUPDATE: a variant of this is to retain the original data order, so the output is as follows:\r\n\r\n    {\r\n      &quot;headers&quot;: [ &quot;col1&quot;, &quot;col2&quot;, &quot;col3&quot; ],\r\n      &quot;values&quot;: [\r\n        [[&quot;b&quot;,&quot;b&quot;,&quot;b&quot;],[&quot;d&quot;,&quot;e&quot;,&quot;f&quot;],[&quot;j&quot;,&quot;g&quot;,&quot;h&quot;,&quot;i&quot;]],\r\n        [[&quot;l&quot;,&quot;j&quot;,&quot;k&quot;],null,[&quot;o&quot;]]\r\n      ],\r\n      &quot;sources&quot;: [\r\n        [[&quot;src2&quot;,&quot;src1&quot;,&quot;src3&quot;],[&quot;src4&quot;,&quot;src5&quot;,&quot;src6&quot;],[&quot;src7&quot;,&quot;src8&quot;,&quot;src9&quot;,&quot;src10&quot;]],\r\n        [[&quot;src13&quot;,&quot;src11&quot;,&quot;src12&quot;],null,[&quot;src15&quot;]]\r\n      ]\r\n    }\r\n",
        "link": "https://stackoverflow.com/questions/39739195/using-jq-to-break-array-of-elements-into-multiple-arrays-of-varying-length",
        "title": "using jq to break array of elements into multiple arrays of varying length"
    },
    {
        "tags": [
            "csv",
            "export-to-csv",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1475085741,
                "last_edit_date": 1475085741,
                "creation_date": 1475081155,
                "answer_id": 39753305,
                "question_id": 39746314,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Just use the `-r` command-line option for &quot;raw output&quot;.  As in: `jq -r ...`\r\n\r\np.s. If you ever find yourself having to lop off quotation marks from the beginning and ending of lines, that too can be done using jq. With jq version 1.4 or later:\r\n\r\n    jq -R -r &#39;.[1:-1]&#39;",
                "title": "@csv formatting without quoting entire line for lists containing only numbers?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1475085741,
        "creation_date": 1475062580,
        "question_id": 39746314,
        "body_markdown": "When trying to output lists using csv formatting, I end up with having quotes around the entire line. Is there a way to get rid of those just using `jq` without resorting to other tools? Example below:\r\n\r\nI have a json string:\r\n\r\n    {&quot;stat&quot;: {&quot;foo&quot;: 1.2, &quot;bar&quot;: 3.1}}\r\n\r\nI apply the following jq command to it:\r\n\r\n    $ jq &#39;.stat | [.foo, .bar] | @csv&#39; test.json\r\n\r\nThe resulting stdout will be:\r\n\r\n    &quot;1.2,3.1&quot;\r\n\r\nNow, I can fix this by applying a combination of `rev` and `cut`, but if possible, I would like to skip that step:\r\n\r\n    rev | cut -c2- | rev | cut -c2-\r\n\r\n",
        "link": "https://stackoverflow.com/questions/39746314/csv-formatting-without-quoting-entire-line-for-lists-containing-only-numbers",
        "title": "@csv formatting without quoting entire line for lists containing only numbers?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1475081762,
                "creation_date": 1475081762,
                "answer_id": 39753484,
                "question_id": 39752829,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "There are several possible answers, depending on which version of jq you have, so here I&#39;ll focus on a generic and generally useful answer.\r\n\r\n1.  Use the `-s` (&quot;slurp&quot;) option to get the second JSON entity, as in `jq -s &#39;.[1]&#39;`\r\n\r\n2. In jq 1.4 and later, the jq filter `.[]` when used on objects preserves the order of the keys.  (Using jq 1.3, you may be out of luck if you do not know anything about the key names.)  For example, using jq 1.4 or later:\r\n\r\n```\r\n    $ jq &#39;.[]&#39;\r\n    {&quot;b&quot;:1, &quot;a&quot;:2}\r\n    1\r\n    2\r\n```",
                "title": "Handling multiple &quot;elements&quot; in one JSON file with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1475081762,
        "creation_date": 1475079683,
        "question_id": 39752829,
        "body_markdown": "I have a JSON-file which consists of multiple JSON-&quot;elements&quot;, e.g.\r\n\r\n    {\r\n      &quot;name&quot;: &quot;Name 1&quot;,\r\n      &quot;foo&quot;: &quot;Bar&quot;\r\n    }\r\n    {\r\n      &quot;id&quot;: 123,\r\n      &quot;bar&quot;: &quot;Foo&quot;\r\n    }\r\n\r\nI&#39;m only interested in the second element and I need to query by the &#39;index&#39; of the element (i.e. I do not know what fields the element will contain).\r\n\r\nHow do I achieve this with `jq`?",
        "link": "https://stackoverflow.com/questions/39752829/handling-multiple-elements-in-one-json-file-with-jq",
        "title": "Handling multiple &quot;elements&quot; in one JSON file with jq"
    },
    {
        "tags": [
            "python",
            "python-3.4",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1001458,
                    "reputation": 27390,
                    "user_id": 1016216,
                    "user_type": "registered",
                    "accept_rate": 67,
                    "profile_image": "https://i.sstatic.net/xF5Ew.png?s=256",
                    "display_name": "L3viathan",
                    "link": "https://stackoverflow.com/users/1016216/l3viathan"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1475109789,
                "post_id": 39759649,
                "comment_id": 66815239,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 3480007,
                    "reputation": 23309,
                    "user_id": 2912340,
                    "user_type": "registered",
                    "accept_rate": 44,
                    "profile_image": "https://i.sstatic.net/ddQ02.jpg?s=256",
                    "display_name": "Łukasz Rogalski",
                    "link": "https://stackoverflow.com/users/2912340/%c5%81ukasz-rogalski"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1475109836,
                "post_id": 39759649,
                "comment_id": 66815252,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 3900197,
                    "reputation": 1205,
                    "user_id": 3228230,
                    "user_type": "registered",
                    "accept_rate": 56,
                    "profile_image": "https://i.sstatic.net/m9lny.jpg?s=256",
                    "display_name": "paperduck",
                    "link": "https://stackoverflow.com/users/3228230/paperduck"
                },
                "reply_to_user": {
                    "account_id": 3480007,
                    "reputation": 23309,
                    "user_id": 2912340,
                    "user_type": "registered",
                    "accept_rate": 44,
                    "profile_image": "https://i.sstatic.net/ddQ02.jpg?s=256",
                    "display_name": "Łukasz Rogalski",
                    "link": "https://stackoverflow.com/users/2912340/%c5%81ukasz-rogalski"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1475129374,
                "post_id": 39759649,
                "comment_id": 66820323,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1475109803,
                "creation_date": 1475109803,
                "answer_id": 39759669,
                "question_id": 39759649,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "`pip search` searches through *available* packages. To list *installed* packages, use `pip list`.\r\n\r\nTry installing the `jq` module with `pip install jq`.",
                "title": "Why can&#39;t my Python program find the jq module?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1475109803,
        "creation_date": 1475109577,
        "question_id": 39759649,
        "body_markdown": "I try to use the Python jq module:\r\n\r\n    #!/usr/bin/python3\r\n    # Python 3.4\r\n    \r\n    #--------------------------\r\n    import datetime\r\n    import sys\r\n    import urllib.request\r\n    import urllib.error\r\n    import time\r\n    from jq import jq\r\n\r\nWhen I run it on the command line:\r\n\r\n    # ./daemon.py\r\n\r\nit says this:\r\n\r\n    Traceback (most recent call last):\r\n      File &quot;./daemon.py&quot;, line 10, in &lt;module&gt;\r\n        from jq import jq\r\n    ImportError: No module named &#39;jq&#39;\r\n\r\nList of installed python packages:\r\n\r\n    # pip search jq \r\n\r\nshows this:\r\n\r\n    ...\r\n    jq (0.1.6)         - jq is a lightweight and flexible JSON processor.\r\n    ...\r\n    \r\nSo why can&#39;t my program import the jq module?",
        "link": "https://stackoverflow.com/questions/39759649/why-cant-my-python-program-find-the-jq-module",
        "title": "Why can&#39;t my Python program find the jq module?"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 166270,
                    "reputation": 135171,
                    "user_id": 390278,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/84715fec547362389d02f5be0ed12814?s=256&d=identicon&r=PG",
                    "display_name": "Jeff Mercado",
                    "link": "https://stackoverflow.com/users/390278/jeff-mercado"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1475113968,
                "post_id": 39760071,
                "comment_id": 66816015,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 19417,
                    "reputation": 39168,
                    "user_id": 45525,
                    "user_type": "registered",
                    "accept_rate": 83,
                    "profile_image": "https://i.sstatic.net/TKzgD.png?s=256",
                    "display_name": "Synesso",
                    "link": "https://stackoverflow.com/users/45525/synesso"
                },
                "reply_to_user": {
                    "account_id": 166270,
                    "reputation": 135171,
                    "user_id": 390278,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/84715fec547362389d02f5be0ed12814?s=256&d=identicon&r=PG",
                    "display_name": "Jeff Mercado",
                    "link": "https://stackoverflow.com/users/390278/jeff-mercado"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1475114018,
                "post_id": 39760071,
                "comment_id": 66816028,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 463401,
                    "reputation": 602,
                    "user_id": 6096046,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/c899d982dde4860797f9268a8bdb0df5?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "dwks",
                    "link": "https://stackoverflow.com/users/6096046/dwks"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1475114339,
                "post_id": 39760071,
                "comment_id": 66816088,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1475213381,
                "last_edit_date": 1475213381,
                "creation_date": 1475114627,
                "answer_id": 39760240,
                "question_id": 39760071,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "If your jq has `input_line_number`, you might be able to use that.  Here is a typescript illustrating what it does:\r\n\r\n    $ jq &#39;input_line_number&#39;\r\n    &quot;a&quot;\r\n    1\r\n    &quot;b&quot;\r\n    2\r\n\r\n(In the above, the input line is immediately followed by the output line.)\r\n  \r\nSimilarly, here is how `foreach` and `inputs` can be used together:\r\n\r\n    $ jq -n &#39;foreach inputs as $line (0; .+1; &quot;line \\(.) is \\($line)&quot;)&#39;\r\n    &quot;abc&quot;\r\n    &quot;line 1 is abc&quot;\r\n    123\r\n    &quot;line 2 is 123&quot;\r\n\r\n\r\n\r\nIf your jq does not have `foreach`, then you might find `reduce` adequate for your needs:\r\n\r\n    $ jq -s -r &#39;reduce .[] as $line\r\n        ( [0,&quot;&quot;]; .[0]+=1 | .[1] += &quot;line \\(.[0]) is \\($line)\\n&quot;)\r\n        | .[1]&#39;\r\n\r\nInput:\r\n\r\n    &quot;abc&quot;\r\n    123\r\n\r\nOutput:\r\n\r\n    line 1 is abc\r\n    line 2 is 123\r\n\r\n\r\n",
                "title": "Get line number (count of newlines) when piping in bash"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1475213381,
        "creation_date": 1475113302,
        "last_edit_date": 1475114057,
        "question_id": 39760071,
        "body_markdown": "I am converting a file of json documents to a file of differently shaped json documents using jq. I need the output documents to have a contiguous positive id. Can I access a variable that equals the number of newlines seen?\r\n\r\n    gzcat input.gz | jq -r &#39;&quot;{\\&quot;id\\&quot;:???, \\&quot;foo\\&quot;:\\(.foo)}&quot;&#39; &gt; output\r\n    # can anything take the place of ??? to give 0..n?",
        "link": "https://stackoverflow.com/questions/39760071/get-line-number-count-of-newlines-when-piping-in-bash",
        "title": "Get line number (count of newlines) when piping in bash"
    },
    {
        "tags": [
            "json",
            "csv",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 113371,
                    "reputation": 104439,
                    "user_id": 298607,
                    "user_type": "registered",
                    "accept_rate": 88,
                    "profile_image": "https://i.sstatic.net/DVW9g.jpg?s=256",
                    "display_name": "dawg",
                    "link": "https://stackoverflow.com/users/298607/dawg"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1475116766,
                "post_id": 39760503,
                "comment_id": 66816652,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1495263327,
                "last_edit_date": 1495263327,
                "creation_date": 1475124897,
                "answer_id": 39761689,
                "question_id": 39760503,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "With your input, and the following program in tocsv.jq:\r\n\r\n    (keys_unsorted | join(&quot;,&quot;)),\r\n    ([.[]] | @csv)\r\n\r\nthe command:\r\n\r\n    $ jq -r -f tocsv.jq input.json\r\n\r\nproduces:\r\n\r\n    Timestamp,DateTime,CustomerId,VisitorId\r\n    140,&quot;2014-06-02 14:32:34.440 PDT&quot;,&quot;01&quot;,&quot;78&quot;\r\n\r\nEliminating the quotation marks in the second line is left as an exercise for the interested reader :-)  [Hint: use `join(&quot;,&quot;)` again.]\r\n\r\n\r\nWARNING: the above program is intended only for jq version 1.5 or later. When using an earlier version of jq, using `to_entries` or explicitly specifying the key names may be required.",
                "title": "I am converting my Json data to .CSV format using Jq but unable to run it"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1495263513,
        "creation_date": 1475116680,
        "last_edit_date": 1495263513,
        "question_id": 39760503,
        "body_markdown": "**Input :-**\r\n\r\n     {&quot;Timestamp&quot;:140,\r\n      &quot;DateTime&quot;:&quot;2014-06-02 14:32:34.440 PDT&quot;,\r\n      &quot;CustomerId&quot;:&quot;01&quot;,\r\n      &quot;VisitorId&quot;:&quot;78&quot;}\r\n     \r\n**Desired Output**\r\n\r\n    Timestamp; DateTime;  CustomerId; VisitorId\r\n    140;       2014-06-02 14:32:34.440 PDT; 01; 78\r\n\r\n**I tried the following code**:- \r\n\r\n    results.txt\r\n    | (map(keys) | add | unique) as $cols\r\n    | map(. as $row | $cols | map($row[.])) as $rows\r\n    | $cols, $rows[] | @csv\r\n\r\n**Error:-**\r\n&#39;add&#39; is not recognized as an internal or external command,\r\noperable program or batch file.&quot;\r\n\r\nI don&#39;t know what is wrong. I am using window platform with cygwin.\r\n",
        "link": "https://stackoverflow.com/questions/39760503/i-am-converting-my-json-data-to-csv-format-using-jq-but-unable-to-run-it",
        "title": "I am converting my Json data to .CSV format using Jq but unable to run it"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1475165007,
                "creation_date": 1475165007,
                "answer_id": 39775084,
                "question_id": 39773649,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": ".version is inside .build, so the direct approach would be to write: `.build | .version`, or `.build.version` for short.\r\n\r\nIf in general you don&#39;t know exactly where the object of interest lives, you can also use the `..` filter, e.g. `.. | objects | .version // empty`.",
                "title": "jq returns null when executed from linux commandline"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1475172249,
        "creation_date": 1475160936,
        "last_edit_date": 1475172249,
        "question_id": 39773649,
        "body_markdown": "I have a json text as below\r\n\r\n    {\r\n      &quot;_links&quot;: {\r\n        &quot;self&quot;: {\r\n          &quot;href&quot;: &quot;http://xxx:8080/info&quot;\r\n        }\r\n      },\r\n      &quot;build&quot;: {\r\n        &quot;name&quot;: &quot;xxxx&quot;,\r\n        &quot;version&quot;: &quot;2.0.23-69&quot;,\r\n        &quot;description&quot;: &quot;xxxx&quot;\r\n      }\r\n    }\r\n\r\niam trying to get the version from the above json by using the below command\r\n\r\n    cat info.txt|jq  .version\r\nbut this is returning null.\r\nhow can i get the version as 2.0.23-69\r\n",
        "link": "https://stackoverflow.com/questions/39773649/jq-returns-null-when-executed-from-linux-commandline",
        "title": "jq returns null when executed from linux commandline"
    },
    {
        "tags": [
            "json",
            "amazon-s3",
            "amazon-redshift",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 7,
                "is_accepted": true,
                "score": 7,
                "last_activity_date": 1475736933,
                "last_edit_date": 1475736933,
                "creation_date": 1475220648,
                "answer_id": 39786031,
                "question_id": 39785343,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "the following will achieve what you want\r\n\r\n    aws s3api list-objects \\\r\n        --bucket &lt;mybucket&gt; \\\r\n        --prefix &quot;&lt;myprefix&gt;&quot; \\\r\n        --output json \\\r\n        --query &#39;{&quot;entries&quot;: Contents[].{&quot;url&quot;:&quot;Key&quot;}}&#39; \\\r\n    | jq &#39;.entries[] | .url = &quot;s3://&lt;mybucket&gt;/\\(.entries.url)&quot; | .mandatory = true&#39;\r\n\r\nI am using [String interpolation](https://stedolan.github.io/jq/manual/#Stringinterpolation-%5C%28foo%29) to update the `entries[].url` values",
                "title": "jq to prefix a string in a json object with a string"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1649185502,
                "last_edit_date": 1649185502,
                "creation_date": 1649174380,
                "answer_id": 71754975,
                "question_id": 39785343,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This below works perfectly fine for me. The above suggestion did not give comma separated dictionary \r\n\r\n```\r\naws s3api list-objects \\\r\n--bucket &quot;xxxxx-xxxxxxx-xxx&quot; \\\r\n--output json \\\r\n--query &quot;{&quot;entries&quot;: Contents[?LastModified&gt;=&#39;YYYY-MM-DD&#39; &amp;&amp; contains(Key,&#39;somestring&#39;) ].{&quot;url&quot;:&quot;Key&quot;}}&quot; \\\r\n| jq &#39;[.entries[] | .url = &quot;s3://xxxxx-xxxxxx-xxx/\\(.url)&quot; | .mandatory = true] | { entries: .}&#39; &gt; test_jq1.json\r\n\r\nI am not able to add content_length to the above solution as below with &quot;meta&quot; as dictionary.  Any help is greatly appreciated \r\n\r\n{\r\n  &quot;entries&quot;: [\r\n    {\r\n      &quot;url&quot;:&quot;s3://my-bucket/file1.parquet&quot;,\r\n      &quot;mandatory&quot;:true,\r\n      &quot;meta&quot;:{\r\n        &quot;content_length&quot;:2893394\r\n      }\r\n    },\r\n    {\r\n      &quot;url&quot;:&quot;s3://my-bucket/file2.parquet&quot;,\r\n      &quot;mandatory&quot;:true,\r\n      &quot;meta&quot;:{\r\n        &quot;content_length&quot;:2883626\r\n      }\r\n    }\r\n  ]\r\n}",
                "title": "jq to prefix a string in a json object with a string"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 3,
        "last_activity_date": 1649185502,
        "creation_date": 1475218156,
        "last_edit_date": 1475218846,
        "question_id": 39785343,
        "body_markdown": "I am looking to generate a manifest file for a Redshift `COPY` with a combination of `aws s3api --list-objects` and `jq` as below:-\r\n\r\n    aws s3api list-objects --bucket annalects3 --prefix &quot;DFA/20160926/394007-OMD-Coles/dcm_account394007_impression&quot; --output json --query &#39;{&quot;entries&quot;: Contents[].{&quot;url&quot;:&quot;Key&quot;}}&#39; | jq &#39;.entries[].mandatory = true&#39;\r\n\r\nwhich generates an output like below:-\r\n\r\n        {   &quot;entries&quot;: [\r\n            {\r\n              &quot;mandatory&quot;: true,\r\n              &quot;url&quot;: &quot;DFA/20160926/394007-OMD-Coles/dcm_account394007_impression_2016092507_20160926_002328_292527438.csv.gz&quot;\r\n            },\r\n            {\r\n              &quot;mandatory&quot;: true,\r\n              &quot;url&quot;: &quot;DFA/20160926/394007-OMD-Coles/dcm_account394007_impression_2016092508_20160926_020131_292592736.csv.gz&quot;\r\n            },\r\n            {\r\n              &quot;mandatory&quot;: true,\r\n              &quot;url&quot;: &quot;DFA/20160926/394007-OMD-Coles/dcm_account394007_impression_2016092509_20160926_030312_292502379.csv.gz&quot;\r\n            },\r\n            {\r\n              &quot;mandatory&quot;: true,\r\n              &quot;url&quot;: &quot;DFA/20160926/394007-OMD-Coles/dcm_account394007_impression_2016092510_20160926_033656_292590227.csv.gz&quot;\r\n            }   \r\n      ] \r\n    }\r\n\r\nThe manifest file, however needs the URL objects prefixed with a bucket-name which I haven&#39;t got around with. The output needs to look as\r\n\r\n  \r\n\r\n    {   &quot;entries&quot;: [\r\n            {\r\n              &quot;mandatory&quot;: true,\r\n              &quot;url&quot;: &quot;s3://mybucket/DFA/20160926/394007-OMD-Coles/dcm_account394007_impression_2016092507_20160926_002328_292527438.csv.gz&quot;\r\n            },\r\n            {\r\n              &quot;mandatory&quot;: true,\r\n              &quot;url&quot;: &quot;s3://mybucket/DFA/20160926/394007-OMD-Coles/dcm_account394007_impression_2016092508_20160926_020131_292592736.csv.gz&quot;\r\n            },\r\n            {\r\n              &quot;mandatory&quot;: true,\r\n              &quot;url&quot;: &quot;s3://mybucket/DFA/20160926/394007-OMD-Coles/dcm_account394007_impression_2016092509_20160926_030312_292502379.csv.gz&quot;\r\n            },\r\n            {\r\n              &quot;mandatory&quot;: true,\r\n              &quot;url&quot;: &quot;s3://mybucket/DFA/20160926/394007-OMD-Coles/dcm_account394007_impression_2016092510_20160926_033656_292590227.csv.gz&quot;\r\n            }   \r\n      ] \r\n    }",
        "link": "https://stackoverflow.com/questions/39785343/jq-to-prefix-a-string-in-a-json-object-with-a-string",
        "title": "jq to prefix a string in a json object with a string"
    },
    {
        "tags": [
            "python",
            "python-2.7",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 6,
                "is_accepted": false,
                "score": 5,
                "last_activity_date": 1475221202,
                "creation_date": 1475221202,
                "answer_id": 39786170,
                "question_id": 39785890,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "It doesn&#39;t appear that jq supports Windows; it says it requires gcc &amp; libtool, which generally means a Unix-like environment.",
                "title": "unable to install JQ via PIP"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1475524403,
                "creation_date": 1475524403,
                "answer_id": 39839370,
                "question_id": 39785890,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Like you I had a difficult time installing jq \r\n\r\nIn my attempts I had many various errors including the failed building wheel that you are getting. I assume that the problem was on my end and not that the host was temporarily down. My setup: python 2 &amp; 3, Jupyter, brew in addition to pip. The problem was likely due to some lack of consistency in package links, brew doctor helped me identify which links were broken then brew link/unlink/overwrite. \r\n\r\nAt anyrate I was only successful after brew uninstall jq, fixing all links, then updating brew and rebooting my system (perhaps some dependency was occupied?). \r\n\r\nThen and only then did finally `pip install jq` work\r\n\r\n",
                "title": "unable to install JQ via PIP"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1541689685,
                "creation_date": 1541689685,
                "answer_id": 53210536,
                "question_id": 39785890,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I have experienced same issues as OP. Although in my case (Debian Stretch 9.5) it turned out `dh-autoreconf` package was missing. After installing it, `jq` build finished successfully.",
                "title": "unable to install JQ via PIP"
            },
            {
                "up_vote_count": 7,
                "is_accepted": false,
                "score": 6,
                "last_activity_date": 1564430565,
                "creation_date": 1564430565,
                "answer_id": 57260672,
                "question_id": 39785890,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "On Ubuntu 18.04, I needed to `apt-get install autoconf libtool` before my `pip install pyjq` would complete.",
                "title": "unable to install JQ via PIP"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": 17,
        "last_activity_date": 1564430565,
        "creation_date": 1475220144,
        "question_id": 39785890,
        "body_markdown": "I am trying to install JQ via PIP in python.\r\n\r\n    pip install jq\r\n\r\nI am getting following error.\r\n\r\n**Failed building wheel for jq**\r\n\r\n[![enter image description here][1]][1]\r\n\r\n\r\nI am facing same issue while install pyjq.\r\n\r\n    pip install pyjq\r\n    \r\n**Failed building wheel for pyjq**\r\n\r\n[![enter image description here][2]][2]\r\n\r\n\r\n  [1]: https://i.sstatic.net/ywWcL.png\r\n  [2]: https://i.sstatic.net/2EoxV.png",
        "link": "https://stackoverflow.com/questions/39785890/unable-to-install-jq-via-pip",
        "title": "unable to install JQ via PIP"
    },
    {
        "tags": [
            "json",
            "key",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1475247967,
                "last_edit_date": 1475247967,
                "creation_date": 1475238063,
                "answer_id": 39791423,
                "question_id": 39790351,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "As explained [here](https://github.com/stedolan/jq/issues/940), the abbreviated form `.keyname` cannot be used when the key contains the `-` character. \r\n\r\nYou can run the following to get the list of all names from your file:\r\n\r\n    jq &#39;.&quot;snapshot-sets&quot;[].name&#39; testjq",
                "title": "Unable to filter JSON output using jq. I am using CURL"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1475248108,
        "creation_date": 1475234463,
        "last_edit_date": 1475248108,
        "question_id": 39790351,
        "body_markdown": "I am unable to filter the following.\r\n\r\nI need to find out the count of names starting with &quot;SnapshotSet&quot; which are under the name tag of the below JSON file.\r\n\r\nExample - `&quot;name&quot;: &quot;SnapshotSet.1475076959480&quot;`\r\n\r\nAs a first step I am trying to filter out all the names starting with SnapshotSet...but receiving the following error.\r\n\r\njq `&#39;.snapshot-sets[]&#39; testjq`\r\nerror: sets is not defined\r\n\r\nBut when I filter out links I am able to get an output\r\n\r\n  \r\n\r\n      jq &#39;.links[]&#39; testjq\r\n    {\r\n      &quot;href&quot;: &quot;https://test.com/api/json/v2/types/snapshot-sets/&quot;,\r\n      &quot;rel&quot;: &quot;self&quot;\r\n    }\r\n\r\nAnything to do with the name &quot;snapshot-sets&quot;?\r\n\r\nPlease find the JSON file below.\r\n\r\n\r\n    {\r\n    &quot;links&quot;: [\r\n        {\r\n            &quot;href&quot;: &quot;https://test.com/api/json/v2/types/snapshot-sets/&quot;,\r\n            &quot;rel&quot;: &quot;self&quot;\r\n        }\r\n    ],\r\n    &quot;snapshot-sets&quot;: [\r\n        {\r\n            &quot;href&quot;: &quot;https://test.com/api/json/v2/types/snapshot-sets/1&quot;,\r\n            &quot;name&quot;: &quot;SnapshotSet.1475076959480&quot;\r\n        },\r\n        {\r\n            &quot;href&quot;: &quot;https://test.com/api/json/v2/types/snapshot-sets/3&quot;,\r\n            &quot;name&quot;: &quot;SnapshotSet.1475165496304&quot;\r\n        },\r\n        {\r\n            &quot;href&quot;: &quot;https://test.com/api/json/v2/types/snapshot-sets/2&quot;,\r\n            &quot;name&quot;: &quot;SnapshotSet.1475158265437&quot;\r\n        },\r\n        {\r\n            &quot;href&quot;: &quot;https://test.com/api/json/v2/types/snapshot-sets/63659&quot;,\r\n            &quot;name&quot;: &quot;server1a_b_c_STFS1474869600618&quot;\r\n        },\r\n",
        "link": "https://stackoverflow.com/questions/39790351/unable-to-filter-json-output-using-jq-i-am-using-curl",
        "title": "Unable to filter JSON output using jq. I am using CURL"
    },
    {
        "tags": [
            "linux",
            "bash",
            "shell",
            "curl",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 123,
                "is_accepted": true,
                "score": 122,
                "last_activity_date": 1670212144,
                "last_edit_date": 1670212144,
                "creation_date": 1475263695,
                "answer_id": 39798786,
                "question_id": 39798542,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You need to combine filters by means of `|` operator:\r\n\r\n    $ jq -r &#39;.[] | .[] | .name&#39; test.json \r\n    rhel6.6\r\n    rhel7\r\n\r\nThe first `.[]` fetches `repositories` array. The next `.[]` fetches all the items of the `repositories` array. Finally, `.name` extracts properties from the array items(objects).\r\n\r\nNote, the first `.[]` works on object because it is a documented feature:\r\n\r\n\r\n&lt;!-- language: none --&gt;\r\n\r\n    .[]\r\n        If you use the .[index] syntax, but omit the index entirely, it\r\n        will return all of the elements of an array...\r\n\r\n        You can also use this on an object, and it will return all the\r\n        values of the object.\r\n",
                "title": "Using jq to fetch key value from json output"
            },
            {
                "up_vote_count": 39,
                "is_accepted": false,
                "score": 39,
                "last_activity_date": 1475263724,
                "creation_date": 1475263724,
                "answer_id": 39798796,
                "question_id": 39798542,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You want to look at the repositories array instead of treating the input as an array:\r\n\r\n    $ jq -r &#39;.repositories[].name&#39; file\r\n    rhel6.6\r\n    rhel7\r\n\r\n",
                "title": "Using jq to fetch key value from json output"
            },
            {
                "up_vote_count": 18,
                "is_accepted": false,
                "score": 18,
                "last_activity_date": 1504141693,
                "last_edit_date": 1592644375,
                "creation_date": 1504141693,
                "answer_id": 45971763,
                "question_id": 39798542,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is another solution.  Assuming the requirements\n\n&gt; I want to get only name values with each of them in a new line so that I can use while read -r line. \n&gt;\n&gt; Can you please how can i get output in format rhel12/rhel6.6 In other words, I need o/p in format namespace/name\n\nif the data is in `data.json` then the command\n\n    jq -M -r &#39;.repositories[] | &quot;\\(.namespace)/\\(.name)&quot;&#39; data.json\n\nshould produce\n\n    rhel12/rhel6.6\n    rhel12/rhel7",
                "title": "Using jq to fetch key value from json output"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 68,
        "last_activity_date": 1670212144,
        "creation_date": 1475262658,
        "question_id": 39798542,
        "body_markdown": "I have a file that looks as below:\r\n\r\n    {\r\n      &quot;repositories&quot;: [\r\n       {\r\n        &quot;id&quot;: &quot;156c48fc-f208-43e8-a631-4d12deb89fa4&quot;,\r\n        &quot;namespace&quot;: &quot;rhel12&quot;,\r\n        &quot;namespaceType&quot;: &quot;organization&quot;,\r\n        &quot;name&quot;: &quot;rhel6.6&quot;,\r\n        &quot;shortDescription&quot;: &quot;&quot;,\r\n        &quot;visibility&quot;: &quot;public&quot;\r\n       },\r\n       {\r\n        &quot;id&quot;: &quot;f359b5d2-cb3a-4bb3-8aff-d879d51f1a04&quot;,\r\n        &quot;namespace&quot;: &quot;rhel12&quot;,\r\n        &quot;namespaceType&quot;: &quot;organization&quot;,\r\n        &quot;name&quot;: &quot;rhel7&quot;,\r\n        &quot;shortDescription&quot;: &quot;&quot;,\r\n        &quot;visibility&quot;: &quot;public&quot;\r\n       }\r\n      ]\r\n     }\r\n\r\nI want to get only name values with each of them in a new line so that I can use `while read -r line`.\r\nI need only \r\n\r\n    rhel6.6 \r\n    rhel7\r\n\r\nI am using jq as follows which doesn&#39;t seem to work:\r\n\r\n    jq -r &#39;.[].name&#39;\r\n\r\nPlease suggest correct use of jq here",
        "link": "https://stackoverflow.com/questions/39798542/using-jq-to-fetch-key-value-from-json-output",
        "title": "Using jq to fetch key value from json output"
    }
]