[
    {
        "tags": [
            "json",
            "bash",
            "sed",
            "jq",
            "cut"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1495046189,
                "post_id": 44032450,
                "comment_id": 75091395,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 3959308,
                    "reputation": 53394,
                    "user_id": 3266847,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/U0oyt.png?s=256",
                    "display_name": "Benjamin W.",
                    "link": "https://stackoverflow.com/users/3266847/benjamin-w"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1495053605,
                "post_id": 44032450,
                "comment_id": 75095447,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 19,
                "is_accepted": true,
                "score": 19,
                "last_activity_date": 1495046727,
                "last_edit_date": 1495046727,
                "creation_date": 1495046370,
                "answer_id": 44032543,
                "question_id": 44032450,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "I would recommend using [jq][1]:\r\n\r\n    $ jq &#39;.data.password&#39; data.json\r\n    &quot;test123&quot;\r\n\r\nOr both fields:\r\n\r\n    $ jq &#39;.data.password, .data.username&#39; data.json\r\n    &quot;test123&quot;\r\n    &quot;testuser1&quot;\r\n\r\n  [1]: https://stedolan.github.io/jq/tutorial/\r\n\r\n",
                "title": "Parse through JSON using only Bash"
            },
            {
                "up_vote_count": 7,
                "is_accepted": false,
                "score": 6,
                "last_activity_date": 1495046765,
                "last_edit_date": 1495046765,
                "creation_date": 1495046653,
                "answer_id": 44032609,
                "question_id": 44032450,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "I would recommend  `jq` a lightweight `JSON` aware parser for manipulating `JSON` content. Pipe your `curl` command input to a filter in `jq` as\r\n\r\n    curl-command | jq --raw-output &#39;.data.password, .data.username&#39;\r\n\r\nInstructions to [download-and-install `jq`](https://stedolan.github.io/jq/download/) available.",
                "title": "Parse through JSON using only Bash"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1534161729,
                "creation_date": 1534161729,
                "answer_id": 51821931,
                "question_id": 44032450,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use [bashJson][1]\r\n\r\n\r\n  [1]: https://github.com/hack4mer/bashjson\r\n\r\n\r\nIts a wrapper for the Python&#39;s JSON module and can handle complex JSON data.\r\n\r\nSee my answer here for example usage : https://stackoverflow.com/a/51821898/2734348",
                "title": "Parse through JSON using only Bash"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 11,
        "last_activity_date": 1658236793,
        "creation_date": 1495046121,
        "last_edit_date": 1658236793,
        "question_id": 44032450,
        "body_markdown": "I have a JSON file :\r\n\r\n    {\r\n    \t&quot;request_id&quot;: &quot;9a081c0c-9401-7eca-f55d-50e3b7c0301c&quot;,\r\n    \t&quot;lease_id&quot;: &quot;&quot;,\r\n    \t&quot;renewable&quot;: false,\r\n    \t&quot;lease_duration&quot;: 2764800,\r\n    \t&quot;data&quot;: {\r\n    \t\t&quot;password&quot;: &quot;test123&quot;,\r\n    \t\t&quot;username&quot;: &quot;testuser1&quot;\r\n    \t},\r\n    \t&quot;wrap_info&quot;: null,\r\n    \t&quot;warnings&quot;: null,\r\n    \t&quot;auth&quot;: null\r\n    }\r\n\r\nI am trying to read the values of `username` and `password`. Now I was able to integrate bash and python to get what I wanted.\r\n\r\n    # curl --silent -k https://1.2.3.4:8200/v1/secret/service/clustered -H &quot;X-Vault-Token: c2e3b6ec17df&quot; | python3 -c &quot;import sys, json; print(json.load(sys.stdin)[&#39;data&#39;][&#39;password&#39;])&quot;\r\n    test123\r\n    \r\n    # curl --silent -k https://1.2.3.4:8200/v1/secret/service/clustered -H &quot;X-Vault-Token: c2e3b6ec17df&quot; | python3 -c &quot;import sys, json; print(json.load(sys.stdin)[&#39;data&#39;][&#39;username&#39;])&quot;\r\n    testuser1\r\n\r\nBut since I only want to use bash, I have done the following too:\r\n\r\n    # curl --silent -k https://1.2.3.4:8200/v1/secret/service/clustered -H &quot;X-Vault-Token: c2e3b6ec17df&quot; | sed -n -e &#39;s/^.*password&quot;:&quot;//p&#39; | cut -d&#39;&quot;&#39; -f1\r\n    test123\r\n    \r\n    # curl --silent -k https://1.2.3.4:8200/v1/secret/service/clustered -H &quot;X-Vault-Token: c2e3b6ec17df&quot; | sed -n -e &#39;s/^.*username&quot;:&quot;//p&#39; | cut -d&#39;&quot;&#39; -f1\r\n    testuser\r\n\r\nI am just concerned whether I have made use of `sed` and `cut` commands correctly in this case. Or is there a better way to extract the required fields? ",
        "link": "https://stackoverflow.com/questions/44032450/parse-through-json-using-only-bash",
        "title": "Parse through JSON using only Bash"
    },
    {
        "tags": [
            "centos",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 24,
                "is_accepted": false,
                "score": 24,
                "last_activity_date": 1495160950,
                "creation_date": 1495160950,
                "answer_id": 44060478,
                "question_id": 44044449,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "This is how I installed it on CentOS 7:\r\n\r\n    wget https://github.com/stedolan/jq/releases/download/jq-1.5/jq-linux64 -O jq\r\n    chmod +x jq\r\n\r\nThen \r\n\r\n    mv jq /usr/local/bin\r\n\r\n",
                "title": "Facing issue while installing jq in centos"
            },
            {
                "up_vote_count": 133,
                "is_accepted": false,
                "score": 133,
                "last_activity_date": 1503006401,
                "last_edit_date": 1592644375,
                "creation_date": 1503006401,
                "answer_id": 45745410,
                "question_id": 44044449,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Just in case if someone is looking for a different solution.\n\nThis is how I installed in Cent OS 7 and it worked. Ensure you have **sudo** privilege.\n# Installer solution\n\n    yum install epel-release -y\n    yum install jq -y\n    jq --version\n\noutput was **jq-1.5**\n\n[Reference][1]\n\n\n  [1]: https://centos.pkgs.org/7/epel-x86_64/jq-1.5-1.el7.x86_64.rpm.html",
                "title": "Facing issue while installing jq in centos"
            },
            {
                "up_vote_count": 10,
                "is_accepted": false,
                "score": 10,
                "last_activity_date": 1573056230,
                "creation_date": 1573056230,
                "answer_id": 58734188,
                "question_id": 44044449,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Install pre-req &amp; install jq\r\n\r\n    $ sudo yum -y install https://dl.fedoraproject.org/pub/epel/epel-release-latest-7.noarch.rpm\r\n    \r\n    $ sudo yum install jq -y\r\n\r\n\r\nmore usage info..  https://medium.com/@gchandra/install-jq-on-centos-7-459dd650baa3",
                "title": "Facing issue while installing jq in centos"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 36,
        "last_activity_date": 1573056230,
        "creation_date": 1495101209,
        "last_edit_date": 1503010056,
        "question_id": 44044449,
        "body_markdown": "While installing jq on centos, I am experiencing an issue. I have run the following commands: \r\n    \r\n    yum groupinstall &quot;Development Tools&quot;\r\n    yum install autoconf automake libtool python\r\n\r\nafter that I have used `pip install jq` and I was facing error like this:\r\n\r\n    jq.c:8:22: fatal error: pyconfig.h: No such file or directory\r\n    #include &quot;pyconfig.h&quot;\r\n                         ^\r\n    compilation terminated.\r\n    error: command &#39;gcc&#39; failed with exit status 1\r\n\r\n    ----------------------------------------\r\n    Command &quot;/usr/bin/python -u -c &quot;import setuptools, tokenize;__file__=&#39;/tmp/pip-build-akuaZu/jq/setup.py&#39;;f=getattr(tokenize, &#39;open&#39;, open)(__file__);code=f.read                                                                                        ().replace(&#39;\\r\\n&#39;, &#39;\\n&#39;);f.close();exec(compile(code, __file__, &#39;exec&#39;))&quot; \r\n    instal --record /tmp/pip-04CW9h-record/install-record.txt --single-version-externally  \r\n    -managed --compile&quot; failed with error code 1 in /tmp/pip-build-akuaZu/jq/\r\n\r\nCan anyone help me??\r\n\r\n\r\n\r\n  ",
        "link": "https://stackoverflow.com/questions/44044449/facing-issue-while-installing-jq-in-centos",
        "title": "Facing issue while installing jq in centos"
    },
    {
        "tags": [
            "json",
            "bash",
            "newline",
            "jq",
            "output-formatting"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1495175437,
                "post_id": 44062915,
                "comment_id": 75150344,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 3861004,
                    "reputation": 477,
                    "user_id": 3198755,
                    "user_type": "registered",
                    "accept_rate": 53,
                    "profile_image": "https://www.gravatar.com/avatar/d12bd5a6c21a7736ab068935de9799d7?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "user3198755",
                    "link": "https://stackoverflow.com/users/3198755/user3198755"
                },
                "reply_to_user": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1495176496,
                "post_id": 44062915,
                "comment_id": 75150813,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 19375,
                    "reputation": 447959,
                    "user_id": 45375,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/39f6e2dc52425b1e08027c01bb880be0?s=256&d=identicon&r=PG",
                    "display_name": "mklement0",
                    "link": "https://stackoverflow.com/users/45375/mklement0"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1495332586,
                "post_id": 44062915,
                "comment_id": 75206540,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 19,
                "is_accepted": true,
                "score": 19,
                "last_activity_date": 1495176733,
                "last_edit_date": 1495176733,
                "creation_date": 1495176193,
                "answer_id": 44063154,
                "question_id": 44062915,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Couple of _issues_ in the information you have provided. The `jq` filter `.[] | .login, .id` will not produce the output as you claimed on `jq-1.5`. For your original `JSON`\r\n\r\n    {  \r\n       &quot;login&quot;:&quot;dmaxfield&quot;,\r\n       &quot;id&quot;:7449977\r\n    }\r\n    {  \r\n       &quot;login&quot;:&quot;stackfield&quot;,\r\n       &quot;id&quot;:2342323\r\n    }\r\n\r\n\r\nIt will produce four lines of output as,\r\n\r\n    jq -r &#39;.login, .id&#39; &lt; json\r\n    dmaxfield\r\n    7449977\r\n    stackfield\r\n    2342323\r\n\r\nIf you are interested in storing them side by side, you need to do variable interpolation as\r\n\r\n    jq -r &#39;&quot;\\(.login), \\(.id)&quot;&#39; &lt; json\r\n    dmaxfield, 7449977\r\n    stackfield, 2342323\r\n\r\nAnd if you feel your output stored in a variable is not working. It is probably because of lack of double-quotes when you tried to print the variable in the shell.\r\n\r\n    jqOutput=$(jq -r &#39;&quot;\\(.login), \\(.id)&quot;&#39; &lt; json)\r\n    printf &quot;%s\\n&quot; &quot;$jqOutput&quot;\r\n    dmaxfield, 7449977\r\n    stackfield, 2342323\r\n\r\nThis way the embedded new lines in the command output are _not_ swallowed by the shell.\r\n\r\n---\r\n\r\nFor you updated `JSON` (totally new one compared to old one), all you need to do is\r\n \r\n    jqOutput=$(jq -r &#39;.[] | .name&#39; &lt; json)\r\n    printf &quot;%s\\n&quot; &quot;$jqOutput&quot;\r\n    Arthur\r\n    Richard\r\n\r\n",
                "title": "How to get newline on every iteration in jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1495332265,
                "last_edit_date": 1495332265,
                "creation_date": 1495200663,
                "answer_id": 44071453,
                "question_id": 44062915,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "In case the .login or .id contains embedded spaces or other characters that might cause problems, a more robust approach is to ensure each JSON value is on a separate line.  Consider, for example:\r\n\r\n    jq -c .login,.id input.json | while read login ; do read id; echo login=&quot;$login&quot; and id=&quot;$id&quot; ; done\r\n    login=&quot;dmaxfield&quot; and id=7449977\r\n    login=&quot;stackfield&quot; and id=2342323",
                "title": "How to get newline on every iteration in jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 12,
        "last_activity_date": 1581576078,
        "creation_date": 1495175373,
        "last_edit_date": 1581576078,
        "question_id": 44062915,
        "body_markdown": "I have the following file\r\n\r\n    [\r\n      {\r\n        &quot;id&quot;: 1,\r\n        &quot;name&quot;: &quot;Arthur&quot;,\r\n        &quot;age&quot;: &quot;21&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: 2,\r\n        &quot;name&quot;: &quot;Richard&quot;,\r\n        &quot;age&quot;: &quot;32&quot;\r\n      }\r\n    ]\r\nTo display login and id together, I am using the following command\r\n\r\n    $ jq &#39;.[] | .name&#39; test\r\n    &quot;Arthur&quot;\r\n    &quot;Richard&quot;\r\n\r\nBut when I put it in a shell script and try to assign it to a variable then the whole output is displayed on a single line like below\r\n\r\n    #!/bin/bash\r\n\r\n    names=$(jq &#39;.[] | .name&#39; test)\r\n    echo $names\r\n\r\n    $ ./script.sh\r\n    &quot;Arthur&quot; &quot;Richard&quot;\r\n\r\nI want to break at every iteration similar to how it works on the command line.",
        "link": "https://stackoverflow.com/questions/44062915/how-to-get-newline-on-every-iteration-in-jq",
        "title": "How to get newline on every iteration in jq"
    },
    {
        "tags": [
            "arrays",
            "select",
            "indexing",
            "key",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1519980724,
                "last_edit_date": 1519980724,
                "creation_date": 1495198023,
                "answer_id": 44070541,
                "question_id": 44066308,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here&#39;s one of many possibilities:\r\n\r\n    .arr | range(0;length) as $i | select(.[$i].Name != &quot;app&quot;) | $i\r\n\r\nAnd slightly more briefly but less efficiently:\r\n\r\n    .arr | to_entries[] | select(.value.Name != &quot;app&quot;) | .key\r\n\r\nAnd if you are itching to use a for-style loop, or if you want something to think about:\r\n\r\n    foreach .arr[] as $o (-1; .+1; select($o.Name != &quot;app&quot;))",
                "title": "JQ: Finding array index of object with specific attribute value"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1503025264,
                "creation_date": 1503025264,
                "answer_id": 45747833,
                "question_id": 44066308,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a solution which uses **tostream**.\r\n\r\n          tostream\r\n        | if   .[0][-1] == &quot;Name&quot; and .[1] == &quot;app&quot;\r\n          then .[0][-2]\r\n          else  empty\r\n          end",
                "title": "JQ: Finding array index of object with specific attribute value"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1519980724,
        "creation_date": 1495186100,
        "question_id": 44066308,
        "body_markdown": "I have the following:\r\n\r\n    {&quot;arr&quot;:[{&quot;Name&quot;:&quot;web&quot;},{&quot;Name&quot;:&quot;app&quot;}]}\r\n\r\nI need to find out the array index of all array objects that do not have &quot;app&quot; in the attribute &quot;Name&quot;.\r\n\r\nI&#39;ve tried to use a combination of &quot;select&quot; and &quot;keys&quot; but this does not work:\r\n\r\n    jq &#39;.arr[] | select(.Name != &quot;app&quot;) | keys&#39;",
        "link": "https://stackoverflow.com/questions/44066308/jq-finding-array-index-of-object-with-specific-attribute-value",
        "title": "JQ: Finding array index of object with specific attribute value"
    },
    {
        "tags": [
            "json",
            "object",
            "merge",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1495444733,
                "last_edit_date": 1495444733,
                "creation_date": 1495203730,
                "answer_id": 44072482,
                "question_id": 44072197,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Yes, it&#39;s possible, and in fact quite easy under various interpretations of the problem as originally stated.\r\n\r\nThe following solves the the problem as it was originally stated, with &quot;it&quot; being interpreted as `.[&quot;some-array&quot;]` rather than its constituents.\r\n\r\nAssuming `$update` holds the object with the updated information as shown, the update could be performed using this filter:\r\n\r\n    .[&quot;some-array&quot;] = ($update | .[&quot;some-array&quot;])\r\n\r\nThere are many ways to endow `$update` with the desired value.\r\n",
                "title": "Merge two complex JSON objects (using jq)"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1495444368,
                "last_edit_date": 1592644375,
                "creation_date": 1495444368,
                "answer_id": 44109009,
                "question_id": 44072197,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is a solution to the updated problem.  This solution assumes that the names are string-valued.  It relies on two helper functions:\n\n    # array-to-hash\n    def a2h(f): reduce .[] as $x ({}; . + {($x | f): $x});\n\n    # hash-to-array\n    def h2a: . as $in | reduce keys_unsorted[] as $k ([]; . + [$in[$k]]);\n\nThe first of these creates a &quot;hash&quot; based on an input array, and the second implements the inverse operation.\n\nWith these helper functions, the solution can be written:\n\n    .[&quot;some-array&quot;] |= (a2h(.name) + ($update|.[&quot;some-array&quot;] | a2h(.name)) | h2a)\n\nwhere `$update` is the &quot;new&quot; value.  This solution relies on the &quot;right-dominance&quot; of object-addition.\n\n### Output\nFor the given example, the output is:\n\n    {\n      &quot;some-array&quot;: [\n        {\n          &quot;name&quot;: &quot;foo&quot;,\n          &quot;attr&quot;: &quot;new-value&quot;,\n          &quot;new-attrib&quot;: &quot;new-value&quot;\n        },\n        {\n          &quot;name&quot;: &quot;foo bar&quot;,\n          &quot;attr&quot;: &quot;new-value&quot;\n        },\n        {\n          &quot;name&quot;: &quot;foo bar baz&quot;,\n          &quot;attr&quot;: &quot;value&quot;\n        }\n      ],\n      &quot;some-other-array&quot;: []\n    }\n\n",
                "title": "Merge two complex JSON objects (using jq)"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1495596120,
        "creation_date": 1495202862,
        "last_edit_date": 1495596120,
        "question_id": 44072197,
        "body_markdown": "I&#39;m trying to replace objects in a complex JSON object. It seemed that the tool `jq` could be offering the perfect solution, but I&#39;m really struggling with the right choice / chain of filters.\r\n\r\nI have a complete configuration JSON object which looks like this (has some more keys in it, shortened it for illustration):\r\n\r\n    {\r\n        &quot;some-array&quot;: [\r\n            {\r\n                &quot;name&quot;: &quot;foo&quot;,\r\n                &quot;attr&quot;: &quot;value&quot;\r\n            },\r\n            {\r\n                &quot;name&quot;: &quot;foo bar&quot;,\r\n                &quot;attr&quot;: &quot;value&quot;\r\n            },\r\n            {\r\n                &quot;name&quot;: &quot;foo bar baz&quot;,\r\n                &quot;attr&quot;: &quot;value&quot;\r\n            }\r\n        ],\r\n        &quot;some-other-array&quot;: []\r\n    }\r\n\r\nNow I have another object containing an array with updated objects which I need to merge with the full configuration in some way. I need to find the nested objects by name, add it if it does not exist yet and replace it if it does exist.\r\n\r\n    {\r\n        &quot;some-array&quot;: [\r\n            {\r\n                &quot;name&quot;: &quot;foo&quot;,\r\n                &quot;attr&quot;: &quot;new-value&quot;,\r\n                &quot;new-attrib&quot;: &quot;new-value&quot;\r\n            },\r\n            {\r\n                &quot;name&quot;: &quot;foo bar&quot;,\r\n                &quot;attr&quot;: &quot;new-value&quot;\r\n            }\r\n        ]\r\n    }\r\n\r\nSo, with the above example, my expected result would be:\r\n\r\n    {\r\n        &quot;some-array&quot;: [\r\n            {\r\n                &quot;name&quot;: &quot;foo&quot;,\r\n                &quot;attr&quot;: &quot;new-value&quot;,\r\n                &quot;new-attrib&quot;: &quot;new-value&quot;\r\n            },\r\n            {\r\n                &quot;name&quot;: &quot;foo bar&quot;,\r\n                &quot;attr&quot;: &quot;new-value&quot;\r\n            },\r\n            {\r\n                &quot;name&quot;: &quot;foo bar baz&quot;,\r\n                &quot;attr&quot;: &quot;value&quot;\r\n            }\r\n        ],\r\n        &quot;some-other-array&quot;: []\r\n    }\r\n\r\nI already tried `select(.&quot;some-array&quot;[].name == &quot;foo&quot;)` to begin with and a few other things as a `jq` filter, but I&#39;m struggling to move forward here and would really appreciate some inspiration / an actual solution.\r\n\r\nCan anyone tell me if what I&#39;m trying to achieve is actually possible with `jq` or do I have to find another solution?\r\n",
        "link": "https://stackoverflow.com/questions/44072197/merge-two-complex-json-objects-using-jq",
        "title": "Merge two complex JSON objects (using jq)"
    },
    {
        "tags": [
            "json",
            "csv",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1495401327,
                "last_edit_date": 1495401327,
                "creation_date": 1495249831,
                "answer_id": 44081536,
                "question_id": 44081265,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "To avoid the unwanted Cartesian product, ensure there is only one call to `.BlockDeviceMappings[]`.\r\n\r\nThe following filter extracts the information you want as a stream of arrays:\r\n\r\n       .Images[] | [.ImageId,.Name,.State] + (.BlockDeviceMappings[] | [.Ebs[] ]) \r\n\r\n(In the above, [.Ebs[]] produces an array of the values of `.Ebs`, which may or may not be exactly what you want.)\r\n\r\nTo convert these arrays into strings with pipe-delimited values, you could pipe the above into `join(&quot;|&quot;)` or `@tsv | gsub(&quot;\\t&quot;;&quot;|&quot;)` to produce (using jq -r):\r\n\r\n    ami-111|etl-db|available|snap-AAA|size-AAA\r\n    ami-111|etl-db|available|snap-BBB|size-BBB",
                "title": "How to use jq to extract joined rows of data from a json doc"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1495401327,
        "creation_date": 1495246519,
        "last_edit_date": 1495309150,
        "question_id": 44081265,
        "body_markdown": "I have a JSON doc that looks like:\r\n\r\n    {\r\n    &quot;Images&quot;: [\r\n        {\r\n            &quot;ImageId&quot;: &quot;ami-111&quot;,\r\n            &quot;Name&quot;: &quot;etl-db&quot;,\r\n            &quot;State&quot;: &quot;available&quot;,\r\n            &quot;BlockDeviceMappings&quot;: [\r\n                {\r\n                    &quot;DeviceName&quot;: &quot;/dev/sda&quot;,\r\n                    &quot;Ebs&quot;: {\r\n                        &quot;SnapshotId&quot;: &quot;snap-AAA&quot;,\r\n                        &quot;VolumeSize&quot;: &quot;size-AAA&quot;\r\n                    }\r\n                },\r\n                {\r\n                    &quot;DeviceName&quot;: &quot;/dev/sdb&quot;,\r\n                    &quot;Ebs&quot;: {\r\n                        &quot;SnapshotId&quot;: &quot;snap-BBB&quot;,\r\n                        &quot;VolumeSize&quot;: &quot;size-BBB&quot;\r\n                    }\r\n                }\r\n            ]\r\n        }\r\n    ]\r\n}\r\n\r\nI used the follwoing jq command trto get output like:\r\nami-111|etl-db|available|snap-AAA|size-AAA\r\nami-111|etl-db|available|snap-BBB|size-BBB\r\n\r\n    cat json.doc | jq -r &#39;.Images[]|&quot;\\(.ImageId)|\\(.Name)|\\(.State)|\\(.BlockDeviceMappings[].Ebs.SnapshotId)|\\(.BlockDeviceMappings[].Ebs.VolumeSize)&quot;&#39;\r\n\r\nHowever it generates a Cartesian Product for  SnapshotId x VolumeSize\r\n\r\n    ami-111|etl-db|available|snap-AAA|size-AAA\r\n    ami-111|etl-db|available|snap-BBB|size-AAA\r\n    ami-111|etl-db|available|snap-AAA|size-BBB\r\n    ami-111|etl-db|available|snap-BBB|size-BBB\r\n\r\nHow can I get the following output?\r\n\r\n    ami-111|etl-db|available|snap-AAA|size-AAA\r\n    ami-111|etl-db|available|snap-BBB|size-BBB\r\nThanks!\r\n",
        "link": "https://stackoverflow.com/questions/44081265/how-to-use-jq-to-extract-joined-rows-of-data-from-a-json-doc",
        "title": "How to use jq to extract joined rows of data from a json doc"
    },
    {
        "tags": [
            "json",
            "object",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1495436226,
                "last_edit_date": 1495436226,
                "creation_date": 1495433372,
                "answer_id": 44105730,
                "question_id": 44105429,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Given the example input, here&#39;s a simple solution, assuming the stream of objects is available as an array. (This can be done using `jq -s` if the JSON objects are given as input to jq, or in your case, following your example, simply using `.parameters | to_entries`).\r\n\r\n    map( select(.value.isEncrypted == false) | {(.key): .value.value } )\r\n    | add\r\n\r\nThis produces the JSON object:\r\n\r\n    {\r\n      &quot;something-else&quot;: &quot;bloop&quot;,\r\n      &quot;something&quot;: &quot;blah&quot;\r\n    }\r\n\r\n\r\nThe key ideas here are:\r\n\r\n - the syntax for object construction: `{( KEYNAME ): VALUE}`\r\n - `add`\r\n\r\nOne way to gain an understanding of how this works is to run the first part of the filter (map(...)) first.\r\n    \r\n### Using `keys_unsorted`\r\n\r\nIf you want to avoid the overhead of `to_entries`, you might want to consider the following approach, which piggy-backs off your implicit description of `.parameters`:\r\n\r\n    .parameters\r\n    | [ keys_unsorted[] as $k\r\n      | if .[$k].isEncrypted == false \r\n        then { ($k) : .[$k].value } else empty end ]\r\n    | add\r\n\r\n",
                "title": "Building objects with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1495436752,
        "creation_date": 1495431999,
        "last_edit_date": 1495436752,
        "question_id": 44105429,
        "body_markdown": "Using `jq` I&#39;d like to convert data of the format:\r\n\r\n\r\n    {\r\n      &quot;key&quot;: &quot;something-else&quot;,\r\n      &quot;value&quot;: {\r\n        &quot;value&quot;: &quot;bloop&quot;,\r\n        &quot;isEncrypted&quot;: false\r\n      }\r\n    }\r\n    {\r\n      &quot;key&quot;: &quot;something&quot;,\r\n      &quot;value&quot;: {\r\n        &quot;value&quot;: &quot;blah&quot;,\r\n        &quot;isEncrypted&quot;: false\r\n      }\r\n    }\r\n\r\nTo the format:\r\n\r\n    {\r\n      something: &quot;blah&quot;,\r\n      something-else: &quot;bloop&quot;\r\n    }\r\n\r\nFiltering out &#39;encrypted values&#39; along the way. How can I achieve this? I&#39;ve gotten as far as the following:\r\n\r\n    .parameters | to_entries[] | select (.value.isEncrypted == false) | .key + &quot;: &quot; + .value.value\r\n\r\nWhich produces:\r\n\r\n    &quot;something-else: bloop&quot;\r\n    &quot;something: blah&quot;\r\n\r\nClose, but not there just yet. I suspect that there&#39;s some clever function for this.",
        "link": "https://stackoverflow.com/questions/44105429/building-objects-with-jq",
        "title": "Building objects with jq"
    },
    {
        "tags": [
            "amazon-ec2",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 6,
                "is_accepted": true,
                "score": 6,
                "last_activity_date": 1495540839,
                "creation_date": 1495540839,
                "answer_id": 44134261,
                "question_id": 44133851,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Are the angle bracket characters really there? Otherwise you can simply `tr &#39;\\n&#39; &#39;,&#39;`.",
                "title": "How to get the output of jq in single line?"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1495574203,
                "last_edit_date": 1495574203,
                "creation_date": 1495568966,
                "answer_id": 44143811,
                "question_id": 44133851,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here are some jq-only approaches.\r\n\r\nIt&#39;s often simplest just to &quot;join&quot; the lines (e.g. using `join(&quot;,&quot;)`). This is typically done with the `-r` command-line option.\r\n\r\nIn cases where this is impractical or inefficient, one can use the `--join` (or `-j`) command-line option.  Here are two illustrations using this approach.  In neither of the examples does the output include a newline.\r\n\r\n### With a terminating comma\r\n\r\n    jq -n -j &#39;range(0;5) | &quot;\\(.),&quot;&#39;\r\n\r\n### Without a terminating comma\r\n\r\noneline.jq:\r\n\r\n    def oneline(f):\r\n      foreach f as $i (null;\r\n        if . == null then &quot;\\($i)&quot; else &quot;,\\($i)&quot; end;\r\n        .);\r\n\r\n    oneline( range(0;5) )\r\n\r\nInvocation: jq -n -j -f oneline.jq\r\n\r\nOutput:\r\n\r\n    0,1,2,3,4\r\n\r\n",
                "title": "How to get the output of jq in single line?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 4,
        "last_activity_date": 1495574203,
        "creation_date": 1495539691,
        "last_edit_date": 1495541186,
        "question_id": 44133851,
        "body_markdown": "I have used jq with aws cli to print the instances .\r\nEg: \r\n**Retrieve instances list**\r\n\r\n    aws ec2 describe-instances --filters &quot;Name=tag:bld_env,Values=test&quot; --output json &gt; all-inst.json\r\n\r\nJq to print instances id :\r\n\r\n    jq -r &#39;.Reservations[].Instances[].InstanceId&#39; all-inst.json\r\nOutput of Jq:\r\n\r\n     i-09e0d805cc \r\n     i-091a61038 \r\n     i-07d3022\r\n     i-0428ac7c4c\r\n     i-970dc5c4d99 \r\n     i-014c4ea\r\n     i-0ac924df\r\n     i-031f6 and so on..\r\n\r\n\r\nI want to print them in a line like this :\r\n\r\n   \r\n\r\n    i-09e0d805cc,i-091a61038,i-07d3022,i-0428ac7c4c,i-970dc5c4d99,i-014c4ea,i-0ac924df,i-031f6 and so on..\r\n\r\n",
        "link": "https://stackoverflow.com/questions/44133851/how-to-get-the-output-of-jq-in-single-line",
        "title": "How to get the output of jq in single line?"
    },
    {
        "tags": [
            "json",
            "data-manipulation",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1495553283,
                "creation_date": 1495553283,
                "answer_id": 44139086,
                "question_id": 44138658,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "there are probably better ways but here you go\r\n\r\n```jq &#39;.results[0].profile * .results[0] | del(.profile)&#39;```\r\n\r\n---\r\n\r\nexplanation:\r\n\r\nmerge recursivly container with nested-container by means of `A * B`, then pipe to `del(` to remove nested container\r\n",
                "title": "reshape json data using jq"
            },
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1495553463,
                "creation_date": 1495553463,
                "answer_id": 44139167,
                "question_id": 44138658,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You can combine two objects with the addition operator.\r\n\r\n`jq &#39;.results[] | .profile + {UID}&#39;`\r\n\r\n.profile is already an object.\r\n\r\nThe other object is created with {}. {UID} is shorthand for {&quot;UID&quot; : .UID}",
                "title": "reshape json data using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1495592233,
        "creation_date": 1495552161,
        "last_edit_date": 1495592233,
        "question_id": 44138658,
        "body_markdown": "I&#39;m trying to reshape a json document and I assumed it would be easy to do using jq but I haven&#39;t been trying for several hours now and no success ... \r\n\r\n(Please note that I&#39;m not a jq jedi and the doc did not help)\r\n\r\n\r\nI want to go from this : \r\n\r\n    {\r\n      &quot;results&quot;: [\r\n        {\r\n          &quot;profile&quot;: {\r\n            &quot;birthYear&quot;: 1900,\r\n            &quot;locale&quot;: &quot;en_EN&quot;,\r\n            &quot;city&quot;: &quot;Somewhere, Around&quot;,\r\n            &quot;timezone&quot;: &quot;2&quot;,\r\n            &quot;age&quot;: 52,\r\n            &quot;gender&quot;: &quot;m&quot;\r\n          },\r\n          &quot;UID&quot;: &quot;SQSQSQerl7XSQSqSsqSQ&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\n\r\nto this : \r\n\r\n    {\r\n       &quot;birthYear&quot;: 1900,\r\n       &quot;locale&quot;: &quot;en_EN&quot;,\r\n       &quot;city&quot;: &quot;Somewhere, Around&quot;,\r\n       &quot;timezone&quot;: &quot;2&quot;,\r\n       &quot;age&quot;: 52,\r\n       &quot;gender&quot;: &quot;m&quot;,\r\n       &quot;UID&quot;: &quot;SQSQSQerl7XSQSqSsqSQ&quot;\r\n    }\r\n\r\nI got what below using this filter : *.results[].profile ,  .results[].UID*\r\n\r\n\r\n\r\n    {\r\n       &quot;birthYear&quot;: 1900,\r\n       &quot;locale&quot;: &quot;en_EN&quot;,\r\n       &quot;city&quot;: &quot;Somewhere, Around&quot;,\r\n       &quot;timezone&quot;: &quot;2&quot;,\r\n       &quot;age&quot;: 52,\r\n       &quot;gender&quot;: &quot;m&quot;   \r\n    }\r\n    &quot;UID&quot;: &quot;SQSQSQerl7XSQSqSsqSQ&quot;\r\n\r\nThanks in advance for your help..",
        "link": "https://stackoverflow.com/questions/44138658/reshape-json-data-using-jq",
        "title": "reshape json data using jq"
    },
    {
        "tags": [
            "json",
            "bash",
            "sh",
            "text-processing",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1495615990,
                "creation_date": 1495615990,
                "answer_id": 44153525,
                "question_id": 44149753,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "1. To add two JSON objects, $one and $two, you can write `$one + $two`.\r\n\r\n2. The two objects given at the beginning of the problem description are not quite valid as JSON.  Assuming that the file input.json contains the corrected text, the invocation:\r\n\r\n    jq -s &#39;.[0] + .[1]&#39; input.json\r\n\r\nyields the desired answer.\r\n\r\n\r\n",
                "title": "jq to convert text strings and add them into an existing json object"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1495618634,
        "creation_date": 1495604091,
        "last_edit_date": 1495618634,
        "question_id": 44149753,
        "body_markdown": "How do I convert text strings and add them into an existing json object\r\n\r\nCurrent json output:\r\n\r\n    {\r\n      &quot;start process&quot;: &quot;Wed May 24 05:22:35 UTC 2017&quot;,\r\n      &quot;logfilename&quot;: &quot;log_test&quot;\r\n    }\r\n    {\r\n      &quot;start filelist&quot;: [\r\n        &quot;/downloads/json_log_array2object.jq&quot;,\r\n        &quot;/downloads/json_log_string2object.jq&quot;,\r\n        &quot;/downloads/log_test.json&quot;,\r\n        &quot;/downloads/log_test.txt&quot;,\r\n        &quot;/downloads/test_logs.sh&quot;\r\n      ]\r\n    }\r\n\r\nTarget json output:\r\n\r\n    {\r\n      &quot;start process&quot;: &quot;Wed May 24 05:22:35 UTC 2017&quot;,\r\n      &quot;logfilename&quot;: &quot;log_test&quot;,\r\n      &quot;start filelist&quot;: [\r\n        &quot;/downloads/json_log_array2object.jq&quot;,\r\n        &quot;/downloads/json_log_string2object.jq&quot;,\r\n        &quot;/downloads/log_test.json&quot;,\r\n        &quot;/downloads/log_test.txt&quot;,\r\n        &quot;/downloads/test_logs.sh&quot;\r\n      ]\r\n    }\r\n\r\nbash script:\r\n\r\n    logfilename=&quot;log_test&quot;\r\n\r\n    writelogstring2object() {\r\n      exec 4&gt;&gt;&quot;${1}.json&quot;\r\n      flock -x 4\r\n      tee -a &quot;$1.txt&quot; | jq -sRf json_log_string2object.jq &gt;&amp;4\r\n    }\r\n    \r\n    writelogarray2object() {\r\n      exec 4&gt;&gt;&quot;${1}.json&quot;\r\n      flock -x 4\r\n      tee -a &quot;$1.txt&quot; | jq -nRf json_log_array2object.jq &gt;&amp;4\r\n    }\r\n  \r\n    exec 3&gt; &gt;(writelogstring2object &quot;$logfilename&quot;)\r\n    {\r\n    echo &quot;start process: $(date -u)&quot;\r\n    echo &quot;logfilename:&quot; $logfilename\r\n    } &gt;&amp;3\r\n    exec 3&gt;&amp;-\r\n    flock -s &quot;$logfilename.json&quot; -c :\r\n    \r\n    exec 3&gt; &gt;(writelogarray2object &quot;$logfilename&quot;)\r\n    {\r\n    echo &quot;start filelist:&quot;\r\n    printf &#39;%s\\n&#39; &quot;$PWD&quot;/*\r\n    } &gt;&amp;3\r\n    exec 3&gt;&amp;-\r\n    flock -s &quot;$logfilename.json&quot; -c :\r\n\r\njq programs:\r\n\r\njson_log_string2object.jq\r\n\r\n    def trim: sub(&quot;^ +&quot;;&quot;&quot;) | sub(&quot; +$&quot;;&quot;&quot;);\r\n    \r\n    def s2o:\r\n      (index(&quot;:&quot;) // empty) as $ix\r\n      | {(.[:$ix]): (.[$ix+1:]|trim)};\r\n    \r\n    split(&quot;\\n&quot;) | map(s2o) | add\r\n\r\njson_log_array2object.jq\r\n\r\n    foreach (inputs,null) as $line ({};\r\n       if $line == null then .emit = {(.key|tostring): .value}\r\n       elif $line[-1:] == &quot;:&quot;\r\n       then (if .key then {emit: {(.key): .value}} else null end)\r\n            + { key : $line[0:-1] }\r\n       else {key, value: (.value + [$line])}\r\n       end;\r\n       .emit // empty )\r\n\r\n\r\n\r\nAppreciate approaches and examples ",
        "link": "https://stackoverflow.com/questions/44149753/jq-to-convert-text-strings-and-add-them-into-an-existing-json-object",
        "title": "jq to convert text strings and add them into an existing json object"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1143565,
                    "reputation": 535973,
                    "user_id": 1126841,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa05233b2357f8d11c22ef4cfc7bb85c?s=256&d=identicon&r=PG",
                    "display_name": "chepner",
                    "link": "https://stackoverflow.com/users/1126841/chepner"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1495674894,
                "post_id": 44169813,
                "comment_id": 75357385,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1495680808,
                "last_edit_date": 1495680808,
                "creation_date": 1495667751,
                "answer_id": 44169922,
                "question_id": 44169813,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "It looks like .value contains an array; if so, then the jq query that matches your description would be:\r\n\r\n    .value | map( select(.label==&quot;this.com&quot;)) | .[0]\r\n\r\nIf there is no match, this will produce `null`, so you might want to make adjustments accordingly.\r\n\r\nIf you want the value of .ELEMENT in the first match, you could consider:\r\n\r\n    .value | map( select(.label==&quot;this.com&quot;)) | .[0] // empty | .ELEMENT\r\n\r\nIf your jq has `first/1`, a more efficient solution is possible:\r\n\r\n    first( .value[] | select(.label==&quot;this.com&quot;) ) | . ELEMENT",
                "title": "How do I parse multiple matches using jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1495680987,
        "creation_date": 1495667015,
        "last_edit_date": 1495680987,
        "question_id": 44169813,
        "body_markdown": "How do I get the first index of a query that contains multiple matches? I am trying to get the value of the first key called **ELEMENT** in this query:\r\n\r\n    ```\r\n    {\r\n      &quot;ELEMENT&quot;: &quot;FADC6B14-0369-4FF4-9ADC-A5E0F5C6D30D&quot;,\r\n      &quot;type&quot;: &quot;XCUIElementTypeStaticText&quot;,\r\n      &quot;label&quot;: &quot;this.com&quot;\r\n    }\r\n    {\r\n      &quot;ELEMENT&quot;: &quot;CC89DD73-AB90-495E-A90B-74722C56DD46&quot;,\r\n      &quot;type&quot;: &quot;XCUIElementTypeStaticText&quot;,\r\n      &quot;label&quot;: &quot;this.com&quot;\r\n    }\r\n    {\r\n      &quot;ELEMENT&quot;: &quot;B888ADA6-4209-44C4-BCB8-F5174312D102&quot;,\r\n      &quot;type&quot;: &quot;XCUIElementTypeStaticText&quot;,\r\n      &quot;label&quot;: &quot;this.com&quot;\r\n    }\r\n    {\r\n      &quot;ELEMENT&quot;: &quot;9A6E77C7-E93D-41DE-9163-2CB60B8DD2FB&quot;,\r\n      &quot;type&quot;: &quot;XCUIElementTypeStaticText&quot;,\r\n      &quot;label&quot;: &quot;this.com&quot;\r\n    }\r\n    ```\r\n\r\nHere is the cURL that produces this result:\r\n\r\n    curl -X POST $JSON_HEADER -d &quot;{\\&quot;using\\&quot;:\\&quot;partial link text\\&quot;,\\&quot;value\\&quot;:\\&quot;label=this.com\\&quot;}&quot; $DEVICE_URL/session/$SESSION_ID/elements | jq -r &#39;.value[] | select(.label==&quot;this.com&quot;)&#39;\r\n\r\n\r\nI was thinking it could be `label[0]==&quot;this.com&quot;` but I get the message **Cannot index string with number**",
        "link": "https://stackoverflow.com/questions/44169813/how-do-i-parse-multiple-matches-using-jq",
        "title": "How do I parse multiple matches using jq?"
    },
    {
        "tags": [
            "json",
            "count",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1495685923,
                "creation_date": 1495685923,
                "answer_id": 44172191,
                "question_id": 44171931,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Your input data doesn&#39;t seem to correspond exactly with your posting. I&#39;ll assume you meant:\r\n\r\n    [{&quot;name&quot;:&quot;mars&quot;,\r\n      &quot;runner&quot;:[{&quot;foo&quot;:null,&quot;idle&quot;:true},{&quot;foo&quot;:null,&quot;idle&quot;:true},{&quot;foo&quot;:null,&quot;idle&quot;:false}]},\r\n     {&quot;name&quot;:&quot;june&quot;,\r\n      &quot;runner&quot;:[{&quot;foo&quot;:null,&quot;idle&quot;:true},{&quot;foo&quot;:null,&quot;idle&quot;:true},{&quot;foo&quot;:null,&quot;idle&quot;:true}]}]\r\n\r\n### length\r\nA reasonable approach would be to rely on the builtin `length` function:\r\n\r\n    map( { name, idle: (.runner | map(select(.idle)) | length)} )\r\n\r\n### count\r\nA better (e.g. more efficient) solution would be to define a function that can count:\r\n\r\n    def count(s): reduce s as $i (0; .+1); \r\n\r\nHere `s` is any filter that produces a stream of values.  A solution to the problem at hand could then be written as follows:\r\n\r\n    map( {name, idle: count(.runner[] | select(.idle))} )\r\n\r\n### Output\r\nThe output in both cases:\r\n\r\n    [\r\n      {\r\n        &quot;name&quot;: &quot;mars&quot;,\r\n        &quot;idle&quot;: 2\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;june&quot;,\r\n        &quot;idle&quot;: 3\r\n      }\r\n    ]\r\n\r\n",
                "title": "Getting sum of values from object in array using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1495686298,
        "creation_date": 1495683911,
        "last_edit_date": 1495686298,
        "question_id": 44171931,
        "body_markdown": "I&#39;m trying to get the total amount for a specific value in a array.\r\nThe input would be something like\r\n\r\n    [{\r\n    \t&quot;name&quot;: &quot;mars&quot;,\r\n    \t&quot;runner&quot;:  [\r\n    \t\t{\r\n    \t\t&quot;foo&quot;: null,\r\n    \t\t&quot;idle&quot;: true\r\n    \t\t},\r\n    \t\t{\r\n    \t\t&quot;foo&quot;: null,\r\n    \t\t&quot;idle&quot;: true\r\n    \t\t},\r\n    \t\t{\r\n    \t\t&quot;foo&quot;: null,\r\n    \t\t&quot;idle&quot;: false\r\n    \t\t}\r\n    \r\n    \t],\r\n    \t\t&quot;name&quot;: &quot;june&quot;,\r\n    \t\t&quot;runner&quot;: [\r\n    \t\t{\r\n    \t\t&quot;foo&quot;: null,\r\n    \t\t&quot;idle&quot;: true\r\n    \t\t},\r\n    \t\t{\r\n    \t\t&quot;foo&quot;: null,\r\n    \t\t&quot;idle&quot;: true\r\n    \t\t},\r\n    \t\t{\r\n    \t\t&quot;foo&quot;: null,\r\n    \t\t&quot;idle&quot;: true\r\n    \t\t}\r\n    \t]\r\n    }]\r\n\r\nThe desired output\r\n\r\n&gt; [ {&quot;name&quot; : &quot;mars&quot;, &quot;idle&quot; : 2&quot;},{&quot;name&quot; : &quot;june&quot;, &quot;idle&quot; : 1&quot;} ]\r\n\r\nI tried using select and map, but I&#39;m not understanding exactly how jq is working, for instance, I tried the following query\r\n\r\n    jq  &#39; .[] | select(.runner[].idle == true) | {name: .name}&#39;\r\n\r\nThe result was\r\n\r\n&gt; {   &quot;nome&quot;: &quot;mars&quot; } {   &quot;nome&quot;: &quot;mars&quot; } {   &quot;nome&quot;: &quot;june&quot; } {  \r\n&gt; &quot;nome&quot;: &quot;june&quot; } {   &quot;nome&quot;: &quot;june&quot; }\r\n\r\n(3x true in june and 2x in mars) I can keep parsing the json and get to the result I want, but it doesn&#39;t seems right.",
        "link": "https://stackoverflow.com/questions/44171931/getting-sum-of-values-from-object-in-array-using-jq",
        "title": "Getting sum of values from object in array using jq"
    },
    {
        "tags": [
            "json",
            "object",
            "key",
            "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": 1495713052,
                "post_id": 44178362,
                "comment_id": 75373616,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 134685,
                    "reputation": 15242,
                    "user_id": 510036,
                    "user_type": "registered",
                    "accept_rate": 96,
                    "profile_image": "https://www.gravatar.com/avatar/b7c510641e6526d19abc93e866e75ac8?s=256&d=identicon&r=PG",
                    "display_name": "Qix - MONICA WAS MISTREATED",
                    "link": "https://stackoverflow.com/users/510036/qix-monica-was-mistreated"
                },
                "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": 1495765103,
                "post_id": 44178362,
                "comment_id": 75399021,
                "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": 1495766584,
                "post_id": 44178362,
                "comment_id": 75399350,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1495754098,
                "last_edit_date": 1495754098,
                "creation_date": 1495734665,
                "answer_id": 44186819,
                "question_id": 44178362,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "&gt; exclude the _children property from all objects that have it\r\n\r\nIf your jq has `walk/1` then you could:\r\n\r\n    walk( if type == &quot;object&quot; then del(._children) else . end )\r\n\r\nIf not, first include its jq definition (readily googleable) e.g. in ~/.jq\r\n\r\n&gt; What about all properties that start with _ ?\r\n\r\nFor this, you could also use `walk/1`. For clarity and maintainability, it would make sense to define a helper function:\r\n\r\n    def deleteall(f): with_entries(select(.key | f | not ));\r\n\r\nWhich you&#39;d invoke as: deleteall( startswith(&quot;_&quot;) )",
                "title": "How do you exclude a property?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1495767588,
        "creation_date": 1495708544,
        "last_edit_date": 1495767588,
        "question_id": 44178362,
        "body_markdown": "I have the following dataset:\r\n\r\n    [\r\n      {\r\n        &quot;py/object&quot;: &quot;bit.ast.Node&quot;,\r\n        &quot;_children&quot;: [\r\n          {\r\n            &quot;py/object&quot;: &quot;bit.ast.Node&quot;,\r\n            &quot;_children&quot;: [\r\n              &quot;main&quot;,\r\n              {\r\n                &quot;py/object&quot;: &quot;bit.ast.Node&quot;,\r\n                &quot;_children&quot;: [\r\n                  &quot;args&quot;,\r\n                  {\r\n                    &quot;py/object&quot;: &quot;bit.ast.Node&quot;,\r\n                    &quot;_children&quot;: [\r\n                      {\r\n                        &quot;py/object&quot;: &quot;bit.ast.Node&quot;,\r\n                        &quot;_children&quot;: [\r\n                          &quot;str&quot;\r\n                        ],\r\n                        &quot;source_column&quot;: 2,\r\n                        &quot;source_filename&quot;: &quot;tests/fixture/hello.b&quot;,\r\n                        &quot;source_line&quot;: 1,\r\n                        &quot;tag&quot;: &quot;type-named&quot;\r\n                      }\r\n                    ],\r\n                    &quot;base&quot;: {\r\n                      &quot;py/id&quot;: 10\r\n                    },\r\n                    &quot;source_column&quot;: 2,\r\n                    &quot;source_filename&quot;: &quot;tests/fixture/hello.b&quot;,\r\n                    &quot;source_line&quot;: 1,\r\n                    &quot;tag&quot;: &quot;type&quot;,\r\n                    &quot;type&quot;: &quot;array&quot;\r\n                  }\r\n                ],\r\n\r\n(and so on...)\r\n\r\nHow do I get `jq` to exclude the `_children` property from all objects that have it? What about all properties that start with `_`?\r\n\r\nNone of the following seem to work:\r\n\r\n    jq &#39;map(del (._children))&#39;\r\n    jq &#39;map(if has(&quot;_children&quot;) then del (._children) end)&#39;\r\n    jq &#39;del(._children)&#39;\r\n    jq &#39;del(.[]._children)&#39;\r\n    jq &#39;del(.[]|._children)&#39;\r\n\r\nI keep getting an error similar to:\r\n\r\n    jq: error (at &lt;stdin&gt;:1): Cannot index string with string &quot;_children&quot;",
        "link": "https://stackoverflow.com/questions/44178362/how-do-you-exclude-a-property",
        "title": "How do you exclude a property?"
    },
    {
        "tags": [
            "json",
            "shell",
            "awk",
            "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": 2,
                "creation_date": 1495901446,
                "post_id": 44215931,
                "comment_id": 75448587,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 2434269,
                    "reputation": 130,
                    "user_id": 2124559,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b9905f79eeb192ac01808ee928cb3298?s=256&d=identicon&r=PG",
                    "display_name": "dataman",
                    "link": "https://stackoverflow.com/users/2124559/dataman"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1646930845,
                "post_id": 44215931,
                "comment_id": 126251105,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1495883626,
                "last_edit_date": 1495883626,
                "creation_date": 1495883280,
                "answer_id": 44216101,
                "question_id": 44215931,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Assuming you don&#39;t care about the exact filenames, if you want to split input into multiple files, just use [`split`](http://man7.org/linux/man-pages/man1/split.1.html).\r\n\r\n    jq -c . &lt; cities.json | split -l 1 --additional-suffix=.json - .chunks/cities_",
                "title": "Split JSON into multiple files"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1495895222,
                "creation_date": 1495895222,
                "answer_id": 44218024,
                "question_id": 44215931,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "In general to split any text file into separate files per-line using any awk on any UNIX system is simply:\r\n\r\n    awk &#39;{close(f); f=&quot;.chunks/cities_&quot;NR&quot;.json&quot;; print &gt; f}&#39; cities.json",
                "title": "Split JSON into multiple files"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 3,
        "last_activity_date": 1526398404,
        "creation_date": 1495882249,
        "last_edit_date": 1526398404,
        "question_id": 44215931,
        "body_markdown": "I have json file exported from mongodb which looks like:\r\n\r\n    {&quot;_id&quot;:&quot;99919&quot;,&quot;city&quot;:&quot;THORNE BAY&quot;}\r\n    {&quot;_id&quot;:&quot;99921&quot;,&quot;city&quot;:&quot;CRAIG&quot;}\r\n    {&quot;_id&quot;:&quot;99922&quot;,&quot;city&quot;:&quot;HYDABURG&quot;}\r\n    {&quot;_id&quot;:&quot;99923&quot;,&quot;city&quot;:&quot;HYDER&quot;}\r\nthere are about 30000 lines, I want to split each line into it&#39;s own `.json` file. *(I&#39;m trying to transfer my data onto couchbase cluster)*\r\n\r\nI tried doing this:\r\n\r\n    cat cities.json | jq -c -M &#39;.&#39; | \\\r\n    while read line; do echo $line &gt; .chunks/cities_$(date +%s%N).json; done\r\nbut I found that it seems to drop loads of line and the output of running this command only gave me 50 odd files when I was expecting 30000 odd!!\r\n\r\nIs there a logical way to make this not drop any data using anything that would suite?",
        "link": "https://stackoverflow.com/questions/44215931/split-json-into-multiple-files",
        "title": "Split JSON into multiple files"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1496212244,
                "last_edit_date": 1496212244,
                "creation_date": 1496157240,
                "answer_id": 44265972,
                "question_id": 44265085,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "For clarity, let&#39;s first define a jq helper function for modifying the key/value pairs:\r\n\r\n\r\n    def munge: {ParameterKey: .OutputKey, ParameterValue: .OutputValue};\r\n\r\nLet&#39;s also assume that the contents of vpc.json is available as the jq variable $vpc --\r\n this can be accomplished (for example) as shown below.  \r\n\r\nThe update can then be performed by this jq filter:\r\n\r\n    . + (($vpc | map(munge)) - .)\r\n\r\nThe following invocation is one of several possibilities but has the advantage of not requiring the most recent jq version:\r\n\r\n    jq -f vpc.jq --argfile vpc vpc.json parameters.json\r\n\r\n### Variations\r\nDepending on the detailed requirements, more efficient variations might be possible.  For example, if the order of the key/value pairs is unimportant:\r\n\r\n    (. + ($vpc | map(munge))) | unique\r\n\r\nConversely, to avoid duplication within ($vpc|map(munge)) while preserving the ordering:\r\n\r\n    reduce ($vpc[] | munge) as $new\r\n      (.; if index($new) then . else . + [$new] end)\r\n\r\n\r\n\r\n\r\n\r\n\r\n",
                "title": "More concise jq code to get each value from file and place in another"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1496212244,
        "creation_date": 1496154640,
        "last_edit_date": 1496158617,
        "question_id": 44265085,
        "body_markdown": "My goal is to get each value of a group of keypairs, and insert each into another file. I could do this line by line, but is there a cleaner way to add them all at once?\r\n\r\nI have the result of an aws query which gives me the following file called `vpc.json` (with sensitive info stripped);\r\n\r\n    [\r\n        {\r\n            &quot;Description&quot;: &quot;Client VpcId&quot;, \r\n            &quot;OutputKey&quot;: &quot;VpcId&quot;, \r\n            &quot;OutputValue&quot;: &quot;vpc-a12345&quot;\r\n        }, \r\n        {\r\n            &quot;OutputKey&quot;: &quot;ServiceSubnet1&quot;, \r\n            &quot;OutputValue&quot;: &quot;subnet-b12345&quot;\r\n        }, \r\n        {\r\n            &quot;OutputKey&quot;: &quot;PublicSubnet1&quot;, \r\n            &quot;OutputValue&quot;: &quot;subnet-c12345&quot;\r\n        }, \r\n        {\r\n            &quot;OutputKey&quot;: &quot;ServiceSubnet0&quot;, \r\n            &quot;OutputValue&quot;: &quot;subnet-d12345&quot;\r\n        }, \r\n        {\r\n            &quot;OutputKey&quot;: &quot;PublicSubnet0&quot;, \r\n            &quot;OutputValue&quot;: &quot;subnet-e12345&quot;\r\n        }\r\n    ]\r\n\r\nAnd I&#39;d like each value to end up in `parameters.json`, which already has a bunch of other keypairs, with the final file looking like;\r\n\r\n    [\r\n      {\r\n        ...\r\n      },\r\n      {\r\n        &quot;ParameterKey&quot;: &quot;VpcId&quot;,\r\n        &quot;ParameterValue&quot;: &quot;vpc-a12345&quot;\r\n      },\r\n      {\r\n        &quot;ParameterKey&quot;: &quot;ServiceSubnet0&quot;,\r\n        &quot;ParameterValue&quot;: &quot;subnet-b12345&quot;\r\n      },\r\n      {\r\n        &quot;ParameterKey&quot;: &quot;ServiceSubnet1&quot;,\r\n        &quot;ParameterValue&quot;: &quot;subnet-c12345&quot;\r\n      },\r\n      {\r\n        &quot;ParameterKey&quot;: &quot;PublicSubnet0&quot;,\r\n        &quot;ParameterValue&quot;: &quot;subnet-d12345&quot;\r\n      },\r\n      {\r\n        &quot;ParameterKey&quot;: &quot;PublicSubnet1&quot;,\r\n        &quot;ParameterValue&quot;: &quot;subnet-e12345&quot;\r\n      }\r\n    ]\r\n\r\nRight now I can &quot;easily&quot; achieve this with the following code. This would be the snippet required just for the `VpcId` pair, meaning I would have to duplicate it x5, one for each keypair. \r\n\r\nThe code checks to see if the keypair already exists, adding it if not (necessary because this needs to be backwards compatible with older files). It then gets the relevant value from the vpc file and places it in the parameters file.\r\n\r\n    if ! grep -q &quot;VpcId&quot; parameters.json\r\n        then\r\n            jq --argjson obj &#39;{ &quot;ParameterKey&quot;: &quot;VpcId&quot;, &quot;ParameterValue&quot;: &quot;&quot; }&#39; &#39;. += [$obj]&#39; &lt;parameters.json | sponge parameters.json\r\n    fi\r\n    \r\n    keyVpc=$(jq -r &#39;.[] | select(.OutputKey==&quot;VpcId&quot;) | .OutputValue&#39; &lt; vpc.json)\r\n    \r\n    jq --arg keyVpc &quot;$keyVpc&quot; &#39;(.[] | select(.ParameterKey == &quot;VpcId&quot;) | .ParameterValue) |= $keyVpc&#39; ${parameters.json | sponge parameters.json\r\n\r\nI have to imagine that there&#39;s a better way to do this that doesn&#39;t require 5 copies of the same three lines. The keys will always be the same names, but the values will change. ",
        "link": "https://stackoverflow.com/questions/44265085/more-concise-jq-code-to-get-each-value-from-file-and-place-in-another",
        "title": "More concise jq code to get each value from file and place in another"
    },
    {
        "tags": [
            "json",
            "parsing",
            "data-manipulation",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1496200799,
                "creation_date": 1496200799,
                "answer_id": 44275064,
                "question_id": 44271503,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The requirements are not entirely clear in several respects, but the following query matches the description and produces the two values that it should, assuming the example input has been modified to become valid JSON:\r\n\r\n    .two[]\r\n    | select( .ab.abb | type == &quot;array&quot;)\r\n    | select( .ab.abb[] | test(&quot;tata&quot;) )\r\n    | [ .ac[],.aa[] ]\r\n\r\n(You wouldn&#39;t need the second line above if `.two` is as regular as stated. Also, if your jq does not have `test/1`, then you could upgrade or use `index/1` instead.)\r\n\r\nWith the given input, after rectification, invocation of jq with the -c option produces:\r\n\r\n    [&quot;ac_value_1&quot;,&quot;aa_value_1&quot;]\r\n\r\n",
                "title": "JSON file parsing in linux with JQ, select some elements depending on value contained in a specific element"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1496206751,
        "creation_date": 1496176705,
        "last_edit_date": 1496206751,
        "question_id": 44271503,
        "body_markdown": "I&#39;m a new jq user and I have some difficult to find the good way for my problem. \r\n\r\nI have this sample json file : \r\n\r\n    {\r\n    \t&quot;one&quot;:&quot;one_value&quot;,\r\n    \t&quot;two&quot;: [\r\n    \t\t{ // sub structure 0\r\n    \t\t\t&quot;aa&quot; : [\r\n    \t\t\t\t&quot;aa_value_0&quot;\r\n    \t\t\t],\r\n    \t\t\t&quot;ab&quot; : { ... },\r\n    \t\t\t&quot;ac&quot; : [\r\n    \t\t\t\t&quot;ac_value_0&quot;\r\n    \t\t\t] \r\n    \t\t},\r\n    \t\t{ // sub structure 1\r\n    \t\t\t&quot;aa&quot;: [\r\n    \t\t\t\t&quot;aa_value_1&quot;\r\n    \t\t\t],\r\n    \t\t\t&quot;ab&quot;: {\r\n    \t\t\t\t&quot;aba&quot;: [\r\n    \t\t\t\t\t&quot;aba_value_1&quot;\r\n    \t\t\t\t],\r\n    \t\t\t\t&quot;abb&quot;: [\r\n    \t\t\t\t\t&quot;tototatatiti&quot;\r\n    \t\t\t\t],\r\n    \t\t\t\t&quot;abc&quot;: [\r\n    \t\t\t\t\t&quot;abc_value_1&quot;\r\n    \t\t\t\t]\r\n    \t\t\t},\r\n    \t\t\t&quot;ac&quot;: [\r\n    \t\t\t\t&quot;ac_value_1&quot;\r\n    \t\t\t]\r\n    \t\t},\r\n    \t\t{ // sub structure 2\r\n    \t\t\t&quot;aa&quot; : ...\r\n    \t\t\t...\r\n    \t\t},\r\n    \t\t...\r\n    \t\t{ // sub structure x\r\n    \t\t\t&quot;aa&quot; : ...\r\n    \t\t\t...\r\n    \t\t}\r\n    \t]\r\n    }\r\n\r\nI have an array named &quot;two&quot; who contains several sub structures (sub structure 0, sub structure 1, sub structure 2, ..., sub structure x). I want select the &#39;ac&#39; and &#39;aa&#39; values where ab.abb key (in the same sub structure) contains a specific word.\r\nAll sub structures have the same structure. \r\n\r\nIn my example, if I search the word &quot;tata&quot;, I must obtain the values &quot;aa_value_1&quot; and &quot;ac_value_1&quot; because in the sub structure &quot;1&quot;, the ab.abb field contains the word &quot;tata&quot; (tototatatiti)\r\n\r\nHow can I do that ? \r\nThank you :) \r\n\r\n  [1]: https://stedolan.github.io/jq/",
        "link": "https://stackoverflow.com/questions/44271503/json-file-parsing-in-linux-with-jq-select-some-elements-depending-on-value-cont",
        "title": "JSON file parsing in linux with JQ, select some elements depending on value contained in a specific element"
    },
    {
        "tags": [
            "bash",
            "error-handling",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1496236417,
                "post_id": 44282020,
                "comment_id": 75578296,
                "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": 1,
                "creation_date": 1496236535,
                "post_id": 44282020,
                "comment_id": 75578390,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 36086,
                    "reputation": 5053,
                    "user_id": 102699,
                    "user_type": "registered",
                    "accept_rate": 67,
                    "profile_image": "https://www.gravatar.com/avatar/81df87e0d3e269d6fa6a17c6914fd656?s=256&d=identicon&r=PG",
                    "display_name": "MikeSchinkel",
                    "link": "https://stackoverflow.com/users/102699/mikeschinkel"
                },
                "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": 1496269598,
                "post_id": 44282020,
                "comment_id": 75597485,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 36086,
                    "reputation": 5053,
                    "user_id": 102699,
                    "user_type": "registered",
                    "accept_rate": 67,
                    "profile_image": "https://www.gravatar.com/avatar/81df87e0d3e269d6fa6a17c6914fd656?s=256&d=identicon&r=PG",
                    "display_name": "MikeSchinkel",
                    "link": "https://stackoverflow.com/users/102699/mikeschinkel"
                },
                "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": 1496269929,
                "post_id": 44282020,
                "comment_id": 75597587,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 36086,
                    "reputation": 5053,
                    "user_id": 102699,
                    "user_type": "registered",
                    "accept_rate": 67,
                    "profile_image": "https://www.gravatar.com/avatar/81df87e0d3e269d6fa6a17c6914fd656?s=256&d=identicon&r=PG",
                    "display_name": "MikeSchinkel",
                    "link": "https://stackoverflow.com/users/102699/mikeschinkel"
                },
                "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": 1496270008,
                "post_id": 44282020,
                "comment_id": 75597618,
                "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": 1,
                "creation_date": 1496273654,
                "post_id": 44282020,
                "comment_id": 75598617,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 36086,
                    "reputation": 5053,
                    "user_id": 102699,
                    "user_type": "registered",
                    "accept_rate": 67,
                    "profile_image": "https://www.gravatar.com/avatar/81df87e0d3e269d6fa6a17c6914fd656?s=256&d=identicon&r=PG",
                    "display_name": "MikeSchinkel",
                    "link": "https://stackoverflow.com/users/102699/mikeschinkel"
                },
                "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": 1496274400,
                "post_id": 44282020,
                "comment_id": 75598803,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1496227368,
                "last_edit_date": 1592644375,
                "creation_date": 1496226663,
                "answer_id": 44282328,
                "question_id": 44282020,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use a flag in `jq` to propagate the exit code of `jq` to shell which you can use in your command to see if it succeeded.\n\nThe official [jq-documentation](https://stedolan.github.io/jq/manual/) provides just the right option for this,\n\n&gt;-e / --exit-status:\n&gt;\n&gt;Sets the exit status of `jq` to `0` if the last output values was neither `false` nor `null`, `1` if the last output value was either `false` or `null`, or `4` if no valid result was ever produced. Normally `jq` exits with `2` if there was any usage problem or system error, `3` if there was a `jq` program compile error, or `0` if the `jq` program ran.\n\nYou can see it used as follows:-\n\n    jsonStr=&#39;{&quot;foo&quot;: 42, &quot;bar&quot;: &quot;less interesting data&quot;}&#39;\n    jq -er &#39;.foo&#39; &lt;&lt;&lt;&quot;$jsonStr&quot;\n    42\n    echo $?\n    0\n\nNow for the failure case, \n\n    jq -er &#39;.foo1&#39; &lt;&lt;&lt;&quot;$jsonStr&quot;\n    null\n    echo $?\n    1\n\nDo remember that the above case _would not_ be possible if you don&#39;t set the `-e` flag because refer to the last line of the above clause \n\n&gt;or `0` if the `jq` program ran\n\nSo the error codes are _not_ propagated to the shell unless you set the `-e` flag.\n\n(or) a more meaningful shell construct using an if-clause would be to do following,\n\n    jsonStr=&#39;{&quot;foo&quot;: 42, &quot;bar&quot;: &quot;less interesting data&quot;}&#39;\n    \n    if jq -er &#39;.foo&#39; &lt;&lt;&lt;&quot;$jsonStr&quot; &gt; /dev/null; then\n        printf &quot;string contained foo\\n&quot;\n    fi\n\nand for the failure case,\n\n    if jq -er &#39;.foo1&#39; &lt;&lt;&lt;&quot;$jsonStr&quot; &gt; /dev/null; then\n        printf &quot;string contained foo\\n&quot;\n    else\n        printf &quot;string does not contain foo\\n&quot;\n    fi \n\nwhich if you observe carefully will go to the `else` part for the failure case which is your intention. Without the `-e` flag set, the failure case exit code would still be `0` and the true condition would have been met.\n\nThe `&gt;/dev/null` part is just to suppress the `stdout` the command `jq` produces to a null stream.\n\nAlso note that the `-e` was introduced only from [jq-1.4](https://stedolan.github.io/jq/manual/v1.4/) onwards.",
                "title": "How to validate a query in jq 1.5 in macOS/Linux bash?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1496251761,
                "creation_date": 1496251761,
                "answer_id": 44291227,
                "question_id": 44282020,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Please note that if you use the `-e` option, then the JSON value `false` will also trigger an error condition.\r\n\r\nIf the goal is to be able to distinguish the JSON value `null` from the JSON string `&quot;null&quot;`,\r\nthen please note that that could also be done by NOT using the &#39;-r&#39; option.  \r\n\r\nIf you really need the result as though produced by `jq -r`, then consider first setting the shell variable using `jq &quot;$query&quot;` and\r\nthen invoking jq again with the -r option.\r\n",
                "title": "How to validate a query in jq 1.5 in macOS/Linux bash?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1496441501,
                "creation_date": 1496441501,
                "answer_id": 44338131,
                "question_id": 44282020,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "I (being a jq noob) would validate it like this:\r\n\r\n    query()(\r\n      local q=$1\r\n      local json=&#39;{&quot;foo&quot;:&quot;bar&quot;}&#39;\r\n      local value=$(jq -r &quot;if($q) then $q else empty end&quot; &lt;&lt;&lt;&quot;$json&quot; 2&gt;/dev/null)\r\n      if ! test -n &quot;$value&quot;; then\r\n        echo &quot;You&#39;ve done it all wrong&quot;\r\n        return 1\r\n      fi &gt;&amp;2\r\n      echo &quot;$value&quot;\r\n    )\r\n\r\nIn action:\r\n&lt;code&gt;\r\n$ query foo\r\nYou&#39;ve done it all wrong\r\n$ query .foo\r\nbar\r\n$ echo $?\r\n0\r\n$ query .foo1\r\nYou&#39;ve done it all wrong\r\n$ echo $?\r\n1\r\n&lt;/code&gt;",
                "title": "How to validate a query in jq 1.5 in macOS/Linux bash?"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 2,
        "last_activity_date": 1496441501,
        "creation_date": 1496225838,
        "last_edit_date": 1496269438,
        "question_id": 44282020,
        "body_markdown": "I am trying my darnedest to figure out how to tell a user of one of my scripts that they passed a query that is invalid per [`jq 1.5`](https://stedolan.github.io/jq/manual/v1.5/).\r\n\r\nHere is a simple example JSON:\r\n\r\n    { &quot;foo&quot;: { &quot;bar&quot;:&quot;baz&quot; } } \r\n\r\nI want to be able to present an error message to my user when they provide a query like `.foo.bax` but have it return the value `baz` when they provide a correct query like `.foo.bar`.\r\n\r\nI cannot _(or do not know how to)_ read `jq`&#39;s return values because I need to run `jq` in a subshell, i.e.:\r\n\r\n    value=&quot;$(echo -e &quot;${json}&quot; | jq -r &quot;${query}&quot;)&quot;\r\n\r\nThe `jq` always return a `null` string when I give it an invalid query.  But I cannot differentiate that from a value of `null` that might be contained in a JSON file as `&quot;property&quot;: &quot;null&quot;`.\r\n\r\nIt appears `jq` has various functions that I might be able to use for this, but I cannot figure out how I would use them.\r\n\r\nSo is there any way to get `jq` to validate a query where I can tell the difference between a `null` and a `&quot;null&quot;`? \r\n\r\n------------\r\n**UPDATE**\r\n\r\nWhat I was hoping to find when I asked the question is a syntax that would be roughly equivalent to `&quot;$(jq.validate(&quot;${query}&quot;) &amp;&amp; echo &quot;valid&quot;)&quot;`, assuming `jq` had a `validate()` method.\r\n",
        "link": "https://stackoverflow.com/questions/44282020/how-to-validate-a-query-in-jq-1-5-in-macos-linux-bash",
        "title": "How to validate a query in jq 1.5 in macOS/Linux bash?"
    },
    {
        "tags": [
            "arrays",
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 42,
                "is_accepted": true,
                "score": 42,
                "last_activity_date": 1542228540,
                "last_edit_date": 1542228540,
                "creation_date": 1496245135,
                "answer_id": 44289083,
                "question_id": 44288635,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Adding &quot;else empty&quot; gets the right result\r\n\r\n    jq &#39;[ .[] | if length &gt; 0 then . else empty end ]&#39;\r\n\r\nConsider using select instead.\r\n\r\n    jq &#39;[ .[] | select(length &gt; 0) ]&#39;\r\n\r\nAnd since map(x) is equivalent to `[.[] | x]`, we can do this.\r\n\r\n    jq &#39;map(select(length &gt; 0))&#39;\r\n",
                "title": "Remove blank strings from array with jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 21,
        "last_activity_date": 1542228540,
        "creation_date": 1496243885,
        "question_id": 44288635,
        "body_markdown": "How does one remove blank string items from an array in jq?\r\n\r\nThis is my best guess, but it doesn&#39;t appear to work:\r\n\r\n**Attempt**\r\n\r\n    echo &#39;[&quot;bob&quot;,&quot;&quot;,&quot;tim&quot;,&quot;&quot;]&#39; | jq &#39;[ . [] | if length &gt; 0 then . end ]&#39;\r\n\r\n**Desired output:**\r\n\r\n    [&quot;bob&quot;, &quot;tim&quot;]\r\n\r\n**Error:**\r\n\r\n    . [] | if length &gt; 0 then . end                            \r\n    jq: error: Possibly unterminated &#39;if&#39; statement at &lt;top-level&gt;, line 1:\r\n    . [] | if length &gt; 0 then . end       \r\n    jq: 2 compile errors\r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/44288635/remove-blank-strings-from-array-with-jq",
        "title": "Remove blank strings from array with jq?"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 386425,
                    "reputation": 57870,
                    "user_id": 744178,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/a3193139ea494c45e63752504f5ff1f2?s=256&d=identicon&r=PG",
                    "display_name": "jwodder",
                    "link": "https://stackoverflow.com/users/744178/jwodder"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1496256865,
                "post_id": 44292555,
                "comment_id": 75591649,
                "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": 2,
                "creation_date": 1496259214,
                "post_id": 44292555,
                "comment_id": 75592975,
                "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": 1143565,
                    "reputation": 535973,
                    "user_id": 1126841,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa05233b2357f8d11c22ef4cfc7bb85c?s=256&d=identicon&r=PG",
                    "display_name": "chepner",
                    "link": "https://stackoverflow.com/users/1126841/chepner"
                },
                "edited": false,
                "score": 3,
                "creation_date": 1496262482,
                "post_id": 44292555,
                "comment_id": 75594648,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 9754,
                    "reputation": 26532,
                    "user_id": 18149,
                    "user_type": "registered",
                    "accept_rate": 80,
                    "profile_image": "https://www.gravatar.com/avatar/f5e10278b9b6a518d5835f658704d85f?s=256&d=identicon&r=PG",
                    "display_name": "leeand00",
                    "link": "https://stackoverflow.com/users/18149/leeand00"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1496881839,
                "post_id": 44292555,
                "comment_id": 75848016,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1501977562,
                "creation_date": 1501977562,
                "answer_id": 45527392,
                "question_id": 44292555,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "To start with, the [jq manual.yml](https://github.com/stedolan/jq/blob/master/docs/content/3.manual/manual.yml#L20-L32) describes the behavior of filters this way:\r\n\r\n&gt; Some filters produce multiple results, for instance there&#39;s one that\r\n  produces all the elements of its input array. Piping that filter\r\n  into a second runs the second filter for each element of the\r\n  array. Generally, things that would be done with loops and iteration\r\n  in other languages are just done by gluing filters together in jq.\r\n  \r\n&gt; It&#39;s important to remember that every filter has an input and an\r\n  output. Even literals like &quot;hello&quot; or 42 are filters - they take an\r\n  input but always produce the same literal as output. Operations that\r\n  combine two filters, like addition, generally feed the same input to\r\n  both and combine the results. So, you can implement an averaging\r\n  filter as `add / length` - feeding the input array both to the `add`\r\n  filter and the `length` filter and then performing the division.\r\n\r\nIt&#39;s also important to keep in mind that the default behavior of jq is to run the filter you specify once for each JSON object.  In the following example, jq runs the identity filter four times passing one value to it each time:\r\n\r\n    $ (echo 2;echo {}; echo []; echo 3) | jq .\r\n    2\r\n    {}\r\n    []\r\n    3\r\n\r\nWhat is happening here is similar to\r\n\r\n    $ jq -n &#39;2, {}, [], 3 | .&#39;\r\n    2\r\n    {}\r\n    []\r\n    3\r\n\r\nSince this isn&#39;t always what you want, the `-s` option can be used to tell jq to gather the separate values into an array and feed that to the filter:\r\n\r\n    $ (echo 2;echo {}; echo []; echo 3)| jq -s .\r\n    [\r\n      2,\r\n      {},\r\n      [],\r\n      3\r\n    ]\r\n\r\nwhich is similar to\r\n\r\n    $ jq -n &#39;[2, {}, [], 3] | .&#39;\r\n    [\r\n      2,\r\n      {},\r\n      [],\r\n      3\r\n    ]\r\n\r\nThe [jq manual.yml](https://github.com/stedolan/jq/blob/master/docs/content/3.manual/manual.yml#L130-L135) explains how the `--raw-input`/`-R` option can be included for even more control over input handing:\r\n\r\n&gt; Don&#39;t parse the input as JSON. Instead, each line of text is passed to the filter as a string. If combined with `--slurp`,then the entire input is passed to the filter as a single long string.\r\n\r\nYou can see using the `-s` and `-R` options together in this example produces a different result:\r\n\r\n    $ (echo 2;echo {}; echo []; echo 3)| jq -s -R .\r\n    &quot;2\\n{}\\n[]\\n3\\n&quot;\r\n\r\n",
                "title": "What is it called when you have multiple data structures, but not connected with json in jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1501977562,
        "creation_date": 1496256517,
        "last_edit_date": 1496256779,
        "question_id": 44292555,
        "body_markdown": "For instance, I might have something coming out of my `jq` command like this:\r\n\r\n    &quot;some string&quot;\r\n    &quot;some thing&quot;\r\n    &quot;some ping&quot;\r\n    ...\r\n\r\nNote that there is no outer object or array and no commas between items.\r\n\r\nOr you might have something like:\r\n\r\n    [&quot;some string&quot;\r\n    &quot;some thing&quot;\r\n    &quot;some ping&quot;]\r\n    [&quot;some wing&quot;\r\n    &quot;some bling&quot;\r\n    &quot;some fing&quot;]\r\n\r\nBut again, no commas or outer object or array and no commas between them to indicate that this is JSON.\r\n\r\nI keep thinking the answer is that it is called &quot;raw&quot;, but I&#39;m uncertain about this.\r\n\r\nI&#39;m specifically looking for a term to look for in the documentation that allows you to process the sorts of examples above, and I am at a loss as how to proceed.",
        "link": "https://stackoverflow.com/questions/44292555/what-is-it-called-when-you-have-multiple-data-structures-but-not-connected-with",
        "title": "What is it called when you have multiple data structures, but not connected with json in jq?"
    },
    {
        "tags": [
            "json",
            "linux",
            "shell",
            "sh",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1496259673,
                "creation_date": 1496259673,
                "answer_id": 44293427,
                "question_id": 44293386,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "    jq -r &#39;.instances[] | select(.state==&quot;ON&quot;) | .id&#39;",
                "title": "How can I filter objects selected w/ jq based on other values?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1496260154,
        "creation_date": 1496259524,
        "last_edit_date": 1496260154,
        "question_id": 44293386,
        "body_markdown": "I&#39;m trying to get hold of one of the field values depending on another field&#39;s value.\r\n\r\n    {  \r\n       &quot;dirty&quot;: &quot;false&quot;,\r\n       &quot;instances&quot;: {  \r\n          &quot;random-generated-id-1&quot;: {  \r\n             &quot;state&quot;: &quot;ON&quot;,\r\n             &quot;id&quot;: &quot;random-generated-id-1&quot;\r\n          },\r\n          &quot;random-generated-id-2&quot;: {\r\n             &quot;state&quot;: &quot;OFF&quot;,\r\n             &quot;id&quot;: &quot;random-generated-id-2&quot;\r\n          }\r\n       }\r\n    }\r\n\r\nI want to get `id` of the instance which is in `ON` state.\r\n\r\n`jq &quot;.instances&quot;` gives me both the instances. How do I get only `random-generated-id-1`?",
        "link": "https://stackoverflow.com/questions/44293386/how-can-i-filter-objects-selected-w-jq-based-on-other-values",
        "title": "How can I filter objects selected w/ jq based on other values?"
    },
    {
        "tags": [
            "function",
            "key",
            "refactoring",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1496292821,
                "last_edit_date": 1496292821,
                "creation_date": 1496266473,
                "answer_id": 44295045,
                "question_id": 44294127,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "1. The abbreviation &#39;.x.y&#39; will not work if y is a variable. Use the syntax &#39;.x | .[ y ]&#39; instead.\r\n\r\n2. &#39;E as $i| $i&#39; can be written as &#39;E&#39; in this case.\r\n\r\n3. Your definition should be either:\r\n\r\n&lt;/&gt;\r\n\r\n    def getThese(x): .them | .[x];\r\n\r\nor with different semantics (and requiring a sufficiently recent version of jq):\r\n\r\n    def getThese($x): .them | .[$x];\r\n\r\n4. One alternative would be to define `getThem` as:\r\n\r\n&lt;/&gt;\r\n\r\n    def getThem(f): .them | f;\r\n\r\nThis would allow you to write: `getThem(.keyName)` for keys with unexceptional names.",
                "title": "Refactoring jq with a variable key name?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1496292907,
        "creation_date": 1496262559,
        "last_edit_date": 1496292907,
        "question_id": 44294127,
        "body_markdown": "Is there a way to refactor `jq` into functions?\r\n\r\n**Prior to refactor:** \r\n\r\n    jq &#39; .them .&quot;keyName&quot; &#39; ./some.json\r\n\r\n**After refactor:**\r\n\r\n    def getThese(x): .them .$x;\r\n\r\nin **~/.jq**\r\n\r\nand then call it with...\r\n\r\n    jq &#39; getThese(&quot;keyName&quot;) as $i | $i &#39; ./some.json\r\n\r\nThe above refactor does not appear to work (is there a way?)",
        "link": "https://stackoverflow.com/questions/44294127/refactoring-jq-with-a-variable-key-name",
        "title": "Refactoring jq with a variable key name?"
    },
    {
        "tags": [
            "json",
            "parsing",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1496274394,
                "post_id": 44295432,
                "comment_id": 75598802,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1496296538,
                "creation_date": 1496296538,
                "answer_id": 44299504,
                "question_id": 44295432,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The only way that `.foo | select(.faa | test(&quot;word&quot;))` could produce\r\nmore than one JSON value is if the input consists of a stream of\r\nobjects. Thus, the following will assume that that is the case.\r\n\r\nOne way to solve the given problem is to use the -s command-line option.\r\n\r\nYou can then simply count the number of solutions, along\r\nthe following lines:\r\n\r\n    map(.foo | select(.faa | test(&quot;word&quot;)))\r\n    | if (length == 1) then map(.fii)\r\n      else map(.fuu)\r\n      end\r\n\r\nIf you want a stream of values, rather than an array, then you\r\ncould simply append `| .[]` to the above filter.\r\n\r\n### Using `inputs`\r\n\r\njq 1.5 introduced `inputs`, which avoids some potential problems with &quot;slurping&quot; a large file.  Using jq with the -n option, a solution to the given problem would be as above but with the first line replaced by:\r\n\r\n    [inputs | .foo | select(.faa | test(&quot;word&quot;)) ]\r\n",
                "title": "Parsing json file via JQ, when the result depends on the number of elements selected"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1496296753,
        "creation_date": 1496268525,
        "last_edit_date": 1496296753,
        "question_id": 44295432,
        "body_markdown": "Depending the context, my jq query select one or several elements. If my query return one element I want display a specific field value, else, I want display an another field value. \r\n\r\nBy example, I have this simple query : \r\n\r\njq &#39;.foo | select(.faa&#160;| test(&quot;word&quot;)) | [ .fii, .fuu ]\r\n\r\nSometimes, the selection (select (.faa ... )) return one element, sometimes severals elements. If I have one element, I want display only the field .fii, else, I want display only the field .fuu.\r\nIs there a way for do that with jq ? (with only one query)\r\n\r\nThank :)",
        "link": "https://stackoverflow.com/questions/44295432/parsing-json-file-via-jq-when-the-result-depends-on-the-number-of-elements-sele",
        "title": "Parsing json file via JQ, when the result depends on the number of elements selected"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3842961,
                    "reputation": 93062,
                    "user_id": 3185459,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/u8EuP.jpg?s=256",
                    "display_name": "RomanPerekhrest",
                    "link": "https://stackoverflow.com/users/3185459/romanperekhrest"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1496308317,
                "post_id": 44303178,
                "comment_id": 75611724,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": false,
                "score": 5,
                "last_activity_date": 1496308706,
                "creation_date": 1496308706,
                "answer_id": 44303438,
                "question_id": 44303178,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You need to use the [update assignment operator][1] `|=`:\r\n\r\n    jq &#39;(.Details[]|={entry_date:&quot;\\(.entry_day) \\(.entry_month)&quot;})&#39; input.json\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/#Assignment",
                "title": "append values of objects inside array using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1496308706,
        "creation_date": 1496308106,
        "last_edit_date": 1496308671,
        "question_id": 44303178,
        "body_markdown": "I have an object which has an array of objects. I am willing to append two properties of each object inside the array and create a new key out of that. I am new to JQ and have tried various ways to do this, but not able to figure out. Need help.\r\n\r\nInput:\r\n\r\n    {\r\n      &quot;name&quot;: &quot;Toyota&quot;,\r\n      &quot;Model&quot;: &quot;Innova&quot;,\r\n      &quot;Details&quot;: [\r\n        {\r\n          &quot;entry_day&quot;: &quot;23&quot;,\r\n          &quot;entry_month&quot;: &quot;May&quot;\r\n        },\r\n        {\r\n          &quot;entry_day&quot;: &quot;01&quot;,\r\n          &quot;entry_month&quot;: &quot;Jan&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\nOutput I expect:\r\n\r\n    {\r\n    \t&quot;name&quot;: &quot;Toyota&quot;,\r\n    \t&quot;Model&quot;: &quot;Innova&quot;,\t\r\n    \t&quot;Details&quot;: [\r\n    \t\t{\r\n    \t\t\t&quot;entry_date&quot;: &quot;23 May&quot;\r\n    \t\t},\r\n    \t\t{\r\n    \t\t\t&quot;entry_date&quot;: &quot;01 Jan&quot;\r\n    \t\t}\r\n    \t]\r\n    }",
        "link": "https://stackoverflow.com/questions/44303178/append-values-of-objects-inside-array-using-jq",
        "title": "append values of objects inside array using jq"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3842961,
                    "reputation": 93062,
                    "user_id": 3185459,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/u8EuP.jpg?s=256",
                    "display_name": "RomanPerekhrest",
                    "link": "https://stackoverflow.com/users/3185459/romanperekhrest"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1496400995,
                "post_id": 44327196,
                "comment_id": 75658537,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 8,
                "is_accepted": true,
                "score": 8,
                "last_activity_date": 1496447083,
                "last_edit_date": 1496447083,
                "creation_date": 1496402075,
                "answer_id": 44327565,
                "question_id": 44327196,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "With a variable, you need to use the long `[...]` form for the key. You don&#39;t need to quote the variables in a JSON filter; the variable *is* the string value.\r\n\r\n    jq -rc \\\r\n       --arg secret_name &quot;${secret_name}&quot; \\\r\n       --arg secret_value &quot;${secret_value}&quot; \\\r\n       &#39;.data[$secret_name] = $secret_value&#39;\r\n\r\n",
                "title": "jq - Use argument to construct a selector"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1496447083,
        "creation_date": 1496400874,
        "last_edit_date": 1496401889,
        "question_id": 44327196,
        "body_markdown": "I&#39;m wondering if possible to use an argument to construct a field name in `jq`.  \r\n\r\nExample:  \r\n\r\n    jq -rc \\\r\n       --arg secret_name ${secret_name} \\\r\n       --arg secret_value ${secret_value} \\\r\n       &#39;.data.$secret_name = &quot;$secret_value&quot;&#39;\r\n\r\nIn above example, I want to use value of argument `secret_name` to create a key under `.data`. Is this possible using `jq`?\r\n\r\nExample Data:  \r\n\r\n    secret_name=abc  \r\n    secret_value=xyz \r\n\r\n \r\nJSON on which `jq` is run:  \r\n\r\n    {\r\n        &quot;apiVersion&quot;: &quot;v1&quot;,\r\n        &quot;data&quot;: {},\r\n        &quot;kind&quot;: &quot;Secret&quot;,\r\n        &quot;metadata&quot;: {\r\n            &quot;name&quot;: &quot;kv-secrets&quot;,\r\n            &quot;namespace&quot;: &quot;default&quot;\r\n        },\r\n        &quot;type&quot;: &quot;Opaque&quot;\r\n    } \r\n\r\nExpected output:  \r\n\r\n    {\r\n        &quot;apiVersion&quot;: &quot;v1&quot;,\r\n        &quot;data&quot;: {\r\n          &quot;abc&quot;: &quot;xyz&quot;\r\n        },\r\n        &quot;kind&quot;: &quot;Secret&quot;,\r\n        &quot;metadata&quot;: {\r\n            &quot;name&quot;: &quot;secrets&quot;\r\n        },\r\n        &quot;type&quot;: &quot;Opaque&quot;\r\n    }\r\n\r\nDo mind that I intend to run the original command to fill `.data` will more key-value pairs.",
        "link": "https://stackoverflow.com/questions/44327196/jq-use-argument-to-construct-a-selector",
        "title": "jq - Use argument to construct a selector"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1496600136,
                "last_edit_date": 1496600136,
                "creation_date": 1496599527,
                "answer_id": 44357248,
                "question_id": 44356606,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "***jq*** solution:\r\n\r\n    cat File[1-2] | jq -s &#39;if .[0].servers == .[1].ServerID then \r\n                  .[0] + .[1] | del(.servers,.ServerID)  else &quot;not match&quot; end&#39;\r\nThe output:\r\n\r\n    {\r\n      &quot;id&quot;: 3918389,\r\n      &quot;name&quot;: &quot;Application&quot;,\r\n      &quot;AccountID&quot;: 661737,\r\n      &quot;HostName&quot;: &quot;example.com&quot;\r\n    }\r\n\r\n\r\n----------\r\nDetails:\r\n\r\n- `cat File[1-2]` - concatenates and send to the standard output contents of `File1` and `File2` sequentially\r\n\r\n- `-s` (`--slurp`) - instead of running the filter for each JSON object in the input, read the entire input stream into a large array and run the filter just once.\r\n\r\n- `if-then-else` - condition, performs merging of 2 objects `.[0] + .[1]` along with deleting the compared keys `del(.servers,.ServerID)` if crucial properties are equal `.[0].servers == .[1].ServerID`, otherwise - prints `not match`\r\n\r\n",
                "title": "Correlation between 2 different json file with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1496600136,
        "creation_date": 1496595487,
        "question_id": 44356606,
        "body_markdown": "Is it possible with jq to find a correlation between 2 different json file? I have 2 files where both of the same ID key with different pieces of information. \r\n\r\n\r\nFile1\r\n\r\n    {\r\n      &quot;id&quot;: 3918389,\r\n      &quot;name&quot;: &quot;Application&quot;,\r\n      &quot;servers&quot;: 5566625\r\n    }\r\n\r\nFile2\r\n\r\n    {\r\n      &quot;ServerID&quot;: 5566625,\r\n      &quot;AccountID&quot;: 661737,\r\n      &quot;HostName&quot;: &quot;example.com&quot;,\r\n    \r\n    }\r\n\r\nI want a file where &quot;ServerID&quot; and &quot;servers&quot; is the same then merge all info like this:\r\n\r\n\r\nOutput\r\n\r\n    {\r\n    &quot;id&quot;: 3918389,\r\n    &quot;name&quot;: &quot;Application&quot;,\r\n    &quot;AccountID&quot;: 661737,\r\n    &quot;HostName&quot;: &quot;example.com&quot;,\r\n    }\r\n\r\nAny advice is appreciated.\r\n\r\nThanks!\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/44356606/correlation-between-2-different-json-file-with-jq",
        "title": "Correlation between 2 different json file with jq"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1496690328,
                "creation_date": 1496690328,
                "answer_id": 44376152,
                "question_id": 44367613,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Does this do what you want?\r\n\r\n     jq &#39;.description[]\r\n         |= . +\r\n           if has(&quot;car_name&quot;) then {&quot;name&quot;:.car_name}\r\n           else null end\r\n         | del(.description[].car_name)&#39;\r\n\r\nThe if-then block adds the object {name:.car_name} to any object in the description array that has a key with the name &quot;car_name&quot; and adds nothing (null) to any object in the array that does not have a key with that name.\r\n\r\nThe del function deletes key-value pairs at the path expression .description[].car_name",
                "title": "Rename property of an object inside array"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1496811006,
                "creation_date": 1496811006,
                "answer_id": 44403744,
                "question_id": 44367613,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "I just learned about += from an answer to another question. It works here too.\r\n\r\n    jq &#39;.description[] |= (select(has(&quot;car_name&quot;)) += {&quot;name&quot;:.car_name} | del(.car_name))&#39;\r\n\r\nThe select function selects the objects that meet the condition. Then we add to, and delete from, those objects.\r\n",
                "title": "Rename property of an object inside array"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1496850495,
                "creation_date": 1496850495,
                "answer_id": 44417378,
                "question_id": 44367613,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "This seems to work while preserving the order.\r\n    \r\n    jq &#39;.description[] |= with_entries( .key |= gsub(&quot;car_name&quot;; &quot;name&quot;) )&#39;\r\n\r\nThe [jq manual][2] explains what with_entries does.\r\n\r\nCredit goes to an [answer to a similar question][1] by peak.\r\n\r\n\r\n  [1]: https://stackoverflow.com/a/40367791/7839189\r\n  [2]: https://stedolan.github.io/jq/manual/v1.5/",
                "title": "Rename property of an object inside array"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1497935733,
                "creation_date": 1497935733,
                "answer_id": 44644345,
                "question_id": 44367613,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "To preserve the order of keys while being sure only to change the specific key name:\r\n\r\n\r\n    jq &#39;.description[] |= with_entries(if .key == &quot;car_name&quot; then .key = &quot;name&quot; else . end)&#39;\r\n\r\n",
                "title": "Rename property of an object inside array"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1589815429,
                "last_edit_date": 1589815429,
                "creation_date": 1497936430,
                "answer_id": 44644492,
                "question_id": 44367613,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```\r\njq &#39;.description[] |= with_entries(if .key == &quot;car_name&quot; then .key = &quot;name&quot; else . end)&#39;\r\n```",
                "title": "Rename property of an object inside array"
            }
        ],
        "is_answered": true,
        "answer_count": 5,
        "score": 5,
        "last_activity_date": 1589815429,
        "creation_date": 1496660934,
        "last_edit_date": 1496668947,
        "question_id": 44367613,
        "body_markdown": "This is my input JSON\r\n\r\n    {\r\n\t&quot;uuid&quot;:123,\r\n\t&quot;description&quot;: [\r\n\t    {\r\n\t\t    &quot;car_name&quot;:&quot;Toyota&quot;,\r\n\t\t    &quot;saleDate&quot;:&quot;23 May 2017&quot;\r\n\t\t}\r\n\t  ]\r\n    }\r\n\r\nExpected output:\r\n\r\n    {\r\n\t&quot;uuid&quot;:123,\r\n\t&quot;description&quot;: [\r\n\t    {\r\n\t\t    &quot;name&quot;:&quot;Toyota&quot;,\r\n\t\t    &quot;saleDate&quot;:&quot;23 May 2017&quot;\r\n\t\t}\r\n\t  ]\r\n    }\r\n\r\nRule : .description[]|={name:.car_name,saleDate}\r\n\r\nI am able to achieve the desired result with this rule. However, is there a way I can rename the &#39;car_name&#39; property to &#39;name&#39; and also not mention all the other properties ( in this case, &#39;saleDate&#39;) in the rule. I might end up having 50+ properties inside the object and I do not want to mention all of them in the rule.\r\n\r\nThere can be more than one object in the array. ",
        "link": "https://stackoverflow.com/questions/44367613/rename-property-of-an-object-inside-array",
        "title": "Rename property of an object inside array"
    },
    {
        "tags": [
            "json",
            "string",
            "bash",
            "jq",
            "doi"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1496687332,
                "creation_date": 1496687332,
                "answer_id": 44375419,
                "question_id": 44375141,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here&#39;s one way to do that with `jq`:\r\n\r\n    ... | jq &#39;.author[] | .given + &quot; &quot; + .family&#39; | jq -s &#39;join(&quot;, &quot;)&#39;\r\n\r\nOutputs:\r\n\r\n&gt;     &quot;Fabio Facchinelli, Andreas P. M. Weber&quot;",
                "title": "Get author names from CrossRef (get text out of JSON)"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1496689538,
                "creation_date": 1496689538,
                "answer_id": 44375974,
                "question_id": 44375141,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Can do it with a sed script:\r\n\r\n    $ cat json.sed\r\n    /&quot;given&quot;:/{\r\n        s/^.*&quot;given&quot;://\r\n        s/[&quot;,]//g\r\n        h\r\n    }\r\n    /&quot;family&quot;:/{\r\n        s/^.*&quot;family&quot;://\r\n        s/[&quot;,]//g\r\n        G\r\n        s/\\n/, /\r\n        p\r\n    }\r\n\r\nThen call it like this:\r\n\r\n    $ sed -n -f json.sed curl.json \r\n     Facchinelli,  Fabio\r\n     Weber,  Andreas P. M.\r\n\r\n\r\n\r\n",
                "title": "Get author names from CrossRef (get text out of JSON)"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1497702086,
                "creation_date": 1497702086,
                "answer_id": 44604586,
                "question_id": 44375141,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The task can be accomplished with just one invocation of jq:\r\n\r\n\t\r\n     ... | jq &#39;.author | map(.given + &quot; &quot; + .family) | join(&quot;, &quot;)&#39;\r\n",
                "title": "Get author names from CrossRef (get text out of JSON)"
            }
        ],
        "is_answered": false,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1497702429,
        "creation_date": 1496686414,
        "last_edit_date": 1497702429,
        "question_id": 44375141,
        "body_markdown": "I&#39;m trying to get the author names of [this paper][1] by using the CrossRef API with curl.\r\n\r\n    curl -LH &quot;Accept: application/citeproc+json&quot; http://dx.doi.org/10.3389/fpls.2011.00050 | jq .author\r\n\r\nOf course I get a JSON as response, but rather need pure text for further bash processing:\r\n\r\n&lt;!-- language: json --&gt;\r\n\r\n    [\r\n      {\r\n        &quot;given&quot;: &quot;Fabio&quot;,\r\n        &quot;family&quot;: &quot;Facchinelli&quot;,\r\n        &quot;affiliation&quot;: []\r\n      },\r\n      {\r\n        &quot;given&quot;: &quot;Andreas P. M.&quot;,\r\n        &quot;family&quot;: &quot;Weber&quot;,\r\n        &quot;affiliation&quot;: []\r\n      }\r\n    ]\r\n\r\nI thought of using jq, but couldn&#39;t figure out, how to just get:\r\n\r\n&quot;Fabio Facchinelli, Andreas P. M. Weber&quot;\r\n\r\nDo you know a solution (must not be jq)?\r\n\r\n\r\n  [1]: http://journal.frontiersin.org/article/10.3389/fpls.2011.00050/full",
        "link": "https://stackoverflow.com/questions/44375141/get-author-names-from-crossref-get-text-out-of-json",
        "title": "Get author names from CrossRef (get text out of JSON)"
    },
    {
        "tags": [
            "json",
            "utf-8",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1496799772,
                "post_id": 44392282,
                "comment_id": 75804009,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 7943529,
                    "reputation": 747,
                    "user_id": 5996722,
                    "user_type": "registered",
                    "accept_rate": 62,
                    "profile_image": "https://www.gravatar.com/avatar/800c439dfce31690465ac7a2f7d0cbb1?s=256&d=identicon&r=PG",
                    "display_name": "TimoC",
                    "link": "https://stackoverflow.com/users/5996722/timoc"
                },
                "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": 1496903485,
                "post_id": 44392282,
                "comment_id": 75854362,
                "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": 1496923775,
                "post_id": 44392282,
                "comment_id": 75867842,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 7943529,
                    "reputation": 747,
                    "user_id": 5996722,
                    "user_type": "registered",
                    "accept_rate": 62,
                    "profile_image": "https://www.gravatar.com/avatar/800c439dfce31690465ac7a2f7d0cbb1?s=256&d=identicon&r=PG",
                    "display_name": "TimoC",
                    "link": "https://stackoverflow.com/users/5996722/timoc"
                },
                "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": 1496929729,
                "post_id": 44392282,
                "comment_id": 75872510,
                "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": 1,
                "creation_date": 1496951606,
                "post_id": 44392282,
                "comment_id": 75886485,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 7943529,
                    "reputation": 747,
                    "user_id": 5996722,
                    "user_type": "registered",
                    "accept_rate": 62,
                    "profile_image": "https://www.gravatar.com/avatar/800c439dfce31690465ac7a2f7d0cbb1?s=256&d=identicon&r=PG",
                    "display_name": "TimoC",
                    "link": "https://stackoverflow.com/users/5996722/timoc"
                },
                "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": 1497247683,
                "post_id": 44392282,
                "comment_id": 75978403,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 8011176,
                    "reputation": 4161,
                    "user_id": 6042824,
                    "user_type": "registered",
                    "accept_rate": 94,
                    "profile_image": "https://i.sstatic.net/YoO5z.jpg?s=256",
                    "display_name": "Bilesh Ganguly",
                    "link": "https://stackoverflow.com/users/6042824/bilesh-ganguly"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1508259713,
                "post_id": 44392282,
                "comment_id": 80537459,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1541717159,
                "creation_date": 1541717159,
                "answer_id": 53217286,
                "question_id": 44392282,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Works for me just fine in Linux. I&#39;d recommend using [Bash for Windows][1] and installing jq and trying again. Also, be sure to use single quotes around your filter statement.\r\n\r\n  [1]: https://www.howtogeek.com/249966/how-to-install-and-use-the-linux-bash-shell-on-windows-10/ ",
                "title": "JQ: Codepage Errors after transformation"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1541717159,
        "creation_date": 1496758070,
        "last_edit_date": 1496906763,
        "question_id": 44392282,
        "body_markdown": "I use JQ to transform a json file from a Germany, for a later DB Import. As far i understand supports JQ UTF-8. I checked the original json file with Notepad++ and the Codepage Shows UTF-8 without BOM. \r\nAfter Transformation with jq i checked the new json file and there are a lot of Code Errors where in the original file stands &#228;,&#214;,&#223; and all that stuff. \r\nHow can i transform data without that Errors?\r\nI use JQ 1.5 for Windows (64 bit) downloaded around two weeks from the Github release site\r\n\r\nI use following jq Statement:\r\n\r\n    jq &quot;[{nid, title, nights, zone: .zones[0].title} + (.sails[] | { sails_nid: .nid, arrival, departure } ) + (.sails[].cabins[] | { cabintype: .cabinType.kindName, catalogPrice, discountPrice, discountPercentage, currency } )]&quot;  dreamlines_details.json &gt;test.json\r\n\r\nhere is the original data:\r\n[original data][1]\r\n\r\nhere are one result set:\r\n[results][2]\r\n\r\n\r\n  [1]: https://codeshare.io/5ePZpK\r\n  [2]: https://codeshare.io/5wyJA9",
        "link": "https://stackoverflow.com/questions/44392282/jq-codepage-errors-after-transformation",
        "title": "JQ: Codepage Errors after transformation"
    },
    {
        "tags": [
            "arrays",
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 57200,
                    "reputation": 158728,
                    "user_id": 171318,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/ePRKy.jpg?s=256",
                    "display_name": "hek2mgl",
                    "link": "https://stackoverflow.com/users/171318/hek2mgl"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1496775090,
                "post_id": 44397595,
                "comment_id": 75795145,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 10194592,
                    "reputation": 737,
                    "user_id": 7526791,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/680bcaf78bfc6bbf5163b3ba3b995658?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Sam Upra",
                    "link": "https://stackoverflow.com/users/7526791/sam-upra"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1496775166,
                "post_id": 44397595,
                "comment_id": 75795193,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 9760989,
                    "reputation": 15,
                    "user_id": 7236088,
                    "user_type": "registered",
                    "accept_rate": 40,
                    "profile_image": "https://www.gravatar.com/avatar/75e8f750d88225c92bcba7f58a8db436?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Amlan",
                    "link": "https://stackoverflow.com/users/7236088/amlan"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1496775255,
                "post_id": 44397595,
                "comment_id": 75795235,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 9760989,
                    "reputation": 15,
                    "user_id": 7236088,
                    "user_type": "registered",
                    "accept_rate": 40,
                    "profile_image": "https://www.gravatar.com/avatar/75e8f750d88225c92bcba7f58a8db436?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Amlan",
                    "link": "https://stackoverflow.com/users/7236088/amlan"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1496775480,
                "post_id": 44397595,
                "comment_id": 75795363,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1496810383,
                "last_edit_date": 1496810383,
                "creation_date": 1496798803,
                "answer_id": 44402073,
                "question_id": 44397595,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "1. The input as shown is not quite valid JSON.  The following assumes that surrounding braces have been added so as to produce valid JSON.\r\n\r\n2. The following jq query produces the desired CSV:\r\n\r\n&lt;/&gt;\r\n\r\n    [.abc.a_val, .def.b_val, .normaltext.c_val] | @csv\r\n\r\n### Typescript\r\n\r\n    $ jq -r &#39;[.abc.a_val, .def.b_val, .normaltext.c_val] | @csv&#39; input.json\r\n    true,false,&quot;text_value&quot;",
                "title": "How to extract boolean values from json file?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1497515428,
                "creation_date": 1497515428,
                "answer_id": 44562533,
                "question_id": 44397595,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "If this doesn&#39;t work:\r\n\r\n    jq -r &#39;[.abc.a_val, .def.b_val, .normaltext.c_val] | @csv&#39; jsonfile\r\n\r\nThen try this:\r\n\r\n    jq -r &#39;[(.abc.a_val | tostring), (.def.b_val | tostring), .normaltext.c_val] | @csv&#39; jsonfile",
                "title": "How to extract boolean values from json file?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1497515428,
        "creation_date": 1496774707,
        "last_edit_date": 1496774871,
        "question_id": 44397595,
        "body_markdown": "I am using jq parser to convert json to csv.\r\n\r\nInput:\r\n\r\n    &quot;abc&quot;:{\r\n          &quot;a_val&quot;:true\r\n       },\r\n    &quot;def&quot;:{\r\n          &quot;b_val&quot;:false\r\n       },\r\n    &quot;normaltext&quot;:{\r\n          &quot;c_val&quot;:&quot;text_value&quot;\r\n       }\r\n\r\nI am getting below output.\r\n\r\n    ,,&quot;text_value&quot;\r\n\r\nBut my desire output is\r\n\r\n    &quot;true&quot;, &quot;false&quot;, &quot;text_value&quot;\r\nor\r\n\r\n    true, false, text_value\r\n\r\nPlease help.\r\nThanks in advance.\r\n\r\n",
        "link": "https://stackoverflow.com/questions/44397595/how-to-extract-boolean-values-from-json-file",
        "title": "How to extract boolean values from json file?"
    },
    {
        "tags": [
            "amazon-web-services",
            "unix",
            "aws-cli",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 5226940,
                    "reputation": 7436,
                    "user_id": 4191049,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://lh6.googleusercontent.com/-D_DNImGAQNc/AAAAAAAAAAI/AAAAAAAAADA/0xP7usFFWf4/s256-rj/photo.jpg",
                    "display_name": "krishna_mee2004",
                    "link": "https://stackoverflow.com/users/4191049/krishna-mee2004"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1498573325,
                "post_id": 44400002,
                "comment_id": 76569578,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1496797305,
                "last_edit_date": 1496797305,
                "creation_date": 1496793971,
                "answer_id": 44401514,
                "question_id": 44400002,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "It *is* easy with jq\r\n\r\n    jq &#39;.[] |= map(select(.StackName | startswith(&quot;monkeyman&quot;), startswith(&quot;bulldog&quot;)))&#39;\r\n\r\nIn a nutshell, map(x) applies x to every object that is fed to it. select(y) selects the objects that meet the condition y. In this case, condition y is that there is a key called StackName whose value starts with either &quot;monkeyman&quot; or &quot;bulldog&quot;.",
                "title": "Using jq parse a json output to get specific properties as a new json output"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1498573325,
        "creation_date": 1496783916,
        "last_edit_date": 1496784344,
        "question_id": 44400002,
        "body_markdown": "I am very new to jq, I am trying to parse an output json I get from  command -\r\n\r\n    aws cloudformation list-stacks --stack-status-filter CREATE_COMPLETE\r\n\r\nto get a new output where values of the key matches to certain pattern.\r\n\r\nfor example this is my json output from previous command -\r\n\r\n    {\r\n      &quot;StackSummaries&quot;: [\r\n        {\r\n          &quot;StackId&quot;: &quot;arn:aws:213dqwqwdqwdqwdq&quot;,\r\n          &quot;StackName&quot;: &quot;monkeyman&quot;,\r\n          &quot;CreationTime&quot;: &quot;2017-06-06T20:52:59.728Z&quot;,\r\n          &quot;StackStatus&quot;: &quot;CREATE_COMPLETE&quot;,\r\n          &quot;TemplateDescription&quot;: &quot;Liaison API ELB cloud formation script&quot;\r\n        },\r\n        {\r\n          &quot;StackId&quot;: &quot;arn:aws:csdfsdfcsdfsdfsdfsdfsdfgdfgfdg&quot;,\r\n          &quot;StackName&quot;: &quot;monkeyman2&quot;,\r\n          &quot;CreationTime&quot;: &quot;2017-06-06T20:51:55.191Z&quot;,\r\n          &quot;StackStatus&quot;: &quot;CREATE_COMPLETE&quot;,\r\n          &quot;TemplateDescription&quot;: &quot;yoohooo instance&quot;\r\n        },\r\n        {\r\n          &quot;StackId&quot;: &quot;arn:aws:sdffgds444fsdfsdfgdfgfdg&quot;,\r\n          &quot;StackName&quot;: &quot;starfish2&quot;,\r\n          &quot;CreationTime&quot;: &quot;2017-06-06T20:51:55.191Z&quot;,\r\n          &quot;StackStatus&quot;: &quot;CREATE_COMPLETE&quot;,\r\n          &quot;TemplateDescription&quot;: &quot;helloworld instance&quot;\r\n        },\r\n        {\r\n          &quot;StackId&quot;: &quot;arn:aws:csdfsdfcsdfsdfsdfsdfsdfgdfgfdg&quot;,\r\n          &quot;StackName&quot;: &quot;bulldog4&quot;,\r\n          &quot;CreationTime&quot;: &quot;2017-06-06T20:51:55.191Z&quot;,\r\n          &quot;StackStatus&quot;: &quot;CREATE_COMPLETE&quot;,\r\n          &quot;TemplateDescription&quot;: &quot;night night instance&quot;\r\n        },\r\n        {\r\n          &quot;StackId&quot;: &quot;arn:aws:yhyhyhyhyhysdfgdfgfdg&quot;,\r\n          &quot;StackName&quot;: &quot;carrotman&quot;,\r\n          &quot;CreationTime&quot;: &quot;2017-06-06T20:51:55.191Z&quot;,\r\n          &quot;StackStatus&quot;: &quot;CREATE_COMPLETE&quot;,\r\n          &quot;TemplateDescription&quot;: &quot;surprise mo instance&quot;\r\n        }\r\n    \r\n      ]\r\n    \r\n    }\r\nHere I need to create a new output json by piping the first output to jq where StackName startsWith **monkeyman** and **bulldog** and which should look like -\r\n\r\n\r\n    {\r\n      &quot;StackSummaries&quot;: [\r\n        {\r\n          &quot;StackId&quot;: &quot;arn:aws:213dqwqwdqwdqwdq&quot;,\r\n          &quot;StackName&quot;: &quot;monkeyman&quot;,\r\n          &quot;CreationTime&quot;: &quot;2017-06-06T20:52:59.728Z&quot;,\r\n          &quot;StackStatus&quot;: &quot;CREATE_COMPLETE&quot;,\r\n          &quot;TemplateDescription&quot;: &quot;Liaison API ELB cloud formation script&quot;\r\n        },\r\n        {\r\n          &quot;StackId&quot;: &quot;arn:aws:csdfsdfcsdfsdfsdfsdfsdfgdfgfdg&quot;,\r\n          &quot;StackName&quot;: &quot;monkeyman2&quot;,\r\n          &quot;CreationTime&quot;: &quot;2017-06-06T20:51:55.191Z&quot;,\r\n          &quot;StackStatus&quot;: &quot;CREATE_COMPLETE&quot;,\r\n          &quot;TemplateDescription&quot;: &quot;yoohooo instance&quot;\r\n        },\r\n        {\r\n          &quot;StackId&quot;: &quot;arn:aws:csdfsdfcsdfsdfsdfsdfsdfgdfgfdg&quot;,\r\n          &quot;StackName&quot;: &quot;bulldog4&quot;,\r\n          &quot;CreationTime&quot;: &quot;2017-06-06T20:51:55.191Z&quot;,\r\n          &quot;StackStatus&quot;: &quot;CREATE_COMPLETE&quot;,\r\n          &quot;TemplateDescription&quot;: &quot;night night instance&quot;\r\n        }\r\n    \r\n      ]\r\n    \r\n    }\r\nI have tried a lot, I was able to do it somehow using basic unix split and regex commands but something tells me it would be easier and less cumbersome to do directly with jq.",
        "link": "https://stackoverflow.com/questions/44400002/using-jq-parse-a-json-output-to-get-specific-properties-as-a-new-json-output",
        "title": "Using jq parse a json output to get specific properties as a new json output"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 6,
                "is_accepted": true,
                "score": 6,
                "last_activity_date": 1496794619,
                "creation_date": 1496794619,
                "answer_id": 44401603,
                "question_id": 44401246,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You pretty much had it, but you&#39;ll want to restructure your filter to preserve the full results.  You want to make sure that none of the filters changes the context.  By starting off with `.items`, you changed it from your root object to the `items` array.  That in of itself is not so much a problem but what you do with that matters.  Keep in mind that assignments/updates preserves the original context as a result with the change applied.  So if you wrote your filter in terms of an update, it will work for you.\r\n\r\nSo to do this, you&#39;ll want to find the `env` array of the first container in the `DeploymentConfig` item.  First let&#39;s find that:\r\n\r\n    .items[] | select(.kind == &quot;DeploymentConfig&quot;).spec.template.spec.containers[0].env\r\n\r\nYou don&#39;t need to do anything else in terms of error handling since `select` will simply produce no result.  From there, you just need to update the array by adding the new value.\r\n\r\n    (.items[] | select(.kind == &quot;DeploymentConfig&quot;).spec.template.spec.containers[0].env) +=\r\n        [{name:&quot;B_ENV&quot;,value:&quot;b-value&quot;}]\r\n\r\nIf the array exists, it will add the new item. If not, it will create a new `env` array.  If `env` is not an array, that would be a different problem.",
                "title": "Add or Update object in array in JSON using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1496794619,
        "creation_date": 1496791831,
        "last_edit_date": 1496794351,
        "question_id": 44401246,
        "body_markdown": "I&#39;m trying to use `jq` to parse a JSON (the output of the OpenShift `oc process ...` command, actually), and _add/update_ the _env_ array of a `container` with a new key/value pair.\r\n\r\n**Sample input**:\r\n&lt;!-- language: lang-js --&gt;\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;apiVersion&quot;: &quot;v1&quot;,\r\n          &quot;kind&quot;: &quot;Service&quot;,\r\n          &quot;metadata&quot;: {\r\n            &quot;annotations&quot;: {\r\n              &quot;description&quot;: &quot;Exposes and load balances the node.js application pods&quot;\r\n            },\r\n            &quot;name&quot;: &quot;myapp-web&quot;\r\n          },\r\n          &quot;spec&quot;: {\r\n            &quot;ports&quot;: [\r\n              {\r\n                &quot;name&quot;: &quot;web&quot;,\r\n                &quot;port&quot;: 3000,\r\n                &quot;protocol&quot;: &quot;TCP&quot;,\r\n                &quot;targetPort&quot;: 3000\r\n              }\r\n            ],\r\n            &quot;selector&quot;: {\r\n              &quot;name&quot;: &quot;myapp&quot;\r\n            }\r\n          }\r\n        },\r\n        {\r\n          &quot;apiVersion&quot;: &quot;v1&quot;,\r\n          &quot;kind&quot;: &quot;Route&quot;,\r\n          &quot;metadata&quot;: {\r\n            &quot;name&quot;: &quot;myapp-web&quot;\r\n          },\r\n          &quot;spec&quot;: {\r\n            &quot;host&quot;: &quot;app.internal.io&quot;,\r\n            &quot;port&quot;: {\r\n              &quot;targetPort&quot;: &quot;web&quot;\r\n            },\r\n            &quot;to&quot;: {\r\n              &quot;kind&quot;: &quot;Service&quot;,\r\n              &quot;name&quot;: &quot;myapp-web&quot;\r\n            }\r\n          }\r\n        },\r\n        {\r\n          &quot;apiVersion&quot;: &quot;v1&quot;,\r\n          &quot;kind&quot;: &quot;DeploymentConfig&quot;,\r\n          &quot;metadata&quot;: {\r\n            &quot;annotations&quot;: {\r\n              &quot;description&quot;: &quot;Defines how to deploy the application server&quot;\r\n            },\r\n            &quot;name&quot;: &quot;myapp&quot;\r\n          },\r\n          &quot;spec&quot;: {\r\n            &quot;replicas&quot;: 1,\r\n            &quot;selector&quot;: {\r\n              &quot;name&quot;: &quot;myapp&quot;\r\n            },\r\n            &quot;strategy&quot;: {\r\n              &quot;type&quot;: &quot;Rolling&quot;\r\n            },\r\n            &quot;template&quot;: {\r\n              &quot;metadata&quot;: {\r\n                &quot;labels&quot;: {\r\n                  &quot;name&quot;: &quot;myapp&quot;\r\n                },\r\n                &quot;name&quot;: &quot;myapp&quot;\r\n              },\r\n              &quot;spec&quot;: {\r\n                &quot;containers&quot;: [\r\n                  {\r\n                    &quot;env&quot;: [\r\n                      {\r\n                        &quot;name&quot;: &quot;A_ENV&quot;,\r\n                        &quot;value&quot;: &quot;a-value&quot;\r\n                      }\r\n                    ],\r\n                    &quot;image&quot;: &quot;node&quot;,\r\n                    &quot;name&quot;: &quot;myapp-node&quot;,\r\n                    &quot;ports&quot;: [\r\n                      {\r\n                        &quot;containerPort&quot;: 3000,\r\n                        &quot;name&quot;: &quot;app&quot;,\r\n                        &quot;protocol&quot;: &quot;TCP&quot;\r\n                      }\r\n                    ]\r\n                  }\r\n                ]\r\n              }\r\n            },\r\n            &quot;triggers&quot;: [\r\n              {\r\n                &quot;type&quot;: &quot;ConfigChange&quot;\r\n              }\r\n            ]\r\n          }\r\n        }\r\n      ]\r\n    }\r\n\r\nIn this JSON, I want to do the following:\r\n\r\n- Find the `DeploymentConfig` object\r\n- Check if it has the `env` array in the first container\r\n- If it does, add a new object `{&quot;name&quot;: &quot;B_ENV&quot;, &quot;value&quot;: &quot;b-value&quot;}` in it\r\n- If it does not, add the `env` _array_, with the object `{&quot;name&quot;: &quot;B_ENV&quot;, &quot;value&quot;: &quot;b-value&quot;}` in it\r\n\r\nSo far, I&#39;m able to tackle part of this, where I&#39;m able to find the concerned object, and add the new env var to the container:\r\n\r\n&lt;!-- language: lang-bash --&gt;\r\n\r\n    oc process -f &lt;dc.yaml&gt; -o json | jq &#39;.items | map(if .kind == &quot;DeploymentConfig&quot; \r\n        then .spec.template.spec.containers[0].env |= .+ [{&quot;name&quot;: &quot;B_ENV&quot;, &quot;value&quot;: &quot;b-value&quot;}] \r\n        else . \r\n        end)&#39;\r\n\r\nThis is able to insert the new env var as expected, but the output is an array as shown below. &lt;s&gt;Also, it doesn&#39;t handle the part where the `env` array may not be there at all.&lt;/s&gt;\r\n\r\nI want to be able to produce the same output as the input, but with the new env var added.\r\n\r\n**Sample output**:\r\n&lt;!-- language: lang-js --&gt;\r\n\r\n    [\r\n      {\r\n        &quot;apiVersion&quot;: &quot;v1&quot;,\r\n        &quot;kind&quot;: &quot;Service&quot;,\r\n        &quot;metadata&quot;: {\r\n          &quot;annotations&quot;: {\r\n            &quot;description&quot;: &quot;Exposes and load balances the node.js application pods&quot;\r\n          },\r\n          &quot;name&quot;: &quot;myapp-web&quot;\r\n        },\r\n        &quot;spec&quot;: {\r\n          &quot;ports&quot;: [\r\n            {\r\n              &quot;name&quot;: &quot;web&quot;,\r\n              &quot;port&quot;: 3000,\r\n              &quot;protocol&quot;: &quot;TCP&quot;,\r\n              &quot;targetPort&quot;: 3000\r\n            }\r\n          ],\r\n          &quot;selector&quot;: {\r\n            &quot;name&quot;: &quot;myapp&quot;\r\n          }\r\n        }\r\n      },\r\n      {\r\n        &quot;apiVersion&quot;: &quot;v1&quot;,\r\n        &quot;kind&quot;: &quot;Route&quot;,\r\n        &quot;metadata&quot;: {\r\n          &quot;name&quot;: &quot;myapp-web&quot;\r\n        },\r\n        &quot;spec&quot;: {\r\n          &quot;host&quot;: &quot;app.internal.io&quot;,\r\n          &quot;port&quot;: {\r\n            &quot;targetPort&quot;: &quot;web&quot;\r\n          },\r\n          &quot;to&quot;: {\r\n            &quot;kind&quot;: &quot;Service&quot;,\r\n            &quot;name&quot;: &quot;myapp-web&quot;\r\n          }\r\n        }\r\n      },\r\n      {\r\n        &quot;apiVersion&quot;: &quot;v1&quot;,\r\n        &quot;kind&quot;: &quot;DeploymentConfig&quot;,\r\n        &quot;metadata&quot;: {\r\n          &quot;annotations&quot;: {\r\n            &quot;description&quot;: &quot;Defines how to deploy the application server&quot;\r\n          },\r\n          &quot;name&quot;: &quot;myapp&quot;\r\n        },\r\n        &quot;spec&quot;: {\r\n          &quot;replicas&quot;: 1,\r\n          &quot;selector&quot;: {\r\n            &quot;name&quot;: &quot;myapp&quot;\r\n          },\r\n          &quot;strategy&quot;: {\r\n            &quot;type&quot;: &quot;Rolling&quot;\r\n          },\r\n          &quot;template&quot;: {\r\n            &quot;metadata&quot;: {\r\n              &quot;labels&quot;: {\r\n                &quot;name&quot;: &quot;myapp&quot;\r\n              },\r\n              &quot;name&quot;: &quot;myapp&quot;\r\n            },\r\n            &quot;spec&quot;: {\r\n              &quot;containers&quot;: [\r\n                {\r\n                  &quot;env&quot;: [\r\n                    {\r\n                      &quot;name&quot;: &quot;A_ENV&quot;,\r\n                      &quot;value&quot;: &quot;a-value&quot;\r\n                    },\r\n                    {\r\n                      &quot;name&quot;: &quot;B_ENV&quot;,\r\n                      &quot;value&quot;: &quot;b-value&quot;\r\n                    }\r\n                  ],\r\n                  &quot;image&quot;: &quot;node&quot;,\r\n                  &quot;name&quot;: &quot;myapp-node&quot;,\r\n                  &quot;ports&quot;: [\r\n                    {\r\n                      &quot;containerPort&quot;: 3000,\r\n                      &quot;name&quot;: &quot;app&quot;,\r\n                      &quot;protocol&quot;: &quot;TCP&quot;\r\n                    }\r\n                  ]\r\n                }\r\n              ]\r\n            }\r\n          },\r\n          &quot;triggers&quot;: [\r\n            {\r\n              &quot;type&quot;: &quot;ConfigChange&quot;\r\n            }\r\n          ]\r\n        }\r\n      }\r\n    ]\r\n\r\nIs this doable, or is it too much to do with `jq`, and I should probably do this in python or node?\r\n\r\n**EDIT 1**:\r\n\r\nI just realized that conditional add/update of `env` array is already handled by the `|=` syntax!\r\nSo, I basically just need to be able to get the _same_ structure back as the input, with the relevant env var added in the concerned array.",
        "link": "https://stackoverflow.com/questions/44401246/add-or-update-object-in-array-in-json-using-jq",
        "title": "Add or Update object in array in JSON using jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1496810137,
                "last_edit_date": 1496810137,
                "creation_date": 1496807218,
                "answer_id": 44403131,
                "question_id": 44402914,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "One way to retrieve the key names programmatically is using `to_entries`.  For example, given your input, this jq filter:\r\n\r\n\r\n    to_entries[]\r\n    | .key as $type\r\n    | .value[]\r\n    | .proxy as $proxy\r\n    | .server[]\r\n    | select(.name == &quot;PAPP9001&quot;)\r\n    | { Type: $type, name, ip, proxy: $proxy }\r\n\r\n\r\nyields:\r\n\r\n    {\r\n      &quot;Type&quot;: &quot;Type2&quot;,\r\n      &quot;name&quot;: &quot;PAPP9001&quot;,\r\n      &quot;ip&quot;: &quot;10.2.3.2&quot;,\r\n      &quot;proxy&quot;: &quot;type2.prod.proxy.mydomain.com&quot;\r\n    }\r\n\r\n### Variations\r\n\r\nIf, for example, you wanted these four fields as a CSV row, then you could replace the last line of the filter above with:\r\n\r\n    | [$type, .name, .ip, $proxy] | @csv\r\n\r\nSee the jq manual for how to use string interpolation.",
                "title": "Query parent data (multi-level) based on a child value, on a json file, using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1496897116,
        "creation_date": 1496805498,
        "last_edit_date": 1496897116,
        "question_id": 44402914,
        "body_markdown": "I have a ksh script that retrives (using curl) a json file similar to the one bellow:\r\n\r\n    {\r\n      &quot;Type1&quot;: {\r\n        &quot;dev&quot;: {\r\n          &quot;server&quot;: [\r\n            {\t&quot;group&quot;: &quot;APP1&quot;,\t&quot;name&quot;: &quot;DAPP1002&quot;,\t&quot;ip&quot;: &quot;10.1.1.1&quot; },\r\n            {\t&quot;group&quot;: &quot;APP2&quot;,\t&quot;name&quot;: &quot;DAPP2001&quot;,\t&quot;ip&quot;: &quot;10.1.1.2&quot; }\r\n          ]\r\n        },\r\n        &quot;qa&quot;: {\r\n          &quot;server&quot;: [\r\n            {\t&quot;group&quot;: &quot;APP1&quot;,\t&quot;name&quot;: &quot;QAPP1002&quot;,\t&quot;ip&quot;: &quot;10.1.2.1&quot; },\r\n            {\t&quot;group&quot;: &quot;APP2&quot;,\t&quot;name&quot;: &quot;QAPP2001&quot;,\t&quot;ip&quot;: &quot;10.1.2.2&quot; }\r\n          ]\r\n        },\r\n        &quot;prod&quot;: {\r\n          &quot;proxy&quot;: &quot;type1.prod.proxy.mydomain.com&quot;,\r\n          &quot;server&quot;: [\r\n            {\t&quot;group&quot;: &quot;APP1&quot;,\t&quot;name&quot;: &quot;PAPP1001&quot;,\t&quot;ip&quot;: &quot;10.1.3.1&quot; },\r\n            {\t&quot;group&quot;: &quot;APP1&quot;,\t&quot;name&quot;: &quot;PAPP1002&quot;,\t&quot;ip&quot;: &quot;10.1.3.2&quot; },\r\n            {\t&quot;group&quot;: &quot;APP2&quot;,\t&quot;name&quot;: &quot;PAPP2001&quot;,\t&quot;ip&quot;: &quot;10.1.3.3&quot; }\r\n          ]\r\n        }\r\n      },\r\n      \r\n      &quot;Type2&quot;: {\r\n        &quot;dev&quot;: {\r\n          &quot;server&quot;: [\r\n            {\t&quot;group&quot;: &quot;APP8&quot;,\t&quot;name&quot;: &quot;DAPP8002&quot;,\t&quot;ip&quot;: &quot;10.2.1.1&quot; },\r\n            {\t&quot;group&quot;: &quot;APP9&quot;,\t&quot;name&quot;: &quot;DAPP9001&quot;,\t&quot;ip&quot;: &quot;10.2.1.2&quot; }\r\n          ]\r\n        },\r\n        &quot;qa&quot;: {\r\n          &quot;server&quot;: [\r\n            {\t&quot;group&quot;: &quot;APP8&quot;,\t&quot;name&quot;: &quot;QAPP8002&quot;,\t&quot;ip&quot;: &quot;10.2.2.1&quot; },\r\n            {\t&quot;group&quot;: &quot;APP9&quot;,\t&quot;name&quot;: &quot;QAPP9001&quot;,\t&quot;ip&quot;: &quot;10.2.2.2&quot; }\r\n          ]\r\n        },\r\n        &quot;prod&quot;: {\r\n          &quot;proxy&quot;: &quot;type2.prod.proxy.mydomain.com&quot;,\r\n          &quot;server&quot;: [\r\n            {\t&quot;group&quot;: &quot;APP8&quot;,\t&quot;name&quot;: &quot;PAPP8001&quot;,\t&quot;ip&quot;: &quot;10.2.3.1&quot; },\r\n            {\t&quot;group&quot;: &quot;APP9&quot;,\t&quot;name&quot;: &quot;PAPP9001&quot;,\t&quot;ip&quot;: &quot;10.2.3.2&quot; },\r\n            {\t&quot;group&quot;: &quot;APP9&quot;,\t&quot;name&quot;: &quot;PAPP9002&quot;,\t&quot;ip&quot;: &quot;10.2.3.3&quot; }\r\n          ]\r\n        }\r\n      }\r\n    }\r\n\r\n... based on a server name (field `&quot;name&quot;`) I would have to collect the following info, to pass to a function:\r\n\r\n    &quot;Type&quot;, &quot;name&quot;, &quot;ip&quot;, &quot;proxy&quot;\r\n\r\n(Note that the `&quot;proxy&quot;` info is optional)\r\n\r\nI am new to json, and I am trying to get this filtered with jq but so far, I am out of lucky.\r\nWhat I acomplished so far is the following jq query, when searching for **&quot;PAPP9001&quot;** :\r\n\r\n    jq &#39;.[] | .[] | select(.server[].name==&quot;PAPP9001&quot;) | .proxy as $proxy | .server[] | {proxy: $proxy, name: .name, ip: .ip} | select(.name==&quot;PAPP9001&quot;)&#39; curlreturn.json\r\n\r\nwhich returns me:\r\n\r\n    {\r\n      &quot;proxy&quot;: &quot;type2.prod.proxy.mydomain.com&quot;,\r\n      &quot;name&quot;: &quot;PAPP9001&quot;,\r\n      &quot;ip&quot;: &quot;10.2.3.2&quot;\r\n    }\r\n\r\n\r\nbut:\r\n\r\n 1. I could not get the &quot;Type&quot; info, at the top level \r\n 2. Considering the number of pipes and the 2 selects, I doubt that this is the most efficient way.",
        "link": "https://stackoverflow.com/questions/44402914/query-parent-data-multi-level-based-on-a-child-value-on-a-json-file-using-jq",
        "title": "Query parent data (multi-level) based on a child value, on a json file, using jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 11063786,
                    "reputation": 1,
                    "user_id": 8124169,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b1d3d8a6296235a103e195849e307f77?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Avi",
                    "link": "https://stackoverflow.com/users/8124169/avi"
                },
                "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": 1496830722,
                "post_id": 44409037,
                "comment_id": 75818482,
                "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": 1496832132,
                "post_id": 44409037,
                "comment_id": 75819502,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 11063786,
                    "reputation": 1,
                    "user_id": 8124169,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b1d3d8a6296235a103e195849e307f77?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Avi",
                    "link": "https://stackoverflow.com/users/8124169/avi"
                },
                "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": 1496832543,
                "post_id": 44409037,
                "comment_id": 75819780,
                "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": 1496832998,
                "post_id": 44409037,
                "comment_id": 75820106,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1496831966,
                "last_edit_date": 1496831966,
                "creation_date": 1496829883,
                "answer_id": 44409565,
                "question_id": 44409037,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "    cat your-data.json | jq &#39;.[]|.externalIP|select(type==&quot;string&quot;)&#39;\r\n    &quot;198.22.66.99&quot;\r\n    &quot;192.22.66.29&quot;\r\n    &quot;192.22.66.89&quot;\r\n    &quot;192.66.22.79&quot;\r\n\r\nexplanation:\r\n\r\n    .[]                   | .externalIP            | select(type==&quot;string&quot;)    \r\n    for every array entry | get field &#39;externalIP&#39; | drop nulls\r\n\r\n---\r\n\r\nEDIT/ADDENDUM: filter on type (expects router to be on index 0 of type array)\r\n\r\n    cat x | jq &#39;.[]|select(.type[0] == &quot;router&quot;)|.externalIP&#39;\r\n    &quot;198.22.66.99&quot;\r\n    &quot;192.22.66.89&quot;",
                "title": "parsing Json data with jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1496855057,
                "creation_date": 1496855057,
                "answer_id": 44418790,
                "question_id": 44409037,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The description:\r\n\r\n&gt; i would like to extract externalIP for only the array &quot;type&quot;: [ &quot;router&quot; ]\r\n\r\nThe corresponding jq query is:\r\n\r\n    .[] | select(.type==[&quot;router&quot;]) | .externalIP\r\n\r\nTo base the query on whether &quot;router&quot; is amongst the specified types:\r\n\r\n    .[] | select(.type|index(&quot;router&quot;)) | .externalIP\r\n\r\n\r\n",
                "title": "parsing Json data with jq"
            }
        ],
        "is_answered": false,
        "answer_count": 2,
        "score": -1,
        "last_activity_date": 1496855057,
        "creation_date": 1496828645,
        "last_edit_date": 1496835678,
        "question_id": 44409037,
        "body_markdown": "Need help in parsing Json data using jq , I used to parse the data using json path as [?(@.type==&#39;router&#39;)].externalIP. I am not sure how to do the same using jq.\r\n\r\nThe result from the query should provide the .externalIp from the type=router.\r\n198.22.66.99\r\n\r\nJson data snippet as below\r\n----------\r\n## \r\n\r\n&lt;!-- begin snippet: js hide: false console: true babel: false --&gt;\r\n\r\n&lt;!-- language: lang-html --&gt;\r\n\r\n    [\r\n      {\r\n        &quot;externalHostName&quot;: &quot;localhost&quot;,\r\n        &quot;externalIP&quot;: &quot;198.22.66.99&quot;,\r\n        &quot;internalHostName&quot;: &quot;localhost&quot;,\r\n        &quot;isUp&quot;: true,\r\n        &quot;pod&quot;: &quot;gateway&quot;,\r\n        &quot;reachable&quot;: true,\r\n        &quot;region&quot;: &quot;dc-1&quot;,\r\n         &quot;type&quot;: [\r\n          &quot;router&quot;\r\n        ],\r\n        &quot;uUID&quot;: &quot;b5f986fe-982e-47ae-8260-8a3662f25fc2&quot;\r\n      },\r\n      ]\r\n\r\n\r\n&lt;!-- end snippet --&gt;\r\n\r\n ##",
        "link": "https://stackoverflow.com/questions/44409037/parsing-json-data-with-jq",
        "title": "parsing Json data with jq"
    },
    {
        "tags": [
            "json",
            "bash",
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1042811,
                    "reputation": 4083,
                    "user_id": 1745432,
                    "user_type": "registered",
                    "accept_rate": 50,
                    "profile_image": "https://www.gravatar.com/avatar/de8eed2933662cd85e6a5eee3eb9f2fa?s=256&d=identicon&r=PG",
                    "display_name": "Kpym",
                    "link": "https://stackoverflow.com/users/1745432/kpym"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1577457585,
                "post_id": 44410394,
                "comment_id": 105176783,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 6,
                "is_accepted": true,
                "score": 6,
                "last_activity_date": 1496835898,
                "creation_date": 1496835898,
                "answer_id": 44411730,
                "question_id": 44410394,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You can also use `map`, like this:\r\n\r\n    jq &#39;(.values)|=(map((if .name|startswith(&quot;test&quot;) then .id=&quot;NEWID&quot;  else . end)))&#39; file\r\n\r\nOutput:\r\n\r\n    {\r\n      &quot;other-value&quot;: &quot;some-id&quot;,\r\n      &quot;values&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;test-2017-12-01&quot;,\r\n          &quot;id&quot;: &quot;NEWID&quot;\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;othert&quot;,\r\n          &quot;id&quot;: &quot;2&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\n",
                "title": "Using jq to update objects within a JSON document if the value corresponding to a given key starts with a specified string"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1496854382,
                "last_edit_date": 1496854382,
                "creation_date": 1496852681,
                "answer_id": 44418111,
                "question_id": 44410394,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Please note that since the release of jq 1.5, jq has been enhanced to support the query that previously failed.  For example, using the current &#39;master&#39; version:\r\n\r\n    jq -c &#39;(.values[] | select(.name | startswith(&quot;test&quot;)).id) |= &quot;NEWID&quot;&#39;\r\n    {&quot;other-value&quot;:&quot;some-id&quot;,&quot;values&quot;:[{&quot;name&quot;:&quot;test-2017-12-01&quot;,&quot;id&quot;:&quot;NEWID&quot;},{&quot;name&quot;:&quot;othert&quot;,&quot;id&quot;:&quot;2&quot;}]}\r\n\r\nUsing earlier versions of jq, if/then/else/end can be used in this type of situation as follows:\r\n\r\n    .values[] |= if .name | startswith(&quot;test&quot;) then .id = &quot;NEWID&quot; else . end\r\n\r\nIf using `map`, a minimalist expression would be:\r\n\r\n    .values |= map(if .name|startswith(&quot;test&quot;) then .id = &quot;NEWID&quot; else . end)\r\n\r\n\r\n\r\n\r\n",
                "title": "Using jq to update objects within a JSON document if the value corresponding to a given key starts with a specified string"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 9,
        "last_activity_date": 1496863882,
        "creation_date": 1496832080,
        "last_edit_date": 1496863882,
        "question_id": 44410394,
        "body_markdown": "I have the given JSON and want to change the `id` value of all elements, which starts with `test` in the `name` element:\r\n\r\n    {\r\n        &quot;other-value&quot;: &quot;some-id&quot;,\r\n        &quot;values&quot;: [\r\n            {\r\n                &quot;name&quot;: &quot;test-2017-12-01&quot;,\r\n                &quot;id&quot;: &quot;1&quot;\r\n                \r\n            },\r\n            {\r\n                &quot;name&quot;: &quot;othert&quot;,\r\n                &quot;id&quot;: &quot;2&quot;\r\n            }\r\n            \r\n        ]\r\n    }\r\n\r\nThe following jq commands works [jqplay][1]\r\n\r\n    jq (.values[] | select(.name == &quot;test-afs&quot;).id) |= &quot;NEWID&quot;\r\n\r\n\r\nBut when I try it with `startswith` it stops working, what am I missing? [jqplay][2]\r\n\r\n    (.values[] | select(.name | startswith(&quot;test&quot;)).id) |= &quot;NEWID&quot; \r\n\r\n&gt; jq: error (at &lt;stdin&gt;:14): Invalid path expression near attempt to access element &quot;id&quot; of {&quot;name&quot;:&quot;test-afs&quot;,&quot;id&quot;:&quot;id&quot;}\r\nexit status 5\r\n\r\n\r\n  [1]: https://jqplay.org/s/iqAiSq9Fui\r\n  [2]: https://jqplay.org/s/_kpouHRemx",
        "link": "https://stackoverflow.com/questions/44410394/using-jq-to-update-objects-within-a-json-document-if-the-value-corresponding-to",
        "title": "Using jq to update objects within a JSON document if the value corresponding to a given key starts with a specified string"
    },
    {
        "tags": [
            "bash",
            "character",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 11070419,
                    "reputation": 1,
                    "user_id": 8128728,
                    "user_type": "registered",
                    "profile_image": "https://lh6.googleusercontent.com/-SeaykRy1x6A/AAAAAAAAAAI/AAAAAAAAABQ/qyHuXyiT2cs/s256-rj/photo.jpg",
                    "display_name": "Paul Jensen",
                    "link": "https://stackoverflow.com/users/8128728/paul-jensen"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1496888630,
                "post_id": 44425626,
                "comment_id": 75849587,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 4532073,
                    "reputation": 4505,
                    "user_id": 3682217,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/1a30e48ec7d6b4e210ae61f3605cb685?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Shammel Lee",
                    "link": "https://stackoverflow.com/users/3682217/shammel-lee"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1496888961,
                "post_id": 44425626,
                "comment_id": 75849663,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 4532073,
                    "reputation": 4505,
                    "user_id": 3682217,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/1a30e48ec7d6b4e210ae61f3605cb685?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Shammel Lee",
                    "link": "https://stackoverflow.com/users/3682217/shammel-lee"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1496889044,
                "post_id": 44425626,
                "comment_id": 75849679,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 4532073,
                    "reputation": 4505,
                    "user_id": 3682217,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/1a30e48ec7d6b4e210ae61f3605cb685?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Shammel Lee",
                    "link": "https://stackoverflow.com/users/3682217/shammel-lee"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1496889089,
                "post_id": 44425626,
                "comment_id": 75849692,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 11070419,
                    "reputation": 1,
                    "user_id": 8128728,
                    "user_type": "registered",
                    "profile_image": "https://lh6.googleusercontent.com/-SeaykRy1x6A/AAAAAAAAAAI/AAAAAAAAABQ/qyHuXyiT2cs/s256-rj/photo.jpg",
                    "display_name": "Paul Jensen",
                    "link": "https://stackoverflow.com/users/8128728/paul-jensen"
                },
                "reply_to_user": {
                    "account_id": 4532073,
                    "reputation": 4505,
                    "user_id": 3682217,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/1a30e48ec7d6b4e210ae61f3605cb685?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Shammel Lee",
                    "link": "https://stackoverflow.com/users/3682217/shammel-lee"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1496894303,
                "post_id": 44425626,
                "comment_id": 75850816,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1496890073,
                "creation_date": 1496890073,
                "answer_id": 44425838,
                "question_id": 44425626,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The problem is that you don&#39;t know what&#39;s `bash` syntax and what&#39;s `jq` syntax, so you&#39;re merging them both together.\r\n\r\nHere&#39;s an example of what `jq` expects:\r\n\r\n    .users.user[1].cpid.&quot;#text&quot;\r\n\r\nHere&#39;s what you&#39;re giving it:\r\n\r\n    &#39;.users.user[1].cpid.&quot;#text&quot;&#39; filename\r\n\r\n`jq` is never supposed to see the single quotes, in your working command they&#39;re bash syntax to specify which string to pass to `jq`. Instead, you try to give single quotes to `jq` which has no idea what that means.\r\n\r\nSimilarly, the space followed by the filename is bash syntax to specify that you want to pass a second argument. Instead, you try to give them to `jq` in its first argument, which it does not expect.\r\n\r\nTo `jq`, this command is indistinguishable from your original (it results in an `execve` call with the exact same parameters). You can vary the variable to get different indices:\r\n\r\n    var=1\r\n    baselineresult=$(jq -r &#39;.users.user[&#39;&quot;$var&quot;&#39;].cpid.&quot;#text&quot;&#39; &quot;$1&quot;)\r\n",
                "title": "Been at this awhile"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -2,
        "last_activity_date": 1496890073,
        "creation_date": 1496888478,
        "last_edit_date": 1496890011,
        "question_id": 44425626,
        "body_markdown": "So I have a json file converted from xml. I&#39;m trying to use jq in a bash script to work through this problem.\r\n\r\ncurrent at command line `jq -r &#39;.users.user[0].id.&quot;#text&quot;&#39; cosmology18.json` works great and shows the output perfect\r\n\r\nhowever in bash i&#39;ve had to use substitutions to try to get this to work with no resolve.\r\n\r\nfirst I got part of it to work the first part to read user data\r\n\r\n      baselineresult=$(jq -r &#39;.users.user[1].cpid.&quot;#text&quot;&#39; $1)\r\n\r\nwould allow me to echo out the data received perfectly\r\n\r\nhowever when i try to add `$basecount` which increases each time i couldn&#39;t get it to work so i constructed this crazy method in which I had to use substitutions to get the $basecount into the [ ] of the user.\r\n\r\n      bracea=&quot;[&quot;\r\n      braceb=&quot;]&quot;\r\n      dquote=&#39;&quot;&#39;\r\n      squote=&quot;&#39;&quot;\r\n      pound=&quot;#&quot;\r\n      echo test of command is jq -r &quot;${squote}.users.user${bracea}${basecount}${braceb}.cpid.${dquote}#text${dquote}${squote} $1&quot;\r\n\r\n      baselineresult=$(jq -r &quot;${squote}.users.user${bracea}${basecount}${braceb}.cpid.${dquote}${pound}text${dquote}${squote} $1&quot;)\r\n      echo $baselineresult\r\n\r\nthe command matches the one i entered at command line to work.\r\n\r\nhowever i get this:\r\n\r\ntest of command is jq -r &#39;.users.user[0].cpid.&quot;#text&quot;&#39; cosmology18.json\r\njq: error: syntax error, unexpected INVALID_CHARACTER, expecting $end (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n&#39;.users.user[0].cpid.&quot;#text&quot;&#39; cosmology18.json\r\njq: 1 compile error\r\n\r\nany ideas.. been at this for 8 hours now. \r\nI can&#39;t seem to find this illegal character as the output is identical to the one id use at command line of jq -r &#39;.users.user[0].id.&quot;#text&quot;&#39; cosmology18.json\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/44425626/been-at-this-awhile",
        "title": "Been at this awhile"
    },
    {
        "tags": [
            "json",
            "csv",
            "export-to-csv",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1496908122,
                "creation_date": 1496908122,
                "answer_id": 44429715,
                "question_id": 44428844,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "All the values to be printed in a CSV row must be collected in a JSON array.  A solution that is very similar to your attempt would therefore be:\r\n\r\n    .sites[]\r\n    | [.site_id, .domain, (.security.waf.rules[] | .action_text) ]\r\n    | @csv\r\n\r\nBy the way, there is no need to use `cat`:\r\n\r\n    jq -r -f program.jq test.json\r\n\r\n",
                "title": "Yet struggling to parse JSON with jq"
            },
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1496938595,
                "last_edit_date": 1496938595,
                "creation_date": 1496908131,
                "answer_id": 44429718,
                "question_id": 44428844,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "First lets discuss why you received that result.\r\n\r\nWhen you use `[]` to extract items from objects/arrays, it yields a value for every item in that object/array.\r\n\r\n    .sites[]\r\n\r\nproduces a result for the every value in your `sites` array (which in this case there&#39;s only one).\r\n\r\nAnother thing to note, using a comma (`,`) will yield the delimited values within that expression.\r\n\r\n    [.site_id,.domain]\r\n\r\nThe comma here produces two values, the `site_id` and the `domain`.  But, those values are collected in to an array (as denoted by the square brackets).\r\n\r\nPutting this into the next part of the expression\r\n\r\n    .security.waf.rules[] | [.action_text]\r\n\r\nThe first part goes through all the rules objects in that array. Then for each of those objects, creates an array containing the `action_text`.  This creates three arrays (one for each of the rules).\r\n\r\nPut this together with the previous part of the expression (slightly reformatted)\r\n\r\n    ([.site_id,.domain]) , (.security.waf.rules[] | [.action_text])\r\n\r\nThis all together produces four arrays, the array containing the `site_id` and `domain`, followed by the three arrays of `action_text`.\r\n\r\nThen for each of those four arrays, a csv row is created giving you the results you see.\r\n\r\n&lt;hr&gt;\r\n\r\nSo how can we get the desired results?\r\n\r\nFirst, we&#39;ll want to start go through all the sites.  I&#39;m assuming you want a row per site.\r\n\r\n    .sites[]\r\n\r\nThen for each site, we need to build an array of the values in that row.  Start with what we have direct access to.\r\n\r\n    .site_id, .domain\r\n\r\nThen produce the `action_text` values.\r\n\r\n    .security.waf.rules[].action_text\r\n\r\nNote we&#39;re not putting the `action_text` in a separate array, we just want the value.\r\n\r\nNow we put those values together.\r\n\r\n    .site_id, .domain, (.security.waf.rules[].action_text)\r\n\r\nThis creates five values as we discussed, but we want to collect them in an array so we may pass it to the `@csv` filter.\r\n\r\n    [.site_id, .domain, (.security.waf.rules[].action_text)]\r\n\r\nPutting everything together will give us this filter:\r\n\r\n    .sites[] | [.site_id, .domain, (.security.waf.rules[].action_text)] | @csv\r\n\r\nOf course there&#39;s many approaches you can take to get these values (like building out arrays separately then combining them) but this is the most direct.",
                "title": "Yet struggling to parse JSON with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 4,
        "last_activity_date": 1572693126,
        "creation_date": 1496905545,
        "last_edit_date": 1572693126,
        "question_id": 44428844,
        "body_markdown": "I&#39;m slowly getting a grip of how jq works but am still far from mastering it.\r\nNow I&#39;m in a situation I&#39;ve kinda managed to get what I wanted but not to display it the way I want. I&#39;m sure it&#39;s quite simple but I&#39;m missing it...\r\n\r\nHere&#39;s a sample of the JSON I want to parse:\r\n\r\n    {\r\n    \t&quot;sites&quot;: [\r\n    \t\t{\r\n    \t\t\t&quot;site_id&quot;: 123456,\r\n    \t\t\t&quot;status&quot;: &quot;configured&quot;,\r\n    \t\t\t&quot;domain&quot;: &quot;www.domain.com&quot;,\r\n    \t\t\t&quot;account_id&quot;: 654321,\r\n    \t\t\t&quot;security&quot;: {\r\n    \t\t\t\t&quot;waf&quot;: {\r\n    \t\t\t\t\t&quot;rules&quot;: [\r\n    \t\t\t\t\t\t{\r\n    \t\t\t\t\t\t\t&quot;action&quot;: &quot;block_request&quot;,\r\n    \t\t\t\t\t\t\t&quot;action_text&quot;: &quot;Block&quot;,\r\n    \t\t\t\t\t\t\t&quot;id&quot;: &quot;sqli&quot;,\r\n    \t\t\t\t\t\t\t&quot;name&quot;: &quot;SQLi&quot;\r\n    \t\t\t\t\t\t},\r\n    \t\t\t\t\t\t{\r\n    \t\t\t\t\t\t\t&quot;action&quot;: &quot;block_request&quot;,\r\n    \t\t\t\t\t\t\t&quot;action_text&quot;: &quot;Block&quot;,\r\n    \t\t\t\t\t\t\t&quot;id&quot;: &quot;xss&quot;,\r\n    \t\t\t\t\t\t\t&quot;name&quot;: &quot;XSS&quot;\r\n    \t\t\t\t\t\t},\r\n    \t\t\t\t\t\t{\r\n    \t\t\t\t\t\t\t&quot;action&quot;: &quot;alert&quot;,\r\n    \t\t\t\t\t\t\t&quot;action_text&quot;: &quot;Alert&quot;,\r\n    \t\t\t\t\t\t\t&quot;id&quot;: &quot;path_vector&quot;,\r\n    \t\t\t\t\t\t\t&quot;name&quot;: &quot;Path Vector&quot;\r\n    \t\t\t\t\t\t}\r\n    \t\t\t\t\t]\r\n    \t\t\t\t}\r\n    \t\t\t}\r\n    \t\t}\r\n    \t],\r\n    \t&quot;res&quot;: 0,\r\n    \t&quot;res_message&quot;: &quot;OK&quot;,\r\n    \t&quot;debug_info&quot;: {\r\n    \t\t&quot;id-info&quot;: &quot;9123&quot;\r\n    \t}\r\n    }\r\n\r\nI only need a few details and put them in CSV format, here&#39;s what I did so far:\r\n\r\n    cat test.json | jq -r &#39;.sites [] | [.site_id,.domain],(.security.waf.rules[] | [.action_text]) | @csv&#39;\r\n\r\nThis is the ouput I got:\r\n\r\n    123456,&quot;www.domain.com&quot;\r\n    &quot;Block&quot;\r\n    &quot;Block&quot;\r\n    &quot;Alert&quot;\r\n\r\nNot so bad, but what I&#39;m looking for is something like this:\r\n\r\n    123456,&quot;www.domain.com&quot;,&quot;Block&quot;,&quot;Block&quot;,&quot;Alert&quot;\r\n\r\nSame result, just displayed in one single line.\r\nI went over the man pages and fiddled around for a while to no avail.\r\nIs it possible to do it or I need a different tool to manipulate it?\r\n\r\nThanks in advance!\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/44428844/yet-struggling-to-parse-json-with-jq",
        "title": "Yet struggling to parse JSON with jq"
    },
    {
        "tags": [
            "json",
            "filter",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 170085,
                    "reputation": 14111,
                    "user_id": 396567,
                    "user_type": "registered",
                    "accept_rate": 83,
                    "profile_image": "https://i.sstatic.net/ZL3EFR4m.jpg?s=256",
                    "display_name": "Michael Hausenblas",
                    "link": "https://stackoverflow.com/users/396567/michael-hausenblas"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1496935279,
                "post_id": 44439671,
                "comment_id": 75876946,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 170085,
                    "reputation": 14111,
                    "user_id": 396567,
                    "user_type": "registered",
                    "accept_rate": 83,
                    "profile_image": "https://i.sstatic.net/ZL3EFR4m.jpg?s=256",
                    "display_name": "Michael Hausenblas",
                    "link": "https://stackoverflow.com/users/396567/michael-hausenblas"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1496935743,
                "post_id": 44439671,
                "comment_id": 75877313,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 5752502,
                    "reputation": 323,
                    "user_id": 4541683,
                    "user_type": "registered",
                    "accept_rate": 60,
                    "profile_image": "https://www.gravatar.com/avatar/4c14648fcd0b7d2bf98bd325968253fc?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "ptou",
                    "link": "https://stackoverflow.com/users/4541683/ptou"
                },
                "reply_to_user": {
                    "account_id": 170085,
                    "reputation": 14111,
                    "user_id": 396567,
                    "user_type": "registered",
                    "accept_rate": 83,
                    "profile_image": "https://i.sstatic.net/ZL3EFR4m.jpg?s=256",
                    "display_name": "Michael Hausenblas",
                    "link": "https://stackoverflow.com/users/396567/michael-hausenblas"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1496936453,
                "post_id": 44439671,
                "comment_id": 75877887,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 8315485,
                    "reputation": 16244,
                    "user_id": 7128034,
                    "user_type": "registered",
                    "accept_rate": 85,
                    "profile_image": "https://i.sstatic.net/d7vxz.png?s=256",
                    "display_name": "developer_hatch",
                    "link": "https://stackoverflow.com/users/7128034/developer-hatch"
                },
                "reply_to_user": {
                    "account_id": 170085,
                    "reputation": 14111,
                    "user_id": 396567,
                    "user_type": "registered",
                    "accept_rate": 83,
                    "profile_image": "https://i.sstatic.net/ZL3EFR4m.jpg?s=256",
                    "display_name": "Michael Hausenblas",
                    "link": "https://stackoverflow.com/users/396567/michael-hausenblas"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1496938594,
                "post_id": 44439671,
                "comment_id": 75879337,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": false,
                "score": 5,
                "last_activity_date": 1496962919,
                "last_edit_date": 1496962919,
                "creation_date": 1496938108,
                "answer_id": 44440701,
                "question_id": 44439671,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "I think this is what you are looking for:\r\n\r\n\r\n    [ to_entries[] | .value = .value.value ] | from_entries\r\n\r\nA simpler way:\r\n\r\n    with_entries(.value |= .value)\r\n\r\nCheck the result here:\r\n\r\nhttps://jqplay.org/s/uHqfdPoF3e",
                "title": "jq - nested dictionary parser and extract key"
            },
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1496938835,
                "creation_date": 1496938835,
                "answer_id": 44440931,
                "question_id": 44439671,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "If you&#39;re merely getting the `value` of every `value` in the root object, you could use `map_values/1` to get those values.\r\n\r\n    map_values(.value)",
                "title": "jq - nested dictionary parser and extract key"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 4,
        "last_activity_date": 1496962919,
        "creation_date": 1496935110,
        "last_edit_date": 1496938524,
        "question_id": 44439671,
        "body_markdown": "I am trying to parse with jq the following structure:\r\n\r\n    {\r\n        &quot;a&quot;: {\r\n            &quot;sensitive&quot;: false,\r\n            &quot;type&quot;: &quot;string&quot;,\r\n            &quot;value&quot;: &quot;mykeypair&quot;\r\n        },\r\n        &quot;b&quot;: {\r\n            &quot;sensitive&quot;: false,\r\n            &quot;type&quot;: &quot;string&quot;,\r\n            &quot;value&quot;: &quot;123&quot;\r\n        }\r\n    }\r\n\r\nand get this as an output:\r\n\r\n    {\r\n            &quot;a&quot;: &quot;mykeypair&quot;,\r\n            &quot;b&quot;: &quot;123&quot;\r\n    }\r\n\r\nI would like the key and as a value, the value of the field &#39;value&#39;.\r\nAny idea?\r\nCheers,",
        "link": "https://stackoverflow.com/questions/44439671/jq-nested-dictionary-parser-and-extract-key",
        "title": "jq - nested dictionary parser and extract key"
    },
    {
        "tags": [
            "json",
            "string",
            "parsing",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1497253811,
                "last_edit_date": 1497253811,
                "creation_date": 1497015448,
                "answer_id": 44459283,
                "question_id": 44459049,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Your json is incorrect (you can verify in on https://jsonlint.com), you can try this one:\r\n\r\n    {\r\n    \t&quot;additionalInfo&quot;: {\r\n    \t\t&quot;pgUsername&quot;: &quot;postgres&quot;,\r\n    \t\t&quot;pgPassword&quot;: &quot;postgres&quot;,\r\n    \t\t&quot;pgHostname&quot;: &quot;pgmaster&quot;\r\n    \t}\r\n    }\r\n\r\nAnd you will get expected result:\r\n\r\n    $ cat data.json| jq -r &#39;.additionalInfo .pgPassword&#39;\r\n    postgres\r\n\r\n---\r\nEDIT\r\n\r\nFor your modified data you can use:\r\n\r\n    $ cat data.json| jq -r &#39;.additionalInfo&#39; | jq &#39;.pgPassword&#39;\r\n    postgres\r\n\r\n---\r\nEDIT AGAIN\r\n\r\nPlease, see a [comment][1] by @peak -- it doesn&#39;t require multiple execution of `jq`, instead he proposes to use `fromjson` builtin.\r\n\r\n\r\n  [1]: https://stackoverflow.com/a/44461208/279355",
                "title": "Not able to parse the json using jq"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1497020989,
                "creation_date": 1497020989,
                "answer_id": 44461208,
                "question_id": 44459049,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Thanks to `fromjson`, there&#39;s no need to invoke jq twice:\r\n\r\n    jq -r &#39;.additionalInfo|fromjson|.pgPassword&#39; data.json\r\n    postgres",
                "title": "Not able to parse the json using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1497450907,
        "creation_date": 1497014782,
        "last_edit_date": 1497450907,
        "question_id": 44459049,
        "body_markdown": "I have following json with me ( file name sample.json)-\r\n\r\n&gt; {\r\n\t&quot;Prefix&quot;: &quot;pg&quot;,  \r\n\t&quot;fileFormat&quot;: &quot;gz&quot;,  \r\n\t&quot;additionalInfo&quot;:\r\n&quot;\r\n {\\&quot;pgUsername\\&quot;:\\&quot;postgres\\&quot;,\\&quot;pgPassword\\&quot;:\\&quot;postgres\\&quot;,\\&quot;pgHostname\\&quot;:\\&quot;pgmaster\\&quot;}&quot;  \r\n}\r\n\r\nI am reading these parameters using follwoing command-  \r\n` cat sample.json | jq -r &#39;.additionalInfo .pgPassword&#39;`\r\n\r\nexpected output is `postgres`, but I am getting something like `[26]`\r\n\r\nI cant change this json. Does anyone knows, what command should be used to get correct output? Thanks in advance.\r\n",
        "link": "https://stackoverflow.com/questions/44459049/not-able-to-parse-the-json-using-jq",
        "title": "Not able to parse the json using jq"
    },
    {
        "tags": [
            "arrays",
            "json",
            "string",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 24,
                "is_accepted": true,
                "score": 24,
                "last_activity_date": 1497235956,
                "last_edit_date": 1497235956,
                "creation_date": 1497127472,
                "answer_id": 44477891,
                "question_id": 44477810,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "If your jq has `inputs` then the simplest would probably be to use it:\r\n\r\n    jq -ncR &#39;[inputs]&#39; &lt;&lt;&lt; &quot;$groups&quot;\r\n    [&quot;group1&quot;,&quot;group2&quot;,&quot;group3&quot;]\r\n\r\nOtherwise, here are three alternatives:\r\n\r\n    jq -c -n --arg groups &quot;$groups&quot; &#39;$groups | split(&quot;\\n&quot;)&#39; \r\n\r\n    echo -n &quot;$groups&quot; | jq -cRs &#39;split(&quot;\\n&quot;)&#39;\r\n\r\n    echo &quot;$groups&quot; | jq -R -s -c &#39;split(&quot;\\n&quot;) | map(select(length&gt;0))&#39;\r\n\r\nIn any case, the array can easily be incorporated into a JSON object, e.g. by extending the filter with `| {groups: .}`\r\n\r\nIf you really want to produce invalid JSON, consider:\r\n\r\n    printf &quot;%s&quot; &quot;$groups&quot; | jq -Rrsc &#39;split(&quot;\\n&quot;) | &quot;{ \\(.) }&quot;&#39;\r\n\r\nOutput:\r\n\r\n    { [&quot;group_1&quot;,&quot;group_2&quot;,&quot;group_3&quot;] }\r\n\r\n### Note on select(length&gt;0)\r\n\r\nConsider:\r\n\r\n     jq -Rsc &#39;split(&quot;\\n&quot;)&#39; &lt;&lt;&lt; $&#39;a\\nb&#39;\r\n     [&quot;a&quot;,&quot;b&quot;,&quot;&quot;]\r\n\r\nThe reason for including `select(length&gt;0)` is to avoid the trailing &quot;&quot;. \r\n\r\nIf $groups contains consecutive newlines, and if it is important to retain the empty strings, then you might want to use `[:-1]`, e.g.\r\n\r\n    jq -cRs &#39;split(&quot;\\n&quot;)[:-1]&#39; &lt;&lt;&lt; &quot;$groups&quot;\r\n    [&quot;group1&quot;,&quot;group2&quot;,&quot;group3&quot;]\r\n\r\nIf your jq does not support `[:-1]`, make the 0 explicit: `[0:-1]`\r\n",
                "title": "How to convert string list to JSON string array in Bash?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 11,
        "last_activity_date": 1497238767,
        "creation_date": 1497126925,
        "last_edit_date": 1497238767,
        "question_id": 44477810,
        "body_markdown": "How can I convert a variable in Bash with a string list containing newlines, like this\r\n\r\n    groups=&quot;group_1\r\n    group_2\r\n    group_3&quot;\r\n\r\nto a JSON string array:\r\n\r\n    {\r\n        [ &quot;group_1&quot;, &quot;group_2&quot;, &quot;group 3&quot; ]\r\n    }\r\n\r\nIs this possible with jq?",
        "link": "https://stackoverflow.com/questions/44477810/how-to-convert-string-list-to-json-string-array-in-bash",
        "title": "How to convert string list to JSON string array in Bash?"
    },
    {
        "tags": [
            "arrays",
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1497271740,
                "post_id": 44495074,
                "comment_id": 75993039,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1497287151,
                "creation_date": 1497287151,
                "answer_id": 44505010,
                "question_id": 44495074,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Assuming that the enclosing braces have been added to make the input valid JSON, the filter:\r\n\r\n\r\n    .value[]\r\n    | [.Id] + (.FeatureStatus[] | [ .FeatureName, .FeatureServiceStatus ])\r\n\r\nproduces:\r\n\r\n    [&quot;SwayEnterprise&quot;,&quot;Sway1&quot;,&quot;ServiceOperational&quot;]\r\n    [&quot;SwayEnterprise&quot;,&quot;Sway2&quot;,&quot;ServiceDegraded&quot;]\r\n    [&quot;yammer&quot;,&quot;yammerfeatures&quot;,&quot;ServiceOperational&quot;]\r\n\r\nYou can then easily reformat this as desired.",
                "title": "Construct unique arrays from nested array values with common parents"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1497287151,
        "creation_date": 1497257274,
        "question_id": 44495074,
        "body_markdown": "Likely a close question to https://stackoverflow.com/questions/43755787/jq-nested-json-transformation but I wasn&#39;t able to get my head around it.\r\n\r\n**Sample JSON:**\r\n\r\n    &quot;value&quot;: [\r\n    {\r\n      &quot;FeatureStatus&quot;: [\r\n        {\r\n          &quot;FeatureName&quot;: &quot;Sway1&quot;,\r\n          &quot;FeatureServiceStatus&quot;: &quot;ServiceOperational&quot;\r\n        },\r\n        {\r\n          &quot;FeatureName&quot;: &quot;Sway2&quot;,\r\n          &quot;FeatureServiceStatus&quot;: &quot;ServiceDegraded&quot;\r\n        }\r\n      ],\r\n      &quot;Id&quot;: &quot;SwayEnterprise&quot;,\r\n    },\r\n    {\r\n      &quot;FeatureStatus&quot;: [\r\n        {\r\n          &quot;FeatureName&quot;: &quot;yammerfeatures&quot;,\r\n          &quot;FeatureServiceStatus&quot;: &quot;ServiceOperational&quot;\r\n        }\r\n      ],\r\n      &quot;Id&quot;: &quot;yammer&quot;\r\n    }\r\n    ]\r\n\r\nWhat I want to do is create an output with jq which results in the following;\r\n\r\n    {&quot;Sway&quot;:&quot;Sway1&quot;:&quot;ServiceOperational&quot;},\r\n    {&quot;Sway&quot;:&quot;Sway2&quot;:&quot;ServiceDegraded&quot;},\r\n    {&quot;Yammer&quot;:&quot;yammerfeatures&quot;:&quot;ServiceOperational&quot;}\r\n\r\nMy various attempts either end up with thousands of non-unique (i.e Yammer with Sway status), or only one Id with x number of FeatureServiceStatus.\r\n\r\nAny pointers would be greatly appreciated. I&#39;ve gone through the tutorial and the cookbook. I am perhaps 2.5 days into using jq.",
        "link": "https://stackoverflow.com/questions/44495074/construct-unique-arrays-from-nested-array-values-with-common-parents",
        "title": "Construct unique arrays from nested array values with common parents"
    },
    {
        "tags": [
            "jq",
            "iso8601"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3842961,
                    "reputation": 93062,
                    "user_id": 3185459,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/u8EuP.jpg?s=256",
                    "display_name": "RomanPerekhrest",
                    "link": "https://stackoverflow.com/users/3185459/romanperekhrest"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1497264589,
                "post_id": 44497533,
                "comment_id": 75988171,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 7943529,
                    "reputation": 747,
                    "user_id": 5996722,
                    "user_type": "registered",
                    "accept_rate": 62,
                    "profile_image": "https://www.gravatar.com/avatar/800c439dfce31690465ac7a2f7d0cbb1?s=256&d=identicon&r=PG",
                    "display_name": "TimoC",
                    "link": "https://stackoverflow.com/users/5996722/timoc"
                },
                "reply_to_user": {
                    "account_id": 3842961,
                    "reputation": 93062,
                    "user_id": 3185459,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/u8EuP.jpg?s=256",
                    "display_name": "RomanPerekhrest",
                    "link": "https://stackoverflow.com/users/3185459/romanperekhrest"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1497265021,
                "post_id": 44497533,
                "comment_id": 75988399,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 1301452,
                    "reputation": 47599,
                    "user_id": 1331399,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/4a22763d295c9d45db0dd0c692bb4051?s=256&d=identicon&r=PG",
                    "display_name": "Thor",
                    "link": "https://stackoverflow.com/users/1331399/thor"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1497266561,
                "post_id": 44497533,
                "comment_id": 75989381,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 29,
                "is_accepted": true,
                "score": 29,
                "last_activity_date": 1497267249,
                "last_edit_date": 1497267249,
                "creation_date": 1497266898,
                "answer_id": 44498345,
                "question_id": 44497533,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Use `todateiso8601` function:\r\n\r\n&lt;!-- language: lang-sh --&gt;\r\n\r\n    jq &#39;.[].arrival |= todateiso8601 | .[].departure |= todateiso8601&#39; C:\\Import\\import_sails.json\r\nThe output (for your input fragment):\r\n\r\n&lt;!-- language: lang-json --&gt;\r\n\r\n    [\r\n      {\r\n        &quot;nid&quot;: 434508,\r\n        &quot;title&quot;: &quot;Die sch&#246;nsten Orte unserer Welt&quot;,\r\n        &quot;nights&quot;: 121,\r\n        &quot;zone&quot;: &quot;Weltreise&quot;,\r\n        &quot;sails_nid&quot;: 434516,\r\n        &quot;arrival&quot;: &quot;2018-05-06T22:00:00Z&quot;,\r\n        &quot;departure&quot;: &quot;2018-01-05T23:00:00Z&quot;,\r\n        &quot;cabintype&quot;: &quot;Innenkabine&quot;,\r\n        &quot;cabinid&quot;: 379723,\r\n        &quot;catalogPrice&quot;: 17879,\r\n        &quot;discountPrice&quot;: 9519,\r\n        &quot;discountPercentage&quot;: 0.4675876726886291,\r\n        &quot;currency&quot;: &quot;EUR&quot;\r\n      },\r\n      {\r\n        &quot;nid&quot;: 434508,\r\n        &quot;title&quot;: &quot;Die sch&#246;nsten Orte unserer Welt&quot;,\r\n        &quot;nights&quot;: 121,\r\n        &quot;zone&quot;: &quot;Weltreise&quot;,\r\n        &quot;sails_nid&quot;: 434516,\r\n        &quot;arrival&quot;: &quot;2018-05-06T22:00:00Z&quot;,\r\n        &quot;departure&quot;: &quot;2018-01-05T23:00:00Z&quot;,\r\n        &quot;cabintype&quot;: &quot;Innenkabine&quot;,\r\n        &quot;cabinid&quot;: 379730,\r\n        &quot;catalogPrice&quot;: 18599,\r\n        &quot;discountPrice&quot;: 10239,\r\n        &quot;discountPercentage&quot;: 0.44948653153395346,\r\n        &quot;currency&quot;: &quot;EUR&quot;\r\n      }\r\n    ]\r\n\r\n",
                "title": "JQ: Transform UNIX Timestamp to Datetime"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1620346183,
                "creation_date": 1620346183,
                "answer_id": 67427449,
                "question_id": 44497533,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I had a similar problem when parsing output of Perforce (with -Mj option),\r\n but the epoch times were *strings*, not numbers.\r\n\r\n    $ p4 -z tag -Mj labels -e &quot;test_build&quot; | jq &#39;.&#39;\r\n    {\r\n      &quot;Access&quot;: &quot;1581356898&quot;,\r\n      &quot;Description&quot;: &quot;Created by p4build.\\n&quot;,\r\n      &quot;Options&quot;: &quot;unlocked noautoreload&quot;,\r\n      &quot;Owner&quot;: &quot;p4build&quot;,\r\n      &quot;Update&quot;: &quot;1580936739&quot;,\r\n      &quot;label&quot;: &quot;test_build&quot;\r\n    }\r\n\r\n Adding `tonumber` into the filter fixes it:\r\n\r\n    $ p4 -z tag -Mj labels -e &quot;test_build&quot; &gt; test.json\r\n    $ jq -s &#39;.[].Access |= (tonumber | todateiso8601) | .[].Update |= (tonumber | todateiso8601)&#39; test.json\r\n    [\r\n      {\r\n        &quot;Access&quot;: &quot;2020-02-10T17:48:18Z&quot;,\r\n        &quot;Description&quot;: &quot;Created by p4build.\\n&quot;,\r\n        &quot;Options&quot;: &quot;unlocked noautoreload&quot;,\r\n        &quot;Owner&quot;: &quot;p4build&quot;,\r\n        &quot;Update&quot;: &quot;2020-02-05T21:05:39Z&quot;,\r\n        &quot;label&quot;: &quot;test_build&quot;\r\n      }\r\n    ]\r\n",
                "title": "JQ: Transform UNIX Timestamp to Datetime"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 19,
        "last_activity_date": 1620346183,
        "creation_date": 1497264445,
        "last_edit_date": 1497305176,
        "question_id": 44497533,
        "body_markdown": "I use actually `JQ1.5` under a `Windows 10` environment to transform several json files for an import to a `MS SQL` database. Part of the data are formatted in `UNIX timestamp` and I need to transform those data to ISO 8601 Format. \r\n\r\nFollowing command i use actually for the transformation of the data:\r\n\r\n&lt;!-- language: lang-sh --&gt;\r\n\r\n    jq &#39;\r\n    [\r\n      { nid, title, nights, zone: .zones[0].title} + \r\n      (.sails[] | { sails_nid: .nid, arrival, departure } ) + \r\n      (.sails[].cabins[] | \r\n        { cabintype: .cabinType.kindName, \r\n          cabinid:   .cabinType.nid,  \r\n          catalogPrice, \r\n          discountPrice, \r\n          discountPercentage, \r\n          currency \r\n        }\r\n      )\r\n    ]\r\n    &#39; C:\\Import\\dreamlines_details.json &gt; C:\\Import\\import_sails.json\r\n\r\nArrival and departure are the data that are in Unix time formated. \r\n\r\nData:\r\n\r\n&lt;!-- language: lang-json --&gt;\r\n\r\n    [\r\n      {\r\n        &quot;nid&quot;: 434508,\r\n        &quot;title&quot;: &quot;Die sch&#246;nsten Orte unserer Welt&quot;,\r\n        &quot;nights&quot;: 121,\r\n        &quot;zone&quot;: &quot;Weltreise&quot;,\r\n        &quot;sails_nid&quot;: 434516,\r\n        &quot;arrival&quot;: 1525644000,\r\n        &quot;departure&quot;: 1515193200,\r\n        &quot;cabintype&quot;: &quot;Innenkabine&quot;,\r\n        &quot;cabinid&quot;: 379723,\r\n        &quot;catalogPrice&quot;: 17879,\r\n        &quot;discountPrice&quot;: 9519,\r\n        &quot;discountPercentage&quot;: 0.4675876726886291,\r\n        &quot;currency&quot;: &quot;EUR&quot;\r\n      },\r\n      {\r\n        &quot;nid&quot;: 434508,\r\n        &quot;title&quot;: &quot;Die sch&#246;nsten Orte unserer Welt&quot;,\r\n        &quot;nights&quot;: 121,\r\n        &quot;zone&quot;: &quot;Weltreise&quot;,\r\n        &quot;sails_nid&quot;: 434516,\r\n        &quot;arrival&quot;: 1525644000,\r\n        &quot;departure&quot;: 1515193200,\r\n        &quot;cabintype&quot;: &quot;Innenkabine&quot;,\r\n        &quot;cabinid&quot;: 379730,\r\n        &quot;catalogPrice&quot;: 18599,\r\n        &quot;discountPrice&quot;: 10239,\r\n        &quot;discountPercentage&quot;: 0.44948653153395346,\r\n        &quot;currency&quot;: &quot;EUR&quot;\r\n      }\r\n    ]\r\n\r\nI experimented with built in operator &quot;todate&quot; and &quot;strftime&quot;. But get only parsing Errors.\r\n",
        "link": "https://stackoverflow.com/questions/44497533/jq-transform-unix-timestamp-to-datetime",
        "title": "JQ: Transform UNIX Timestamp to Datetime"
    },
    {
        "tags": [
            "default-value",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1497331054,
                "last_edit_date": 1497331054,
                "creation_date": 1497286214,
                "answer_id": 44504729,
                "question_id": 44497817,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "For clarity, a helper function for merging same-age records is useful. This is where the default values are defined:\r\n\r\n    def merge:\r\n      reduce .[] as $x ([0,0];\r\n        if $x.city == &quot;SH&quot; then .[0] = $x.count else .[1] = $x.count end);\r\n\r\nNext, we have only to group records by age:\r\n\r\n    group_by(.age)\r\n    | map( {age: .[0].age, data: merge} )\r\n\r\nInvocation:\r\n\r\n    jq -c -f program.jq input.json\r\n\r\n\r\nResult:\r\n\r\n    [{&quot;age&quot;:0,&quot;data&quot;:[1,0]},{&quot;age&quot;:20,&quot;data&quot;:[1,2]},{&quot;age&quot;:30,&quot;data&quot;:[0,1]},{&quot;age&quot;:40,&quot;data&quot;:[1,0]}]\r\n\r\nYou can then format the result in whichever way you want.\r\n\r\n    \r\n",
                "title": "jq specify default value for some situation"
            },
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1497329999,
                "last_edit_date": 1497329999,
                "creation_date": 1497329294,
                "answer_id": 44512598,
                "question_id": 44497817,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "If the relevant city names are not know beforehand, then the following approach has much to recommend it if the city names are strings:\r\n\r\n    # Merge records having the same age\r\n    def merge:\r\n      reduce .[] as $x ({}; . + ($x | { (.city) : .count}) );\r\n\r\n    # Create an object holding the default values:\r\n    def zeros:\r\n      map( {(tostring): 0} ) | add;\r\n  \r\n    group_by(.age)\r\n    | map( {age: .[0].age, data: merge} )\r\n    | (map(.data) | add | keys | zeros) as $zeros\r\n    | map( .data = $zeros + .data )\r\n\r\nThe output of the above is an array of objects having the form:\r\n    {&quot;age&quot;: _, &quot;data&quot;: CITIES}\r\n\r\ne.g.\r\n\r\n     {\r\n        &quot;age&quot;: 40,\r\n        &quot;data&quot;: {\r\n          &quot;BJ&quot;: 0,\r\n          &quot;SH&quot;: 1\r\n        }\r\n      } \r\n\r\nIt is now easy to transmogrify CITIES to the desired format.\r\n\r\n",
                "title": "jq specify default value for some situation"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1497435072,
        "creation_date": 1497265355,
        "last_edit_date": 1497435072,
        "question_id": 44497817,
        "body_markdown": "Now I have a json \r\n\r\n    [\r\n      {\r\n        &quot;city&quot;: &quot;SH&quot;,\r\n        &quot;age&quot;: 0,\r\n        &quot;count&quot;: 1\r\n      },\r\n      {\r\n        &quot;city&quot;: &quot;SH&quot;,\r\n        &quot;age&quot;: 20,\r\n        &quot;count&quot;: 1\r\n      },\r\n      {\r\n        &quot;city&quot;: &quot;SH&quot;,\r\n        &quot;age&quot;: 40,\r\n        &quot;count&quot;: 1\r\n      },\r\n      {\r\n        &quot;city&quot;: &quot;BJ&quot;,\r\n        &quot;age&quot;: 20,\r\n        &quot;count&quot;: 2\r\n      },\r\n      {\r\n        &quot;city&quot;: &quot;BJ&quot;,\r\n        &quot;age&quot;: 30,\r\n        &quot;count&quot;: 1\r\n      }\r\n    ]\r\n\r\nNow I want to get the count array of every age for some data visualization purpose(see [demo][1]). e.g\r\n\r\n    # age data: [shCount, bjCount]\r\n    age: 0, data:[1, 0]\r\n    age: 20, data: [1, 2] \r\n    age: 30, data: [0, 1]\r\n    age: 40, data: [1, 0]\r\n\r\nIf the city does not have the age, give a default value 0. But if the city does not have the age, it will have not the related json object.\r\n\r\nSo I cannot just by using below shell to get count array of every age, e.g\r\n\r\n    # without BJ value\r\n    ➜  ~ jq -c &#39;.[] | select(.age==0) | [.city, .count]&#39; foo.json\r\n    [&quot;SH&quot;,1]\r\n    \r\n    ➜  ~ jq -c &#39;.[] | select(.age==20) | [.city, .count]&#39; foo.json\r\n    [&quot;SH&quot;,1]\r\n    [&quot;BJ&quot;,2]\r\n\r\nSo if age is 0, how to specify a default value of 0 to `BJ`?\r\n\r\n\r\n  [1]: http://gallery.echartsjs.com/editor.html?c=xSk1tZenM-&amp;v=3",
        "link": "https://stackoverflow.com/questions/44497817/jq-specify-default-value-for-some-situation",
        "title": "jq specify default value for some situation"
    },
    {
        "tags": [
            "bash",
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1565888,
                    "reputation": 19445,
                    "user_id": 1454708,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/eSzgk.png?s=256",
                    "display_name": "Nahuel Fouilleul",
                    "link": "https://stackoverflow.com/users/1454708/nahuel-fouilleul"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1497342552,
                "post_id": 44516029,
                "comment_id": 76024557,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 44,
                "is_accepted": true,
                "score": 43,
                "last_activity_date": 1497363742,
                "last_edit_date": 1497363742,
                "creation_date": 1497342563,
                "answer_id": 44516121,
                "question_id": 44516029,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Just use a variable and save yourself the hassle:\r\n\r\n    &lt; package.json jq --arg b &quot;$BOO&quot; &#39;. + { foo: $b }&#39;\r\n`--arg b &quot;$BOO&quot;` creates a variable `$b` that you can use inside `jq`, without having to deal with quoting issues.\r\n\r\nThat said, the reason that your attempt was failing was that you were missing some literal double quotes:\r\n\r\n    &lt; package.json jq &#39;. + { foo: &quot;&#39;&quot;$BOO&quot;&#39;&quot; }&#39;\r\nThe extra double quotes _inside_ each of the the single-quoted parts of the command are needed, as the other ones are consumed by the shell before the command string is passed to `jq`.\r\n\r\nThis will still fail in the case that the shell variable contains any quotes, so the first approach is the preferred one.",
                "title": "Escape quotes in jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 18,
        "last_activity_date": 1497363742,
        "creation_date": 1497342234,
        "last_edit_date": 1497343639,
        "question_id": 44516029,
        "body_markdown": "I&#39;ve the following two bash lines\r\n\r\n    TMPFILE=&quot;$(mktemp)&quot; || exit 1\r\n    \r\n    &lt; package.json jq &#39;. + {&quot;foo&quot;:&#39;&quot;${BOO}&quot;&#39;}&#39; &gt; &quot;$TMPFILE&quot;\r\n\r\nbut I get the following error:\r\n\r\n\r\n    jq: error: syntax error, unexpected &#39;}&#39; (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n    . + {&quot;foo&quot;:}\r\n    jq: 1 compile error\r\n\r\nany idea how to escape properly that part by having the double quote there to mute the shellcheck error",
        "link": "https://stackoverflow.com/questions/44516029/escape-quotes-in-jq",
        "title": "Escape quotes in jq"
    },
    {
        "tags": [
            "unix",
            "trim",
            "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": 1497370710,
                "post_id": 44526740,
                "comment_id": 76045278,
                "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": 1,
                "creation_date": 1497371273,
                "post_id": 44526740,
                "comment_id": 76045618,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 2719313,
                    "reputation": 16059,
                    "user_id": 2345933,
                    "user_type": "registered",
                    "accept_rate": 84,
                    "profile_image": "https://i.sstatic.net/b2BbE.jpg?s=256",
                    "display_name": "Adam Siemion",
                    "link": "https://stackoverflow.com/users/2345933/adam-siemion"
                },
                "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": 1497378210,
                "post_id": 44526740,
                "comment_id": 76049520,
                "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": 1497382114,
                "post_id": 44526740,
                "comment_id": 76051601,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 3889535,
                    "reputation": 20152,
                    "user_id": 3220113,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/10f69140e2a641a9f2f63bc09bc0e32c?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Walter A",
                    "link": "https://stackoverflow.com/users/3220113/walter-a"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1497391131,
                "post_id": 44526740,
                "comment_id": 76056162,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 10,
                "is_accepted": true,
                "score": 10,
                "last_activity_date": 1497919133,
                "last_edit_date": 1497919133,
                "creation_date": 1497371088,
                "answer_id": 44526894,
                "question_id": 44526740,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The below will remove leading and trailing spaces in strings anywhere inside an arbitrarily complex JSON structure:\r\n\r\n    #!/usr/bin/env jq -cf\r\n\r\n    # Define walk function (standard library only for jq 1.6 and newer, currently unreleased)\r\n    def walk(f):\r\n      . as $in\r\n      | if type == &quot;object&quot; then\r\n          reduce keys_unsorted[] 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(\r\n      if type == &quot;string&quot; then\r\n        (sub(&quot;^[[:space:]]+&quot;; &quot;&quot;) | sub(&quot;[[:space:]]+$&quot;; &quot;&quot;))\r\n      else . end\r\n    )\r\n\r\nIf one saves the above (e.g. in `trim-json`), and marks it executable (`chmod +x trim-json`), then `./trim-json &lt;&lt;&lt;&quot;$json&quot;` with your given input emits:\r\n\r\n    [{&quot;k1&quot;:&quot;v1&quot;,&quot;k2&quot;:&quot;v2&quot;,&quot;k3&quot;:&quot;v3&quot;,&quot;k4&quot;:&quot;v4&quot;}]\r\n\r\nSimilarly, with the updated input:\r\n\r\n    $ json=&#39;[{&quot;k1&quot;:&quot; http://url&quot;, &quot;k2&quot;:null, &quot;k3&quot;:&quot; v3&quot;, &quot;k4&quot;:&quot; v4&quot;}]&#39;\r\n    $ ./trim-json &lt;&lt;&lt;&quot;$json&quot;\r\n    [{&quot;k1&quot;:&quot;http://url&quot;,&quot;k2&quot;:null,&quot;k3&quot;:&quot;v3&quot;,&quot;k4&quot;:&quot;v4&quot;}]",
                "title": "How to trim white space for every element in JQ?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": -1,
                "last_activity_date": 1615325654,
                "last_edit_date": 1615325654,
                "creation_date": 1497371579,
                "answer_id": 44527044,
                "question_id": 44526740,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The example has a space in front of every value. For the case where you can simply remove the first (or N) characters of a string, then a simple map over range slicing works:\r\n\r\n    $ jq -c &#39;.[] | map_values(.[1:]) | .k1,.k2&#39; &lt;&lt;&lt; &quot;$json&quot; | paste -d &quot;,&quot; - -\r\n    &quot;http://url&quot;,null\r\n\r\nThis approach has the benefit of being unpretentious and simple to understand.",
                "title": "How to trim white space for every element in JQ?"
            },
            {
                "up_vote_count": 15,
                "is_accepted": false,
                "score": 15,
                "last_activity_date": 1497769132,
                "creation_date": 1497769132,
                "answer_id": 44612511,
                "question_id": 44526740,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "If the input is an array of JSON objects and if you&#39;re looking for a one-liner, then the following seems to meet your requirements:\r\n\r\n    jq &#39;.[]|(.k1,.k2)|if type==&quot;string&quot; then gsub(&quot;^\\\\s+|\\\\s+$&quot;;&quot;&quot;) else . end&#39; | paste -d &quot;,&quot; - -\r\n\r\nWith your input, this produces \r\n\r\n    &quot;http://url&quot;,null\r\n\r\nIf you are flexible about how `null` is presented in the output, you might also consider an all-jq solution (i.e. without `paste`).  For example:\r\n\r\n    jq -r &#39;.[]|[.k1,.k2]|map(if type==&quot;string&quot; then gsub(&quot;^\\\\s+|\\\\s+$&quot;;&quot;&quot;) else . end)|@csv&#39;\r\n\r\nWith your input, this produces:\r\n\r\n    &quot;http://url&quot;,\r\n\r\n\r\n\r\n\r\n",
                "title": "How to trim white space for every element in JQ?"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 9,
        "last_activity_date": 1615325654,
        "creation_date": 1497370551,
        "last_edit_date": 1497425728,
        "question_id": 44526740,
        "body_markdown": "I have the following simple JSON\r\n\r\n    json=&#39;[{&quot;k1&quot;:&quot; http://url&quot;, &quot;k2&quot;:null, &quot;k3&quot;:&quot; v3&quot;, &quot;k4&quot;:&quot; v4&quot;}]&#39;\r\n\r\nwhat I need is:\r\n\r\n    &quot;http://url&quot;,null\r\n\r\n(without a space before `v1` and `v2`)\r\n\r\nWhat I have is:\r\n\r\n    echo $json | jq -c &#39;.[] | .k1, .k2 &#39; | paste -d &quot;,&quot; - -\r\n\r\nHow to get rid of the space in k1 and k2 values?",
        "link": "https://stackoverflow.com/questions/44526740/how-to-trim-white-space-for-every-element-in-jq",
        "title": "How to trim white space for every element in JQ?"
    },
    {
        "tags": [
            "json",
            "updates",
            "edit",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1857717,
                    "reputation": 2120,
                    "user_id": 1682955,
                    "user_type": "registered",
                    "accept_rate": 65,
                    "profile_image": "https://i.sstatic.net/8EfMs.jpg?s=256",
                    "display_name": "Abdul",
                    "link": "https://stackoverflow.com/users/1682955/abdul"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1497422016,
                "post_id": 44533087,
                "comment_id": 76065141,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1497397662,
                "last_edit_date": 1497397662,
                "creation_date": 1497397149,
                "answer_id": 44533194,
                "question_id": 44533087,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The update operator |= should do the trick.\r\n\r\n    jq &#39;.hosts[].statistics[].timestamp |= .date + &quot; &quot; + .time&#39;\r\n \r\n",
                "title": "Multi dimensional array in JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1497432796,
        "creation_date": 1497396319,
        "last_edit_date": 1497432796,
        "question_id": 44533087,
        "body_markdown": "Can some one please help to transform the input json to output format like i specified below . i tried multiple ways but i could not succeed.\r\n\r\nI have input :\r\n\r\n     {\r\n            &quot;hosts&quot;: [\r\n                {\r\n                    &quot;statistics&quot;: [\r\n                        {\r\n                            &quot;timestamp&quot;: {\r\n                                &quot;date&quot;: &quot;2017-06-09&quot;,\r\n                                &quot;time&quot;: &quot;21:40:01&quot;\r\n                            },\r\n                            &quot;cpu-load&quot;: [\r\n                                {\r\n                                    &quot;idle&quot;: 99.64\r\n                                }\r\n                            ]\r\n                        }\r\n                    ]\r\n                }\r\n            ]\r\n        }\r\n    \r\nI need output :\r\n\r\n    {\r\n\r\n        &quot;hosts&quot;: [\r\n            {\r\n                &quot;statistics&quot;: [\r\n                    {\r\n                        &quot;timestamp&quot;: &quot;2017-06-09 21:40:01&quot;,\r\n                        &quot;cpu-load&quot;: [\r\n                            {\r\n                                &quot;idle&quot;: 99.64\r\n                            }\r\n                        ]\r\n                    }\r\n                ]\r\n            }\r\n        ]\r\n    }",
        "link": "https://stackoverflow.com/questions/44533087/multi-dimensional-array-in-jq",
        "title": "Multi dimensional array in JQ"
    },
    {
        "tags": [
            "json",
            "edit",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1309072,
                    "reputation": 139,
                    "user_id": 1257463,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/ee22f1c9db09d0c8f77e10075581c84c?s=256&d=identicon&r=PG",
                    "display_name": "ola",
                    "link": "https://stackoverflow.com/users/1257463/ola"
                },
                "reply_to_user": {
                    "account_id": 1301452,
                    "reputation": 47599,
                    "user_id": 1331399,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/4a22763d295c9d45db0dd0c692bb4051?s=256&d=identicon&r=PG",
                    "display_name": "Thor",
                    "link": "https://stackoverflow.com/users/1331399/thor"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1497449304,
                "post_id": 44545378,
                "comment_id": 76084923,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1497449132,
                "last_edit_date": 1497449132,
                "creation_date": 1497447160,
                "answer_id": 44546337,
                "question_id": 44545378,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The answer in the UPDATE is perfectly fine, but here is a variant that illustrates a couple of points, notably that no variable is needed and that `{x}` can be used as an abbreviation for `{x: .x}`:\r\n\r\n\r\n    .[0] \r\n    + (.[]\r\n       | select(.messageAttributes.data_that_I_Need != null)\r\n       | {id, \r\n          path,\r\n          messageAttributes: {dataThat_I_Need: .messageAttributes.data_that_I_Need}} )\r\n\r\n\r\n",
                "title": "How can I copy data from several input json objects to one output object with jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1497717956,
        "creation_date": 1497444754,
        "last_edit_date": 1592644375,
        "question_id": 44545378,
        "body_markdown": "I have a file where each line is an array of json objects, like:  \n\n&lt;!-- language: lang-json --&gt;\n\n    [\n      {\n        &quot;ts&quot;: &quot;2017-06-13 16:59:35,778&quot;\n      },\n      {\n        &quot;id&quot;: 39,\n        &quot;path&quot;: &quot;/1497365920809-31368-6D8E756916AE1&quot;,\n        &quot;messageAttributes&quot;: {\n          &quot;some_obsolete_data&quot;: &quot;1497365975532&quot;,\n          &quot;more_obsolete_data&quot;: &quot;20&quot;,\n          &quot;c&quot;: &quot;&quot;\n        }\n      },\n      {\n        &quot;id&quot;: 40,\n        &quot;path&quot;: &quot;/1497365920809-31368-6D8E756916AE1&quot;,\n        &quot;messageAttributes&quot;: {\n          &quot;some_obsolete_data&quot;: &quot;some text&quot;,\n          &quot;data_that_I_Need&quot;: &quot;Name,1,Text,1497365975568&quot;\n        }\n      }\n    ]\n\nThe first object of each array will always be a &quot;timestamp&quot; that I need but the following objects may or may not be of interest.  \n\nNow I need to get jq to convert each line to an array of json objects containing the timestamp and the `data_that_I_Need`, like  \n\n&lt;!-- language: lang-json --&gt;\n\n    [\n      {\n        &quot;ts&quot;: &quot;2017-06-13 16:59:35,778&quot;,\n        &quot;id&quot;: 40,\n        &quot;path&quot;: &quot;/1497365920809-31368-6D8E756916AE1&quot;,\n        &quot;messageAttributes&quot;: {\n          &quot;data_that_I_Need&quot;: &quot;Name,1,Text,1497365975568&quot;\n        }\n      }\n    ]\n\nBy doing  \n\n&lt;!-- language: lang-sh --&gt;\n\n    jq &#39;\n      .[]                                                 | \n      select(.messageAttributes.data_that_I_Need != null) |\n      {\n        id   : .id, \n        path : .path, \n        messageAttributes: { \n          dataThat_I_Need: .messageAttributes.data_that_I_Need\n        }\n      }\n    &#39; &lt;my_file.txt \n\nI can filter out the obsolete data. \n\nBut how can I add the &quot;ts&quot; field from the first object as a field in the output?\n\n### UPDATE\n\nLooks like I can set a variable in the beginning of the program that I can use for all following objects...  \n\n&lt;!-- language: lang-sh --&gt;\n\n    jq &#39;\n      .[0].ts as $ts                                      |\n      .[]                                                 |\n      select(.messageAttributes.data_that_I_Need != null) |\n      {\n        ts   : $ts, \n        id   : .id, \n        path : .path, \n        messageAttributes: { \n          dataThat_I_Need: .messageAttributes.data_that_I_Need\n        }\n      }\n    &#39; &lt;my_file.txt",
        "link": "https://stackoverflow.com/questions/44545378/how-can-i-copy-data-from-several-input-json-objects-to-one-output-object-with-jq",
        "title": "How can I copy data from several input json objects to one output object with jq?"
    },
    {
        "tags": [
            "arrays",
            "json",
            "select",
            "jq",
            "blacklist"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 381835,
                    "reputation": 14681,
                    "user_id": 736714,
                    "user_type": "registered",
                    "accept_rate": 63,
                    "profile_image": "https://www.gravatar.com/avatar/70d2c699f89a1f7f76b436bc79b4d5be?s=256&d=identicon&r=PG",
                    "display_name": "deitch",
                    "link": "https://stackoverflow.com/users/736714/deitch"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1497526824,
                "post_id": 44563115,
                "comment_id": 76121649,
                "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": 1,
                "creation_date": 1497571924,
                "post_id": 44563115,
                "comment_id": 76146463,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 381835,
                    "reputation": 14681,
                    "user_id": 736714,
                    "user_type": "registered",
                    "accept_rate": 63,
                    "profile_image": "https://www.gravatar.com/avatar/70d2c699f89a1f7f76b436bc79b4d5be?s=256&d=identicon&r=PG",
                    "display_name": "deitch",
                    "link": "https://stackoverflow.com/users/736714/deitch"
                },
                "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": 1497585683,
                "post_id": 44563115,
                "comment_id": 76149501,
                "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": 1497588775,
                "post_id": 44563115,
                "comment_id": 76150294,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1497520055,
                "last_edit_date": 1497520055,
                "creation_date": 1497518661,
                "answer_id": 44563763,
                "question_id": 44563115,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "I&#39;m sure it is not the most simple solution, but it works :)\r\n\r\n    $ echo &#39;[&quot;a&quot;,&quot;b&quot;,&quot;c&quot;,&quot;d&quot;,&quot;e&quot;]&#39; | jq &#39;.[] | select(test(&quot;[^ac]&quot;))&#39;\r\n\r\n**Edit:** one more solution - this is even worse :)\r\n\r\n    $ echo &#39;[&quot;a&quot;,&quot;b&quot;,&quot;c&quot;,&quot;d&quot;,&quot;e&quot;]&#39; | jq &#39;.[] | select(. != (&quot;a&quot;) and . != (&quot;b&quot;))&#39;",
                "title": "how to use jq to filter select items not in list?"
            },
            {
                "up_vote_count": 28,
                "is_accepted": true,
                "score": 28,
                "last_activity_date": 1498295365,
                "last_edit_date": 1498295365,
                "creation_date": 1497537901,
                "answer_id": 44570506,
                "question_id": 44563115,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The simplest and most robust (w.r.t. jq versions) approach would be to use the builtin `-`:\r\n\r\n    $ echo &#39;[&quot;a&quot;,&quot;b&quot;,&quot;c&quot;,&quot;d&quot;,&quot;e&quot;]&#39; | jq -c &#39;. - [&quot;a&quot;,&quot;c&quot;]&#39;\r\n    [&quot;b&quot;,&quot;d&quot;,&quot;e&quot;]\r\n\r\nIf the blacklist is very long and riddled with duplicates, then it might be appropriate to remove them (e.g. with `unique`).\r\n\r\n### Variations\r\n\r\nThe problem can also be solved (in jq 1.4 and up) using `index` and `not`, e.g.\r\n\r\n    [&quot;a&quot;,&quot;c&quot;] as $blacklist\r\n    | .[] | select( . as $in | $blacklist | index($in) | not) \r\n\r\nOr, with a variable passed in from the command-line (jq --argjson blacklist ...):\r\n  \r\n    .[] | select( . as $in | $blacklist | index($in) | not) \r\n\r\nTo preserve the list structure, one can use `map( select( ...) )`.\r\n\r\nWith jq 1.5 or later, you could also use `any` or `all`, e.g.\r\n\r\n    def except(blacklist):\r\n      map( select( . as $in | blacklist | all(. != $in) ) );\r\n\r\n### Special case: strings\r\n\r\nSee e.g. https://stackoverflow.com/questions/44704404/select-entries-based-on-multiple-values-in-jq",
                "title": "how to use jq to filter select items not in list?"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1722257505,
                "creation_date": 1722257505,
                "answer_id": 78807174,
                "question_id": 44563115,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "As [suggested][1] by @gobenji, since 1.6, you can use `IN` function:\r\n\r\n```shell\r\njq \\\r\n  &#39;\r\n    .[] |\r\n    select(\r\n      . | IN(&quot;a&quot;, &quot;c&quot;) | not\r\n    )\r\n  &#39; \\\r\n  &lt;&lt;&lt;&#39;[&quot;a&quot;,&quot;b&quot;,&quot;c&quot;,&quot;d&quot;,&quot;e&quot;]&#39;\r\n```\r\n\r\n\r\n  [1]: https://stackoverflow.com/questions/44563115/how-to-use-jq-to-filter-select-items-not-in-list#comment122665599_44570506\r\n  [2]: https://jqlang.github.io/jq/manual/v1.5/#in",
                "title": "how to use jq to filter select items not in list?"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 22,
        "last_activity_date": 1722257505,
        "creation_date": 1497517016,
        "last_edit_date": 1497701396,
        "question_id": 44563115,
        "body_markdown": "In jq, I can select an item *in* a list fairly easily:\r\n\r\n    $ echo &#39;[&quot;a&quot;,&quot;b&quot;,&quot;c&quot;,&quot;d&quot;,&quot;e&quot;]&#39; | jq &#39;.[] | select(. == (&quot;a&quot;,&quot;c&quot;))&#39;\r\n\r\nOr if you prefer to get it as an array:\r\n\r\n    $ echo &#39;[&quot;a&quot;,&quot;b&quot;,&quot;c&quot;,&quot;d&quot;,&quot;e&quot;]&#39; | jq &#39;map(select(. == (&quot;a&quot;,&quot;c&quot;)))&#39;\r\n\r\nBut how do I select all of the items that are *not* in the list? Certainly `. != (&quot;a&quot;,&quot;c&quot;)` does not work:\r\n\r\n    $ echo &#39;[&quot;a&quot;,&quot;b&quot;,&quot;c&quot;,&quot;d&quot;,&quot;e&quot;]&#39; | jq &#39;map(select(. != (&quot;a&quot;,&quot;c&quot;)))&#39;\r\n    [\r\n      &quot;a&quot;,\r\n      &quot;b&quot;,\r\n      &quot;b&quot;,\r\n      &quot;c&quot;,\r\n      &quot;d&quot;,\r\n      &quot;d&quot;,\r\n      &quot;e&quot;,\r\n      &quot;e&quot;\r\n    ]\r\n\r\nThe above gives every item twice, except for `&quot;a&quot;` and `&quot;c`&quot;\r\n\r\nSame for:\r\n\r\n    $ echo &#39;[&quot;a&quot;,&quot;b&quot;,&quot;c&quot;,&quot;d&quot;,&quot;e&quot;]&#39; | jq &#39;.[] | select(. != (&quot;a&quot;,&quot;c&quot;))&#39;\r\n    &quot;a&quot;\r\n    &quot;b&quot;\r\n    &quot;b&quot;\r\n    &quot;c&quot;\r\n    &quot;d&quot;\r\n    &quot;d&quot;\r\n    &quot;e&quot;\r\n    &quot;e&quot;\r\n\r\nHow do I filter _out_ the matching items?",
        "link": "https://stackoverflow.com/questions/44563115/how-to-use-jq-to-filter-select-items-not-in-list",
        "title": "how to use jq to filter select items not in list?"
    },
    {
        "tags": [
            "json",
            "bash",
            "foreach",
            "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": 1497576840,
                "post_id": 44564801,
                "comment_id": 76147588,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 4341220,
                    "reputation": 6230,
                    "user_id": 3544399,
                    "user_type": "registered",
                    "accept_rate": 83,
                    "profile_image": "https://www.gravatar.com/avatar/30608c0bc46e774eecc9f458417b194b?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "hmedia1",
                    "link": "https://stackoverflow.com/users/3544399/hmedia1"
                },
                "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": 1497601442,
                "post_id": 44564801,
                "comment_id": 76156435,
                "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": 1497613112,
                "post_id": 44564801,
                "comment_id": 76164216,
                "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": 1497629853,
                "post_id": 44564801,
                "comment_id": 76175344,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 4341220,
                    "reputation": 6230,
                    "user_id": 3544399,
                    "user_type": "registered",
                    "accept_rate": 83,
                    "profile_image": "https://www.gravatar.com/avatar/30608c0bc46e774eecc9f458417b194b?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "hmedia1",
                    "link": "https://stackoverflow.com/users/3544399/hmedia1"
                },
                "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": 1497670136,
                "post_id": 44564801,
                "comment_id": 76188848,
                "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": 1497671402,
                "post_id": 44564801,
                "comment_id": 76189024,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 4341220,
                    "reputation": 6230,
                    "user_id": 3544399,
                    "user_type": "registered",
                    "accept_rate": 83,
                    "profile_image": "https://www.gravatar.com/avatar/30608c0bc46e774eecc9f458417b194b?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "hmedia1",
                    "link": "https://stackoverflow.com/users/3544399/hmedia1"
                },
                "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": 1497671706,
                "post_id": 44564801,
                "comment_id": 76189077,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1497636922,
                "last_edit_date": 1497636922,
                "creation_date": 1497535588,
                "answer_id": 44569657,
                "question_id": 44564801,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "1. The reason your snippet fails in jq 1.4 is that `foreach` was only introduced in version 1.5.\r\n\r\n2. I&#39;m not sure that your program with `foreach` is consistent with your stated requirements, which unfortunately are slightly unclear. For example, what if the &quot;liveBroadcastContent&quot; key appears more than once in the input JSON entity?\r\n\r\n3.  Your stated requirements as I understand them (glossing over the ambiguity) would correspond to the following program, which has been tested with jq 1.4, 1.5 and the current &quot;master&quot; version:\r\n\r\n&lt;/&gt;\r\n\r\n     (reduce (..| select(type == &quot;object&quot; and has(&quot;liveBroadcastContent&quot;))) as $item\r\n        (false; $item | .liveBroadcastContent)) as $chanstatus\r\n     | {location:&quot;location&quot;,\r\n        channel:&quot;channelid&quot;,\r\n        current_id:&quot;vId&quot;,\r\n        id_status:$chanstatus,\r\n        url:&quot;https://youtu.be/\\(&quot;vId&quot;)&quot;}\r\n\r\n4. For multiline programs such as this, it&#39;s usually much more convenient to use the -f option of jq, e.g. `jq -f program.jq`\r\n\r\n5. If you need to accommodate jq 1.3 as well, then you&#39;d have to handle  `..`, which can be done by using `dotdot` defined as follows:\r\n\r\n&lt;/&gt;\r\n\r\n    def dotdot:\r\n      recurse(if (type | . == &quot;object&quot; or . == &quot;array&quot;) then .[] else empty end);\r\n\r\n",
                "title": "How do I make this jq expression, which works in jq &gt;= 1.5, backwards-compatible / correct for versions &lt; 1.5"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1497674449,
                "last_edit_date": 1497674449,
                "creation_date": 1497629434,
                "answer_id": 44593657,
                "question_id": 44564801,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "I&#39;m not sure what your input actually looks like, but given what you&#39;ve shown here, it doesn&#39;t have to be that complicated.\r\n\r\n    {\r\n        location: &quot;location&quot;,\r\n        channel: &quot;channelid&quot;,\r\n        current_id: &quot;vId&quot;,\r\n        id_status: (.liveBroadcastContent? // false),\r\n        url: &quot;https://youtu.be/vId&quot;\r\n    }\r\n\r\nYou wanted to get the value of `liveBroadcastContent` if it exists, otherwise `false` and that&#39;s what precisely `.liveBroadcastContent? // false` does (assuming `null` is not a valid value).\r\n\r\n&lt;hr&gt;\r\n\r\nSeeing your full input object, it seems like a search result from a web api. I don&#39;t think using recursion here is really necessary. If the goal is take each of the results and display various information about each one, I would write this filter instead. (guessing at some of the fields)\r\n\r\n    .items[] | {\r\n        location: .channelTitle,\r\n        channel: .channelId,\r\n        current_id: .id,\r\n        id_status: (.liveBroadcastContent? // false),\r\n        url: &quot;https://youtu.be/\\(.id)&quot;\r\n    }\r\n\r\nIf on the other hand, you were using the search results to determine whether a feed was available (based on your negative input case), I think it would be better to approach it finding the property on the list of results, rather than just the mere existence of the property anywhere.\r\n\r\nI would do this instead:\r\n\r\n    {\r\n        location: &quot;location&quot;,\r\n        channel: &quot;channelid&quot;,\r\n        current_id: &quot;vId&quot;,\r\n        id_status: ([.items[].snippet.liveBroadcastContent | select(. != null)][0] // false),\r\n        url: &quot;https://youtu.be/vId&quot;\r\n    }",
                "title": "How do I make this jq expression, which works in jq &gt;= 1.5, backwards-compatible / correct for versions &lt; 1.5"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1497721074,
        "creation_date": 1497521534,
        "last_edit_date": 1497721074,
        "question_id": 44564801,
        "body_markdown": "In any version (that i&#39;ve tried) of `jq &gt;= 1.5`, **this works fine**.  &lt;br&gt;In any version of `jq &lt;= 1.4`, I get the following error:\r\n\r\n&lt;pre&gt;&lt;code&gt;error: syntax error, unexpected &lt;strong&gt;as&lt;/strong&gt;, expecting FORMAT or QQSTRING_START&lt;/code&gt;&lt;/pre&gt;\r\n\r\nThere&#39;s a lot of information around on the error: *&quot;expecting FORMAT or QQSTRING_START&quot;*, so far what I&#39;ve seen has not applied here, I wonder if it&#39;s the **`as`** that I am not implementing reliably \r\n\r\n**I can recreate the problem with this trivial code:** (can be copied/pasted as is to test)\r\n\r\n &lt;pre&gt;jq \\\r\n&#39;(..|.liveBroadcastContent?&#39;\\\r\n&#39;| foreach . &lt;strong&gt;as&lt;/strong&gt; $item (.; if $item == null then false else . end)) &lt;strong&gt;as&lt;/strong&gt; $chanstatus &#39;\\\r\n&#39;| {location:&quot;location&quot;,\r\nchannel:&quot;channelid&quot;,\r\ncurrent_id:&quot;vId&quot;,\r\nid_status:$chanstatus,\r\nurl:&quot;https://youtu.be/\\\\(&quot;vId&quot;)&quot;}&#39; \\\r\n&lt;&lt;&lt;&#39;{&quot;liveBroadcastContent&quot;:true}&#39;&lt;/pre&gt;\r\n\r\n**Desired result achieved on `jq &gt; 1.5`**:\r\n\r\n    {\r\n      &quot;location&quot;: &quot;location&quot;,\r\n      &quot;channel&quot;: &quot;channelid&quot;,\r\n      &quot;current_id&quot;: &quot;vId&quot;,\r\n      &quot;id_status&quot;: true,\r\n      &quot;url&quot;: &quot;https://youtu.be/vId&quot;\r\n    }\r\n\r\n\r\n**What it&#39;s supposed to do:**\r\n\r\n- If `liveBroadcastContent` **exists** in the input: then output it&#39;s value in the `id_status` key\r\n- If `liveBroadcastContent` **does not exist**: then output `false` in the `id_status` key\r\n- Output everything else as written\r\n\r\n**Actual Input**:\r\n\r\n[This][1] is what goes into the program when there **is** a live stream present.&lt;br&gt;\r\n[This][2] is what goes into the program when there **is no** live streams\r\n\r\nHence I thought `..|.liveBroadcastContent?` was the most reliable way to basically say &quot;*If this key appears **somewhere** in the data, please return it&#39;s value in **&amp;lt;this&gt;** part of my fixed-format output data*&quot;\r\n\r\nNow that the application is obvious, please note that I am aware of using other methods such as checking the value of `&quot;totalResults&quot;`, in combination with `HTTP 200`, amongst others, however:\r\n\r\n 1.  This application of `jq` may be useful elsewhere and I&#39;d like to address it as it.\r\n 2.  This whole program is a shared program invoked as a one-shot on demand basis, which is a backup method (API key) of a more comprehensively implemented oauth server application.  On occasion the input data is different, thus I just want to recursively search for `liveBroadcastContent`\r\n\r\n\r\n**EDIT:** Just to clarify - this **isn&#39;t** about the behavior of `jq` across versions (something that would belong in the `jq` forums) - It&#39;s about making the most robust portable code.  I tend to think that versions &gt;1.5 are simply forgiving a poorly formed expression (which I&#39;m trying to work out here)\r\n\r\n\r\n  [1]: https://ybin.me/p/e72323d0610e321c#8azNQERYjSV1uBgXiSnLSLIv3dQuex3+8NbBj10WQR0=\r\n  [2]: https://ybin.me/p/94bf4e6669950f1b#mkLPmDJ+1h0pcGAPKGr1nAliCxHbVyAks9h3uYQrJWY=",
        "link": "https://stackoverflow.com/questions/44564801/how-do-i-make-this-jq-expression-which-works-in-jq-1-5-backwards-compatible",
        "title": "How do I make this jq expression, which works in jq &gt;= 1.5, backwards-compatible / correct for versions &lt; 1.5"
    },
    {
        "tags": [
            "bash",
            "awk",
            "sed",
            "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": 11,
                "creation_date": 1497970735,
                "post_id": 44656515,
                "comment_id": 76298498,
                "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": 4,
                "creation_date": 1497970924,
                "post_id": 44656515,
                "comment_id": 76298648,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 944527,
                    "reputation": 1319,
                    "user_id": 972040,
                    "user_type": "registered",
                    "accept_rate": 91,
                    "profile_image": "https://www.gravatar.com/avatar/a15117b65a2228a0fd54f3ae591790ba?s=256&d=identicon&r=PG",
                    "display_name": "ruevaughn",
                    "link": "https://stackoverflow.com/users/972040/ruevaughn"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1671090429,
                "post_id": 44656515,
                "comment_id": 132023798,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1403,
                "is_accepted": true,
                "score": 1401,
                "last_activity_date": 1570532348,
                "last_edit_date": 1570532348,
                "creation_date": 1497970683,
                "answer_id": 44656583,
                "question_id": 44656515,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use the `-r` (or `--raw-output`) option to emit raw strings as output:\r\n\r\n    jq -r &#39;.name&#39; &lt;json.txt",
                "title": "How to remove double-quotes in jq output for parsing json files in bash?"
            },
            {
                "up_vote_count": 82,
                "is_accepted": false,
                "score": 81,
                "last_activity_date": 1682188048,
                "last_edit_date": 1682188048,
                "creation_date": 1663950381,
                "answer_id": 73830593,
                "question_id": 44656515,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "So for a file containing just `{&quot;name&quot;: &quot;Google&quot;}` then yes \r\n\r\n    sample=&#39;{&quot;name&quot;:&quot;Google&quot;}&#39;\r\n    echo $sample| jq &#39;.name&#39;\r\n\r\n    &quot;Google&quot;\r\n\r\nusing `--raw-output` helps\r\n\r\n    echo $sample| jq --raw-output &#39;.name&#39;\r\n\r\n    Google\r\n\r\nBut I stumbled upon this question because I was using `--raw-output` on a json array like this \r\n\r\n    sample=&#39;[{&quot;name&quot;:&quot;Yahoo&quot;},{&quot;name&quot;:&quot;Google&quot;}]&#39;\r\n    echo $sample | jq --raw-output &#39;map(.name)&#39;\r\n\r\n    [\r\n      &quot;Yahoo&quot;,\r\n      &quot;Google&quot;\r\n    ]\r\n\r\nAnd I didn&#39;t understand why the quotes remained. I came across [this post][1], and now I know adding `| .[]` does the trick! \r\n\r\n    echo $sample | jq --raw-output &#39;map(.name)| .[]&#39;\r\n\r\n    Yahoo\r\n    Google\r\n\r\n\r\n\r\n  [1]: https://www.starkandwayne.com/blog/bash-for-loop-over-json-array-using-jq/",
                "title": "How to remove double-quotes in jq output for parsing json files in bash?"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1722213325,
                "last_edit_date": 1722213325,
                "creation_date": 1722213276,
                "answer_id": 78805101,
                "question_id": 44656515,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "For me, it&#39;s more logical to detect an array first and then select a needed key:\r\n\r\n    sample=&#39;[{&quot;name&quot;:&quot;Yahoo&quot;},{&quot;name&quot;:&quot;Google&quot;}]&#39;\r\n    echo $sample | jq -r &#39;.[] | .name&#39;\r\n\r\n    Yahoo\r\n    Google",
                "title": "How to remove double-quotes in jq output for parsing json files in bash?"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 779,
        "last_activity_date": 1722213325,
        "creation_date": 1497970519,
        "last_edit_date": 1540642996,
        "question_id": 44656515,
        "body_markdown": "I&#39;m using jq to parse a JSON file as shown [here][1]. However, the results for string values contain the &quot;double-quotes&quot; as expected, as shown below:\r\n\r\n&lt;!-- language-all: none --&gt;\r\n\r\n    $ cat json.txt | jq &#39;.name&#39;\r\n    &quot;Google&quot;\r\n\r\nHow can I pipe this into another command to remove the &quot;&quot;? so I get\r\n\r\n    $ cat json.txt | jq &#39;.name&#39; | some_other_command\r\n    Google\r\n\r\nWhat `some_other_command` can I use?\r\n\r\n  [1]: http://xmodulo.com/how-to-parse-json-string-via-command-line-on-linux.html#comment-13001",
        "link": "https://stackoverflow.com/questions/44656515/how-to-remove-double-quotes-in-jq-output-for-parsing-json-files-in-bash",
        "title": "How to remove double-quotes in jq output for parsing json files in bash?"
    },
    {
        "tags": [
            "json",
            "shell",
            "jenkins",
            "jq",
            "jenkins-api"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1497979729,
                "creation_date": 1497979729,
                "answer_id": 44659527,
                "question_id": 44659198,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "jq can only copy direct fields from one object to another in object literals. It wasn&#39;t programmed to go any deeper than that though it is most certainly possible in other languages that support this kind of feature.\r\n\r\nIf your goal is to minimize the repetition of the property names, you will just have to rewrite the filter a bit.\r\n\r\n    {result} + (.actions[2] | {failCount,skipCount,totalCount})",
                "title": "Use jq to grab specific key:value pair from nth object in a JSON array"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1497979731,
                "creation_date": 1497979731,
                "answer_id": 44659528,
                "question_id": 44659198,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The `{}` syntax is sugar. It&#39;s intended to be used as a shortcut when you need a simple expression, but there&#39;s no reason to use that same shortened syntax when what you actually want is more interesting.\r\n\r\n    jq &#39;\r\n      .actions[2] as $a2 |              # assign second action to a variable\r\n      { &quot;result&quot;: .result,              # refer direct to original input when appropriate...\r\n        &quot;skipCount&quot;: $a2.skipCount,     # ...or to that variable otherwise.\r\n        &quot;failCount&quot;: $a2.failCount,\r\n        &quot;totalCount&quot;: $a2.totalCount}\r\n    &#39; &lt;&lt;&lt;&quot;$json&quot;",
                "title": "Use jq to grab specific key:value pair from nth object in a JSON array"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1497987184,
                "creation_date": 1497987184,
                "answer_id": 44661592,
                "question_id": 44659198,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "&gt; My goal was to not have to re-specify the keys in case they changed in the api.\r\n\r\nIf that is one of the main goals, you might want to consider an approach exemplified by the following, which also makes no assumption about which element of `.actions` contains the information of interest:\r\n\r\n    { result } + (.actions[] | select(has(&quot;failCount&quot;)))\r\n\r\nWith your example data, this would produce:\r\n\r\n    {\r\n      &quot;result&quot;: &quot;UNSTABLE&quot;,\r\n      &quot;_class&quot;: &quot;hudson.tasks.junit.TestResultAction&quot;,\r\n      &quot;failCount&quot;: 1,\r\n      &quot;skipCount&quot;: 14,\r\n      &quot;totalCount&quot;: 222,\r\n      &quot;urlName&quot;: &quot;testReport&quot;\r\n    }\r\n\r\nIf you don&#39;t want some of the extra fields, you can delete them, e.g. if you definitely do not want &quot;_class&quot;, you can add `del(._class)` to the pipeline.\r\n\r\n",
                "title": "Use jq to grab specific key:value pair from nth object in a JSON array"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1497987184,
        "creation_date": 1497978508,
        "last_edit_date": 1497980270,
        "question_id": 44659198,
        "body_markdown": "Using this JSON taken from a Jenkins build api call via curl\r\n\r\n    {\r\n       &quot;_class&quot; : &quot;org.jenkinsci.plugins.workflow.job.WorkflowRun&quot;,\r\n       &quot;actions&quot; : [\r\n           {\r\n               &quot;_class&quot; : &quot;hudson.model.CauseAction&quot;,\r\n               &quot;causes&quot; : [\r\n                    {\r\n                        &quot;_class&quot; : &quot;jenkins.branch.BranchIndexingCause&quot;,\r\n                        &quot;shortDescription&quot; : &quot;Branch indexing&quot;\r\n                    }\r\n                ]\r\n            },\r\n            {\r\n                &quot;_class&quot; : &quot;hudson.model.ParametersAction&quot;,\r\n                &quot;parameters&quot; : [ &quot;...&quot; ]\r\n            },\r\n            {\r\n                &quot;_class&quot; : &quot;hudson.tasks.junit.TestResultAction&quot;,\r\n                &quot;failCount&quot; : 1,\r\n                &quot;skipCount&quot; : 14,\r\n                &quot;totalCount&quot; : 222,\r\n                &quot;urlName&quot; : &quot;testReport&quot;\r\n            }\r\n        ],\r\n        &quot;artifacts&quot; : [ &quot;...&quot;  ],\r\n        &quot;result&quot; : &quot;UNSTABLE&quot;,\r\n        &quot;previousBuild&quot; : {\r\n            &quot;number&quot; : 98,\r\n            &quot;url&quot; : &quot;&lt;some Url&gt;&quot;\r\n         }\r\n    }\r\n\r\nWhy can I do `jq &#39;{result}&#39; &lt;fileNameWithJSON&gt;` and get\r\n\r\n    { &quot;result&quot; : &quot;UNSTABLE&quot; }\r\n\r\nBut I cannot do `jq &#39;{.actions[2] failCount}&#39; &lt;fileNameWithJSON&gt;` or other variations such as \r\n\r\n - `jq &#39;{actions[2].failCount}&#39;`\r\n - `jq &#39;{actions[2] failCount}&#39;`\r\n - `jq &#39;{actions .[2].failCount}&#39;`\r\n -  etc.\r\n\r\n to get `{ &quot;failCount&quot; : &quot;1&quot; }` ?\r\n\r\nI want to grab the `result`, as well as `actions[2] failCount`, `actions[2] skipCount` and `actions[2] totalCount` to create a new JSON like this:\r\n\r\n    { &quot;result&quot; : &quot;UNSTABLE&quot;,&quot;failCount&quot; : 1, &quot;skipCount&quot; : 14,&quot;totalCount&quot; : 222}\r\n\r\n**EDIT:**\r\n\r\nMy goal was to not have to re-specify the keys in case they changed in the api. I essentially didn&#39;t want this: \r\n\r\n    {result, &quot;failCount&quot;:.actions[2].failCount, &quot;skipCount&quot;:.actions[2].skipCount, &quot;totalCount&quot;: .actions[2].totalCount}",
        "link": "https://stackoverflow.com/questions/44659198/use-jq-to-grab-specific-keyvalue-pair-from-nth-object-in-a-json-array",
        "title": "Use jq to grab specific key:value pair from nth object in a JSON array"
    },
    {
        "tags": [
            "json",
            "bash",
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2646339,
                    "reputation": 9135,
                    "user_id": 2288944,
                    "user_type": "registered",
                    "accept_rate": 56,
                    "profile_image": "https://i.sstatic.net/7qryD.jpg?s=256",
                    "display_name": "armnotstrong",
                    "link": "https://stackoverflow.com/users/2288944/armnotstrong"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1498099032,
                "post_id": 44689161,
                "comment_id": 76362138,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 7194903,
                    "reputation": 7556,
                    "user_id": 5719396,
                    "user_type": "registered",
                    "accept_rate": 75,
                    "profile_image": "https://www.gravatar.com/avatar/56768209ce48c44cb5fecbe54a387d68?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "iskandarblue",
                    "link": "https://stackoverflow.com/users/5719396/iskandarblue"
                },
                "reply_to_user": {
                    "account_id": 2646339,
                    "reputation": 9135,
                    "user_id": 2288944,
                    "user_type": "registered",
                    "accept_rate": 56,
                    "profile_image": "https://i.sstatic.net/7qryD.jpg?s=256",
                    "display_name": "armnotstrong",
                    "link": "https://stackoverflow.com/users/2288944/armnotstrong"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1498099120,
                "post_id": 44689161,
                "comment_id": 76362161,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": -2,
                "last_activity_date": 1498099787,
                "creation_date": 1498099787,
                "answer_id": 44689326,
                "question_id": 44689161,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "I have naver use the `jq` command\r\n\r\nBut you could do this very easily with a python script:\r\n\r\n\r\n    #!/usr/bin/env python\r\n    # -*- coding: utf-8 -*-\r\n    \r\n    # Author:    \r\n    # Maintainer: \r\n    import simplejson as json\r\n    \r\n    def test():\r\n        with open(&quot;test.json&quot;) as fp:\r\n            js1 = json.loads(fp.read())\r\n            with open(&quot;test2.json&quot;) as fp1:\r\n                js2 = json.loads(fp1.read())\r\n                js = js1 + js2\r\n                print(json.dumps(js, indent=4))\r\n    \r\n    \r\n    \r\n    if __name__ == &quot;__main__&quot;:\r\n        test()\r\n    \r\n    # vim:ai:et:sts=4:sw=4:\r\n\r\nNote the only thing you might have to do is install the `simplejson` package with \r\n\r\n`sudo pip install simplejson` \r\n\r\nsince it might not shipped with your distribution, good luck \r\n\r\n",
                "title": "Combining JSON files without extra brackets"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1498101199,
                "last_edit_date": 1498101199,
                "creation_date": 1498099815,
                "answer_id": 44689331,
                "question_id": 44689161,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The following invocation produces the desired result:\r\n\r\n    jq -s add input.json input.json\r\n\r\nIn brief, the -s (&quot;slurp&quot;) option places all the top-level input JSON entities into an array, producing an array of arrays in the present case.  `add` then &quot;adds&quot; the components of this array -- `add` being polymorphic  has the effect here of concatenating the component arrays. \r\n\r\nIf your jq has `inputs`, you could similarly write:\r\n\r\n    jq -n &#39;[inputs]|add&#39; input.json input.json\r\n\r\n    or:\r\n\r\n    jq -n &#39;[inputs[]]&#39; input.json input.json\r\n\r\nBy the way, there are other ways to pass the JSON in the files into jq.",
                "title": "Combining JSON files without extra brackets"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1498101199,
        "creation_date": 1498098668,
        "last_edit_date": 1498099807,
        "question_id": 44689161,
        "body_markdown": "I have two identical json files - `test.json` and `test2.json` in the exact format as below.  My goal is to combine them and keep the exact same format  - just basically stack one on top of the other without creating two lists.\r\n\r\nI am new to bash and jq but this code throws an error:\r\n\r\n    jq -s &#39;.[0] * .[1]&#39; test.json test2.json\r\n\r\n    jq: error (at test2.json:17): array ([{&quot;vendor&quot;:...) and array ([{&quot;vendor&quot;:...) cannot be multiplied\r\n\r\nWhy does this happen and how does one preserve the format without writing extra brackets `[]`.  How does one combine and keep only one pair of brackets around the entire file?  See below:\r\n\r\n`test.json`:\r\n\r\n    [\r\n      {\r\n        &quot;vendor&quot;: 0,\r\n        &quot;startTime&quot;: 4380,\r\n        &quot;endTime&quot;: 4445\r\n      },\r\n      {\r\n        &quot;vendor&quot;: 0,\r\n        &quot;startTime&quot;: 4448,\r\n        &quot;endTime&quot;: 4453\r\n      },\r\n      {\r\n        &quot;vendor&quot;: 0,\r\n        &quot;startTime&quot;: 4696,\r\n        &quot;endTime&quot;: 4880\r\n      }\r\n    ]\r\n\r\nundesired output:\r\n\r\n    [\r\n      [\r\n        {&quot;vendor&quot;:0,&quot;startTime&quot;:4380,&quot;endTime&quot;:4445},\r\n        {&quot;vendor&quot;:0,&quot;startTime&quot;:4448,&quot;endTime&quot;:4453},\r\n        {&quot;vendor&quot;:0,&quot;startTime&quot;:4696,&quot;endTime&quot;:4880}],\r\n    \r\n        [{&quot;vendor&quot;:0,&quot;startTime&quot;:4380,&quot;endTime&quot;:4445},\r\n          {&quot;vendor&quot;:0,&quot;startTime&quot;:4448,&quot;endTime&quot;:4453},\r\n          {&quot;vendor&quot;:0,&quot;startTime&quot;:4696,&quot;endTime&quot;:4880}\r\n      ]\r\n    ]\r\n\r\n\r\ndesired output:\r\n\r\n      [\r\n        {&quot;vendor&quot;:0,&quot;startTime&quot;:4380,&quot;endTime&quot;:4445},\r\n        {&quot;vendor&quot;:0,&quot;startTime&quot;:4448,&quot;endTime&quot;:4453},\r\n        {&quot;vendor&quot;:0,&quot;startTime&quot;:4696,&quot;endTime&quot;:4880},\r\n        {&quot;vendor&quot;:0,&quot;startTime&quot;:4380,&quot;endTime&quot;:4445},\r\n        {&quot;vendor&quot;:0,&quot;startTime&quot;:4448,&quot;endTime&quot;:4453},\r\n        {&quot;vendor&quot;:0,&quot;startTime&quot;:4696,&quot;endTime&quot;:4880}\r\n      ]\r\n\r\n",
        "link": "https://stackoverflow.com/questions/44689161/combining-json-files-without-extra-brackets",
        "title": "Combining JSON files without extra brackets"
    },
    {
        "tags": [
            "json",
            "jq",
            "whitelist"
        ],
        "comments": [
            {
                "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": 4,
                "creation_date": 1621231879,
                "post_id": 44704404,
                "comment_id": 119422840,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 22,
                "is_accepted": false,
                "score": 20,
                "last_activity_date": 1498148769,
                "creation_date": 1498148769,
                "answer_id": 44704837,
                "question_id": 44704404,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "IRC user gnomon answered this on the [jq channel][1] as follows:\r\n\r\n`jq &#39;select([.author] | inside([&quot;Larry&quot;, &quot;Garry&quot;, &quot;Jerry&quot;]))&#39;`\r\n\r\nThe intuition behind this approach, as stated by the user was: &quot;Literally your idea, only wrapping `.author` as `[.author]` to coerce it into being a single-item array so `inside()` will work on it.&quot; This answer produces the desired result of filtering for a series of names provided in a list as the original question desired.\r\n\r\n  [1]: http://irc.lc/freenode/%23jq/",
                "title": "Select entries based on multiple values in jq"
            },
            {
                "up_vote_count": 6,
                "is_accepted": false,
                "score": 6,
                "last_activity_date": 1498152955,
                "creation_date": 1498152955,
                "answer_id": 44706010,
                "question_id": 44704404,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You can use objects as if they&#39;re sets to test for membership. Methods operating on arrays will be inefficient, especially if the array may be huge.\r\n\r\nYou can build up a set of values prior to reading your input, then use the set to filter your inputs.\r\n\r\n    $ jq -n --argjson names &#39;[&quot;Larry&quot;,&quot;Garry&quot;,&quot;Jerry&quot;]&#39; &#39;\r\n    (reduce $names[] as $name ({}; .[$name] = true)) as $set\r\n        | inputs | select($set[.author])\r\n    &#39; blah.json\r\n\r\n",
                "title": "Select entries based on multiple values in jq"
            },
            {
                "up_vote_count": 29,
                "is_accepted": true,
                "score": 29,
                "last_activity_date": 1498231374,
                "last_edit_date": 1498231374,
                "creation_date": 1498158634,
                "answer_id": 44707560,
                "question_id": 44704404,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "`inside` and `contains` are a bit weird.  Here are some more straightforward solutions:\r\n\r\n### index/1\r\n    select( .author as $a | [&quot;Gary&quot;, &quot;Larry&quot;] | index($a) )\r\n\r\n### any/2\r\n\r\n    [&quot;Gary&quot;, &quot;Larry&quot;] as $whitelist\r\n    | select( .author as $a | any( $whitelist[]; . == $a) )\r\n\r\n\r\n### Using a dictionary\r\n\r\nIf performance is an issue and if &quot;author&quot; is always a string, then a solution along the lines suggested by @JeffMercado should be considered. Here is a variant (to be used with the -n command-line option):\r\n\r\n    [&quot;Gary&quot;, &quot;Larry&quot;] as $whitelist\r\n    | ($whitelist | map( {(.): true} ) | add) as $dictionary\r\n    | inputs\r\n    | select($dictionary[.author])\r\n\r\n\r\n\r\n",
                "title": "Select entries based on multiple values in jq"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 19,
        "last_activity_date": 1560800891,
        "creation_date": 1498147359,
        "last_edit_date": 1560800891,
        "question_id": 44704404,
        "body_markdown": "I&#39;m working with JQ and I absolutely love it so far. I&#39;m running into an issue I&#39;ve yet to find a solution to anywhere else, though, and wanted to see if the community had a way to do this.\r\n\r\nLet&#39;s presume we have a JSON file that looks like so: \r\n\r\n    {&quot;author&quot;: &quot;Gary&quot;, &quot;text&quot;: &quot;Blah&quot;}\r\n    {&quot;author&quot;: &quot;Larry&quot;, &quot;text&quot;: &quot;More Blah&quot;}\r\n    {&quot;author&quot;: &quot;Jerry&quot;, &quot;text&quot;: &quot;Yet more Blah&quot;}\r\n    {&quot;author&quot;: &quot;Barry&quot;, &quot;text&quot;: &quot;Even more Blah&quot;}\r\n    {&quot;author&quot;: &quot;Teri&quot;, &quot;text&quot;: &quot;Text on text on text&quot;}\r\n    {&quot;author&quot;: &quot;Bob&quot;, &quot;text&quot;: &quot;Another thing to say&quot;}\r\n\r\nNow, we want to select rows where the value of `author` is equal to either &quot;Gary&quot; OR &quot;Larry&quot;, but no other case. In reality, I have several thousand names I&#39;m checking against, so simply stating the direct or conditional (e.g. `cat blah.json | jq -r &#39;select(.author == &quot;Gary&quot; or .author == &quot;Larry&quot;)&#39;`) isn&#39;t sufficient. I&#39;m trying to do this via the `inside` function like so but get an error dialog:\r\n\r\n```\r\ncat blah.json | jq -r &#39;select(.author | inside([&quot;Gary&quot;, &quot;Larry&quot;]))&#39;\r\n```\r\n\r\n```\r\njq: error (at &lt;stdin&gt;:1): array ([&quot;Gary&quot;,&quot;La...) and string (&quot;Gary&quot;) cannot have their containment checked\r\n```\r\n\r\nWhat would be the best method for doing something like this?\r\n\r\n",
        "link": "https://stackoverflow.com/questions/44704404/select-entries-based-on-multiple-values-in-jq",
        "title": "Select entries based on multiple values in jq"
    },
    {
        "tags": [
            "json",
            "list",
            "merge",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1498323264,
                "last_edit_date": 1498323264,
                "creation_date": 1498321581,
                "answer_id": 44738513,
                "question_id": 44737620,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Depending on where you are trying to save this new file (local vs server), there are several different approaches.  As far as I know, there is no possible way to save a file locally without using one of the available plugins (https://stackoverflow.com/questions/32546100/how-to-write-data-to-a-json-file-using-javascript).  If you want to save it to a server, this is impossible with JavaScript, and best be done with a background language.\r\n\r\nHere is a way to combine the content of several JSON files into your desired format. \r\n\r\n    // send json files you want combined, and a new file path and name (path/to/filename.json)\r\n      function combineJsonFiles(files, newFileName) {\r\n        var combinedJson = [];\r\n        // iterate through each file \r\n        $.each(files, function(key, fileName) {\r\n          // load json file\r\n          // wait to combine until loaded. without this &#39;when().done()&#39;, boxes would return &#39;undefined&#39;\r\n          $.when(loadJsonFile(fileName)).done(function(boxes) {\r\n            // combine json from file with combinedJson array\r\n            combinedJson = combineJson(boxes, combinedJson);\r\n            // check if this is the last file\r\n            if (key == files.length-1) {\r\n              // puts into json format\r\n              combinedJson = JSON.stringify(combinedJson);\r\n              // your json is now ready to be saved to a file\r\n            }\r\n          });\r\n        });\r\n      }\r\n    \r\n      function loadJsonFile(fileName) {\r\n        return $.getJSON(fileName);\r\n      }\r\n    \r\n  \r\n\r\n    function combineJson(boxes, combinedJson) {\r\n      // iterate through each box \r\n      $.each(boxes, function(key, box) {\r\n        // use grep to search if this box&#39;s id is already included\r\n        var matches = $.grep(combinedJson, function(e) { return e.box_id == box.box_id; });\r\n        \r\n        // if there are no matches, add box to the combined file\r\n        if (matches.length == 0) {\r\n    \r\n          var newBox = { box_id: box.box_id };\r\n    \r\n          // iterate through properties of box\r\n          for (var property in box) {\r\n            // check to ensure that properties are not inherited from base class\r\n            if (box.hasOwnProperty(property)) {\r\n              // will ignore if property is box_id\r\n              if (property !== &#39;box_id&#39;) {\r\n                // box is reformatted to make the property type into array\r\n                newBox[property] = [box[property]];\r\n              }\r\n            }\r\n          }\r\n          combinedJson.push(newBox);\r\n        } else {\r\n          // select first match (there should never be more than one)\r\n          var match = matches[0];\r\n    \r\n          // iterate through properties of box\r\n          for (var property in box) {\r\n            // check to ensure that properties are not inherited from base class\r\n            if (box.hasOwnProperty(property)) {\r\n              // will ignore if property is box_id\r\n              if (property !== &#39;box_id&#39;) {\r\n                // add property to the already existing box in the combined file\r\n                match[property].push(box[property]);\r\n              }\r\n            }\r\n          }\r\n        }\r\n      });\r\n      return combinedJson;\r\n    }\r\n    \r\n      var jsonFiles = [&#39;path/to/data.json&#39;, &#39;path/to/data2.json&#39;, &#39;path/to/data3.json&#39;];\r\n    \r\n      combineJsonFiles(jsonFiles, &#39;combined_json.json&#39;);\r\n\r\nThe JSON output of this will look like:\r\n   \r\n    [{&quot;box_id&quot;:1,&quot;number_items&quot;:[4,7,5]},{&quot;box_id&quot;:3,&quot;number_items&quot;:[15,15,9]},{&quot;box_id&quot;:6,&quot;number_items&quot;:[2,4,0]}]\r\n\r\nHope this helps!\r\n",
                "title": "Merge JSON files with identical structure into JSON file containing lists"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1498487878,
                "last_edit_date": 1498487878,
                "creation_date": 1498324122,
                "answer_id": 44738915,
                "question_id": 44737620,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You can merge files with similar structures by simply passing them all in as input. Their contents will be streamed in in the order they are in.\r\n\r\nThen you could just read them in to a single array, group the objects by the `box_id` then map out the results.\r\n\r\n    $ jq -n &#39;\r\n        [inputs[]] | group_by(.box_id)\r\n            | map({box_id:.[0].box_id, number_items:map(.number_items)})\r\n    &#39; input{1,2,3}.json\r\n\r\nproduces:\r\n\r\n    [\r\n      {\r\n        &quot;box_id&quot;: 1,\r\n        &quot;number_items&quot;: [\r\n          4,\r\n          7,\r\n          5\r\n        ]\r\n      },\r\n      {\r\n        &quot;box_id&quot;: 3,\r\n        &quot;number_items&quot;: [\r\n          15,\r\n          15,\r\n          9\r\n        ]\r\n      },\r\n      {\r\n        &quot;box_id&quot;: 6,\r\n        &quot;number_items&quot;: [\r\n          4,\r\n          2,\r\n          0\r\n        ]\r\n      }\r\n    ]\r\n\r\nIt seems the order isn&#39;t preserved when items are grouped on some platforms. In my case, running on the Windows 64-bit version produces this. So be aware of that if you want to use `group_by`. There are of course other approaches you could take if you want to avoid using this filter, but this is much more convenient to use.",
                "title": "Merge JSON files with identical structure into JSON file containing lists"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1498443659,
                "last_edit_date": 1498443659,
                "creation_date": 1498332205,
                "answer_id": 44740146,
                "question_id": 44737620,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "&gt;  I would like to collect the values associated with certain keys \r\n\r\nHere is a solution which treats all keys, except for the grouping key, in the same way.  It also handles missing keys gracefully and does NOT depend on the stability of jq&#39;s `sort`.  The solution is based on a generic filter, `merge/0`, defined as follows:\r\n\r\n    # Combine an array of objects into a single object, ans, with array-valued keys,\r\n    # such that for every key, k, in the i-th object of the input array, a,\r\n    # ans[k][i] = a[i][k]\r\n    # null is used as padding if a value is missing.\r\n    # Example:\r\n    # [{a:1, b:2}, {b:3, c:4}] | merge\r\n    # produces:\r\n    # {&quot;a&quot;:[1,null],&quot;b&quot;:[2,3],&quot;c&quot;:[null,4]}\r\n    def merge:\r\n      def allkeys: map(keys) | add | unique;\r\n      allkeys as $allkeys\r\n      | reduce .[] as $in ({};\r\n         reduce $allkeys[] as $k (.;\r\n          . + {($k): (.[$k] + [$in[$k]]) } ));\r\n\r\nThe solution to the given problem can then be formulated as:\r\n\r\n    transpose | map(merge) | map( .box_id |= .[0] )\r\n\r\n\r\nInvocation: \r\n\r\n      jq -s -f merge.jq input{1,2,3}.json\r\n\r\nOutput: as shown in the question.\r\n\r\n### More robust solution\r\n\r\nThe above solution assumes uniformity of the ordering by `box_id` within each file.  This assumption seems warranted by the OP requirements, but for safety and robustness, the objects would first be sorted:\r\n\r\n    map(sort_by(.box_id)) | transpose | map( merge | (.box_id |= .[0]) )\r\n\r\nNote that this still assumes that there are no missing values of `box_id` in any of the input files.\r\n\r\n### Still more robust solution\r\n\r\nIf there is a possibility that some of the `box_id` values might be missing in any of the input files, then it would be appropriate to add the missing values.  This can be done with the help of the following filter:\r\n    \r\n    # Input: a matrix of objects (that is, an array of rows of objects),\r\n    #   each of which is assumed to have a distinguished field, f,\r\n    #   with distinct values on each row;\r\n    # Output: a rectangular matrix such that every row, r, of the output\r\n    #   matrix includes the elements of the corresponding row of the input\r\n    #   matrix, with additional elements as necessary so that (r |\r\n    #   map(.id) | sort) is the same for all rows r.\r\n    #\r\n    def rectanglize(f):\r\n      def ids: [.[][] | f] | unique;\r\n      def it: . as $in | {} | (f = $in);\r\n      ids as $ids\r\n      | map( . + ( $ids - [.[]|f] | map(it) ) )\r\n    ;  \r\n\r\nPutting everything together, the main pipeline becomes:\r\n\r\n    rectanglize(.id)\r\n    | map(sort_by(.box_id))\r\n    | transpose \r\n    | map( merge | .box_id |= .[0] )\r\n\r\n",
                "title": "Merge JSON files with identical structure into JSON file containing lists"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1498487878,
        "creation_date": 1498315779,
        "question_id": 44737620,
        "body_markdown": "I have some JSON files, all with identical structure (same keys everywhere, corresponding values might differ for some keys). I would like to collect the values associated with certain keys into lists and store those lists as the values associated with those keys in a new JSON file.\r\n\r\nAs example, consider these three files, where I&#39;m interested in the key `number_items` and the corresponding values. First file —\r\n\r\n    [\r\n      {\r\n        &quot;box_id&quot;: 1,\r\n        &quot;number_items&quot;: 4\r\n      },\r\n      {\r\n        &quot;box_id&quot;: 3,\r\n        &quot;number_items&quot;: 15\r\n      },\r\n      {\r\n        &quot;box_id&quot;: 6,\r\n        &quot;number_items&quot;: 2\r\n      }\r\n    ]\r\n\r\nSecond file —\r\n\r\n    [\r\n      {\r\n        &quot;box_id&quot;: 1,\r\n        &quot;number_items&quot;: 7\r\n      },\r\n      {\r\n        &quot;box_id&quot;: 3,\r\n        &quot;number_items&quot;: 15\r\n      },\r\n      {\r\n        &quot;box_id&quot;: 6,\r\n        &quot;number_items&quot;: 4\r\n      }\r\n    ]\r\n\r\nThird file —\r\n\r\n    [\r\n      {\r\n        &quot;box_id&quot;: 1,\r\n        &quot;number_items&quot;: 5\r\n      },\r\n      {\r\n        &quot;box_id&quot;: 3,\r\n        &quot;number_items&quot;: 9\r\n      },\r\n      {\r\n        &quot;box_id&quot;: 6,\r\n        &quot;number_items&quot;: 0\r\n      }\r\n    ]\r\n\r\nThese should be merged into something that looks like this —\r\n\r\n    [\r\n      {\r\n        &quot;box_id&quot;: 1,\r\n        &quot;number_items&quot;: [\r\n          4,\r\n          7,\r\n          5\r\n        ]\r\n      },\r\n      {\r\n        &quot;box_id&quot;: 3,\r\n        &quot;number_items&quot;: [\r\n          15,\r\n          15,\r\n          9\r\n        ]\r\n      },\r\n      {\r\n        &quot;box_id&quot;: 6,\r\n        &quot;number_items&quot;: [\r\n          2,\r\n          4,\r\n          0\r\n        ]\r\n      }\r\n    ]\r\n\r\nCan this be done using `jq`? If not, what would be a good way to do this? Note that the actual scenario consists of 150+ files with 3 keys whose values I would like to merge into lists.",
        "link": "https://stackoverflow.com/questions/44737620/merge-json-files-with-identical-structure-into-json-file-containing-lists",
        "title": "Merge JSON files with identical structure into JSON file containing lists"
    },
    {
        "tags": [
            "json",
            "csv",
            "nested",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": false,
                "score": 5,
                "last_activity_date": 1498444667,
                "last_edit_date": 1498444667,
                "creation_date": 1498407784,
                "answer_id": 44748291,
                "question_id": 44744381,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Some of the requirements are unclear, but the following solves one interpretation of the problem:\r\n\r\n    paths as $path\r\n    | {path: $path, value: getpath($path)}\r\n    | select(.value|type == &quot;object&quot; )\r\n    | select( [.value[]][0] | type != &quot;object&quot;)\r\n    | .path + ([.value[]])\r\n    | @csv\r\n\r\n(This program could be optimized but the presentation here is intended to make the separate steps clear.)\r\n\r\nInvocation:\r\n\r\n    jq -r -f leaves-to-csv.jq input.json\r\n\r\nOutput:\r\n\r\n    &quot;A&quot;,&quot;C&quot;,&quot;T1&quot;,1\r\n    &quot;A&quot;,&quot;F&quot;,&quot;T2&quot;,2\r\n    &quot;B&quot;,&quot;C&quot;,&quot;T3&quot;,3\r\n\r\n### Unquoted strings\r\n\r\nTo avoid the quotation marks around strings, you could replace the last component of the pipeline above with:\r\n\r\n    join(&quot;,&quot;)\r\n",
                "title": "How to convert nested JSON to CSV using only jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1502867190,
                "creation_date": 1502867190,
                "answer_id": 45707118,
                "question_id": 44744381,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a solution using **tostream** and **group_by**\r\n\r\n        [\r\n            tostream\r\n          | select(length == 2)            # e.g. [[&quot;A&quot;,&quot;C&quot;,&quot;D&quot;],&quot;T1&quot;]\r\n          | .[0][:-1] + [.[1]]             #      [&quot;A&quot;,&quot;C&quot;,&quot;T1&quot;]\r\n        ]\r\n        | group_by(.[:-1])                 #    [[[&quot;A&quot;,&quot;C&quot;,&quot;T1&quot;],[&quot;A&quot;,&quot;C&quot;,1]],...\r\n        | .[]                              #     [[&quot;A&quot;,&quot;C&quot;,&quot;T1&quot;],[&quot;A&quot;,&quot;C&quot;,1]]\r\n        | .[0][0:2] + map(.[-1]|tostring)  #      [&quot;A&quot;,&quot;C&quot;,&quot;T1&quot;,&quot;1&quot;]\r\n        | join(&quot;,&quot;)                        #       &quot;A,C,T1,1&quot;\r\n\r\n",
                "title": "How to convert nested JSON to CSV using only jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1502867190,
        "creation_date": 1498377229,
        "last_edit_date": 1498408029,
        "question_id": 44744381,
        "body_markdown": "I&#39;ve following json,\r\n\r\n    {\r\n    \t&quot;A&quot;: {\r\n    \t\t&quot;C&quot;: {\r\n    \t\t\t&quot;D&quot;: &quot;T1&quot;,\r\n    \t\t\t&quot;E&quot;: 1\r\n    \t\t},\r\n    \t\t&quot;F&quot;: {\r\n    \t\t\t&quot;D&quot;: &quot;T2&quot;,\r\n    \t\t\t&quot;E&quot;: 2\r\n    \t\t}\r\n    \t},\r\n    \t&quot;B&quot;: {\r\n    \t\t&quot;C&quot;: {\r\n    \t\t\t&quot;D&quot;: &quot;T3&quot;,\r\n    \t\t\t&quot;E&quot;: 3\r\n    \t\t}\r\n    \t}\r\n    }\r\n\r\nI want to convert it into csv as follows,\r\n\r\n    A,C,T1,1\r\n    A,F,T2,2\r\n    B,C,T3,3\r\n\r\nDescription of output: The parents keys will be printed until, I&#39;ve reached the leaf child. Once I reached leaf child, print its value.\r\n\r\nI&#39;ve tried following and couldn&#39;t succeed,\r\n&gt; cat my.json | jq -r &#39;(map(keys) | add | unique) as $cols | map(. as $row | $cols | map($row[.])) as $rows | $rows[] | @csv&#39;\r\n\r\nand it throwing me an error. \r\n\r\nI can&#39;t hardcode the parent keys, as the actual json has too many records. But the structure of the json is similar. What am I missing?",
        "link": "https://stackoverflow.com/questions/44744381/how-to-convert-nested-json-to-csv-using-only-jq",
        "title": "How to convert nested JSON to CSV using only jq"
    },
    {
        "tags": [
            "json",
            "merge",
            "key",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1498441515,
                "creation_date": 1498441515,
                "answer_id": 44752164,
                "question_id": 44752048,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here&#39;s a helper function to make the solution easy to understand. It converts the input array into an object, on the assumption that `headers` is an array of strings to be used as key names:\r\n\r\n    def objectify(headers):\r\n      [headers, .] | transpose | map( { (.[0]): .[1] } ) | add;\r\n\r\nA solution is now straightforward:\r\n \r\n    .datatable\r\n    | (.columns | map(.name)) as $headers\r\n    | .data\r\n    | map( objectify($headers) )\r\n\r\n",
                "title": "jq 1.5: Combining keys from one array with their values that are in a different array"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1498473381,
                "creation_date": 1498473381,
                "answer_id": 44757812,
                "question_id": 44752048,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "***Python*** solution:\r\n\r\n***combine_keys.py*** script:\r\n\r\n    import sys, json\r\n    \r\n    data = json.load(open(sys.argv[1], &#39;r&#39;))\r\n    columns = [o[&#39;name&#39;] for o in data[&#39;datatable&#39;][&#39;columns&#39;]]\r\n    result = json.dumps([dict(zip(columns, i)) for i in data[&#39;datatable&#39;][&#39;data&#39;]], indent=4)\r\n    print(result)\r\n*Usage*:\r\n\r\n    python combine_keys.py input.json\r\nThe output:\r\n\r\n    [\r\n        {\r\n            &quot;low&quot;: 38.0,\r\n            &quot;date&quot;: &quot;2012-05-18&quot;,\r\n            &quot;close&quot;: 38.2318,\r\n            &quot;high&quot;: 45.0\r\n        },\r\n        {\r\n            &quot;low&quot;: 33.0,\r\n            &quot;date&quot;: &quot;2012-05-21&quot;,\r\n            &quot;close&quot;: 34.03,\r\n            &quot;high&quot;: 36.66\r\n        },\r\n        {\r\n            &quot;low&quot;: 30.94,\r\n            &quot;date&quot;: &quot;2012-05-22&quot;,\r\n            &quot;close&quot;: 31.0,\r\n            &quot;high&quot;: 33.59\r\n        },\r\n        {\r\n            &quot;low&quot;: 152.91,\r\n            &quot;date&quot;: &quot;2017-06-22&quot;,\r\n            &quot;close&quot;: 153.4,\r\n            &quot;high&quot;: 154.55\r\n        },\r\n        {\r\n            &quot;low&quot;: 152.65,\r\n            &quot;date&quot;: &quot;2017-06-23&quot;,\r\n            &quot;close&quot;: 155.07,\r\n            &quot;high&quot;: 155.2\r\n        }\r\n    ]\r\n\r\n\r\n",
                "title": "jq 1.5: Combining keys from one array with their values that are in a different array"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1500479049,
        "creation_date": 1498440238,
        "last_edit_date": 1500479049,
        "question_id": 44752048,
        "body_markdown": "I&#39;d like to take some key values that are found in one array, and match them with their corresponding values in a different array. For reference I&#39;m using jq-1.5\r\n\r\nI&#39;ve got some data from the quandl api where I&#39;m pulling some stock data. For example, the following pulls down some json data. \r\n\r\n&gt; curl\r\n&gt; https://www.quandl.com/api/v3/datatables/WIKI/PRICES.json?ticker=FB&amp;qopts.columns=date,close,high,low&amp;api_key=myapikeyblahblah\r\n\r\nThe data is as follows, though I&#39;ve removed some of the redundant data;\r\n\r\n    {\r\n      &quot;datatable&quot;: {\r\n        &quot;data&quot;: [\r\n          [&quot;2012-05-18&quot;, 38.2318, 45.0, 38.0],\r\n          [&quot;2012-05-21&quot;, 34.03, 36.66, 33.0],\r\n          [&quot;2012-05-22&quot;, 31.0, 33.59, 30.94],\r\n          [&quot;2017-06-22&quot;, 153.4, 154.55, 152.91],\r\n          [&quot;2017-06-23&quot;, 155.07, 155.2, 152.65]\r\n        ],\r\n        &quot;columns&quot;: [{\r\n          &quot;name&quot;: &quot;date&quot;,\r\n          &quot;type&quot;: &quot;Date&quot;\r\n        }, {\r\n          &quot;name&quot;: &quot;close&quot;,\r\n          &quot;type&quot;: &quot;BigDecimal(34,12)&quot;\r\n        }, {\r\n          &quot;name&quot;: &quot;high&quot;,\r\n          &quot;type&quot;: &quot;BigDecimal(34,12)&quot;\r\n        }, {\r\n          &quot;name&quot;: &quot;low&quot;,\r\n          &quot;type&quot;: &quot;BigDecimal(34,12)&quot;\r\n        }]\r\n      },\r\n      &quot;meta&quot;: {\r\n        &quot;next_cursor_id&quot;: null\r\n      }\r\n    }\r\n\r\nI&#39;m looking to match the &quot;keys&quot; from the .datatable.columns[$index1].name with the &quot;values&quot; in .datatable.data[1] and so on with each iterating index value. I&#39;m looking to get an output like the following;\r\n\r\n    [\r\n      {\r\n        &quot;date&quot;: &quot;2012-05-18&quot;,\r\n        &quot;close&quot;: 38.2318,\r\n        &quot;high&quot;: 45.0,\r\n        &quot;low&quot;: 38.0\r\n      },\r\n      {\r\n        &quot;date&quot;: &quot;2012-05-21&quot;,\r\n        &quot;close&quot;: 34.03,\r\n        &quot;high&quot;: 36.66,\r\n        &quot;low&quot;: 33.0\r\n      },\r\n      {\r\n        &quot;date&quot;: &quot;2012-05-22&quot;,\r\n        &quot;close&quot;: 31.0,\r\n        &quot;high&quot;: 33.59,\r\n        &quot;low&quot;: 30.94\r\n      },\r\n      {\r\n        &quot;date&quot;: &quot;2017-06-22&quot;,\r\n        &quot;close&quot;: 153.4,\r\n        &quot;high&quot;: 154.55,\r\n        &quot;low&quot;: 152.91\r\n      },\r\n      {\r\n        &quot;date&quot;: &quot;2017-06-23&quot;,\r\n        &quot;close&quot;: 155.07,\r\n        &quot;high&quot;: 155.2,\r\n        &quot;low&quot;: 152.65\r\n      }\r\n    ]\r\n\r\nSo far i&#39;ve played around with the idea of counting up the index, but most of my solutions so far have been fairly verbose, and i&#39;m finding myself stepping out of jq to sed/awk etc for something that I imagine is easy in jq. ",
        "link": "https://stackoverflow.com/questions/44752048/jq-1-5-combining-keys-from-one-array-with-their-values-that-are-in-a-different",
        "title": "jq 1.5: Combining keys from one array with their values that are in a different array"
    },
    {
        "tags": [
            "json",
            "bash",
            "csv",
            "unix",
            "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": 3,
                "creation_date": 1498567926,
                "post_id": 44780761,
                "comment_id": 76542053,
                "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": 2,
                "creation_date": 1498568059,
                "post_id": 44780761,
                "comment_id": 76542170,
                "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": 1,
                "creation_date": 1498569295,
                "post_id": 44780761,
                "comment_id": 76543080,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 45,
                "is_accepted": true,
                "score": 43,
                "last_activity_date": 1542964124,
                "last_edit_date": 1542964124,
                "creation_date": 1498568873,
                "answer_id": 44781106,
                "question_id": 44780761,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The right tool for this job is [`jq`](https://stedolan.github.io/jq/manual/).\r\n\r\n    jq -Rsn &#39;\r\n      {&quot;occurrences&quot;:\r\n        [inputs\r\n         | . / &quot;\\n&quot;\r\n         | (.[] | select(length &gt; 0) | . / &quot;;&quot;) as $input\r\n         | {&quot;position&quot;: [$input[0], $input[1]], &quot;taxo&quot;: {&quot;espece&quot;: $input[2]}}]}\r\n    &#39; &lt;se.csv\r\n\r\nemits, given your input:\r\n\r\n    {\r\n      &quot;occurences&quot;: [\r\n        {\r\n          &quot;position&quot;: [\r\n            &quot;-21.3214077&quot;,\r\n            &quot;55.4851413&quot;\r\n          ],\r\n          &quot;taxo&quot;: {\r\n            &quot;espece&quot;: &quot;Ruizia cordata&quot;\r\n          }\r\n        },\r\n        {\r\n          &quot;position&quot;: [\r\n            &quot;-21.3213078&quot;,\r\n            &quot;55.4849803&quot;\r\n          ],\r\n          &quot;taxo&quot;: {\r\n            &quot;espece&quot;: &quot;Cossinia pinnata&quot;\r\n          }\r\n        }\r\n      ]\r\n    }\r\n\r\n---\r\n\r\nBy the way, a less-buggy version of your original script might look like:\r\n\r\n    #!/usr/bin/env bash\r\n\r\n    items=( )\r\n    while IFS=&#39;;&#39; read -r lat long pos _; do\r\n      printf -v item &#39;{ &quot;position&quot;: [%s, %s], &quot;taxo&quot;: {&quot;espece&quot;: &quot;%s&quot;}}&#39; &quot;$lat&quot; &quot;$long&quot; &quot;$pos&quot;\r\n      items+=( &quot;$item&quot; )\r\n    done &lt;se.csv\r\n    \r\n    IFS=&#39;,&#39;\r\n    printf &#39;{&quot;occurrences&quot;: [%s]}\\n&#39; &quot;${items[*]}&quot;\r\n\r\nNote:\r\n\r\n- There&#39;s absolutely no point using `cat` to pipe into a loop (and [good reasons not to](http://mywiki.wooledge.org/BashFAQ/024)); thus, we&#39;re using a redirection (`&lt;`) to open the file directly as the loop&#39;s stdin.\r\n- `read` can be passed a list of destination variables; there&#39;s thus no need to read into an array (or *first* to read into a string, and then to generate a heresting and to read from that into an array). The `_` at the end ensures that extra columns are discarded (by putting them into the dummy variable named `_`) rather than appended to `pos`.\r\n- `&quot;${array[*]}&quot;` generates a string by concatenating elements of `array` with the character in `IFS`; we can thus use this to ensure that commas are present in the output only when they&#39;re needed.\r\n- `printf` is used in preference to `echo`, as advised in the APPLICATION USAGE section of [the specification for `echo` itself](http://pubs.opengroup.org/onlinepubs/9699919799/utilities/echo.html).\r\n- This is still inherently buggy since it&#39;s generating JSON via string concatenation. Don&#39;t use it.",
                "title": "Converting CSV to JSON in bash"
            },
            {
                "up_vote_count": 6,
                "is_accepted": false,
                "score": 5,
                "last_activity_date": 1538007495,
                "last_edit_date": 1538007495,
                "creation_date": 1535639549,
                "answer_id": 52099599,
                "question_id": 44780761,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is an article on the subject: https://infiniteundo.com/post/99336704013/convert-csv-to-json-with-jq\r\n\r\nIt also uses JQ, but a bit different approach using `split()` and `map()`.\r\n\r\n    jq --slurp --raw-input \\\r\n       &#39;split(&quot;\\n&quot;) | .[1:] | map(split(&quot;;&quot;)) |\r\n          map({\r\n             &quot;position&quot;: [.[0], .[1]],\r\n             &quot;taxo&quot;: {\r\n                 &quot;espece&quot;: .[2]\r\n              }\r\n          })&#39; \\\r\n      input.csv &gt; output.json\r\n\r\nIt doesn&#39;t handle separator escaping, though.",
                "title": "Converting CSV to JSON in bash"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1540434267,
                "creation_date": 1540434267,
                "answer_id": 52980445,
                "question_id": 44780761,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Because the `jq` solution does not handle CSV escaping, column names at the first line, commented-out lines and other common CSV &quot;features&quot;, I have extended the [CSV Cruncher](https://github.com/OndraZizka/csv-cruncher) tool to allow reading CSV and writing it as JSON. It&#39;s not exactly &quot;Bash&quot;, but neither is `jq` :)\r\n\r\nIt&#39;s primarily a CSV-as-SQL processing app, so it&#39;s not completely trivial, but here is the trick:\r\n\r\n    ./crunch -in myfile.csv -out output.csv --json -sql &#39;SELECT * FROM myfile&#39;\r\n\r\nIt also allows output as *JSON object per line* or *proper JSON array*. See the documentation.\r\n\r\nIt&#39;s in beta quality, so all feedback or pull requests are welcome.",
                "title": "Converting CSV to JSON in bash"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1543028518,
                "creation_date": 1543028518,
                "answer_id": 53454807,
                "question_id": 44780761,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "In general, if your jq has the `inputs` built-in filter (available since jq 1.5), then it is better to use it rather than the -s command-line option.  \r\n\r\nHere in any case is a solution using `inputs`.  This solution is also variable-free.\r\n\r\n    {&quot;occurrences&quot;:\r\n      [inputs\r\n       | select(length &gt; 0)\r\n       | . / &quot;;&quot;\r\n       | {&quot;position&quot;: [.[0], .[1]], \r\n          &quot;taxo&quot;: {&quot;espece&quot;: .[2]}} ]}\r\n\r\n## SSV, CSV, and all that\r\nThe above of course assumes that the file has semicolon-separated fields in each line, and that there are none of the complications associated with CSV files.\r\n\r\nIf the input has fields that are strictly delimited by a single character, then jq should have no problems handling it.  Otherwise, it might be best to use a tool that can reliably convert to the TSV (tab-separated value) format, which jq can handle directly.  \r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n",
                "title": "Converting CSV to JSON in bash"
            },
            {
                "up_vote_count": 25,
                "is_accepted": false,
                "score": 25,
                "last_activity_date": 1566279203,
                "last_edit_date": 1566279203,
                "creation_date": 1559336135,
                "answer_id": 56401637,
                "question_id": 44780761,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The accepted answer uses `jq` to parse the input. This works but `jq` doesn&#39;t handle escapes i.e. input from a CSV produced from Excel or similar tools is quoted like this:\r\n\r\n```\r\nfoo,&quot;bar,baz&quot;,gaz\r\n```\r\n\r\nwill result in the incorrect output, as jq will see 4 fields, not 3.\r\n\r\nOne option is to use tab-separated values instead of comma (as long as your input data doesn&#39;t contain tabs!), along with the accepted answer.\r\n\r\nAnother option is to combine your tools, and use the best tool for each part: a CSV parser for reading the input and turning it into JSON, and `jq` for transforming the JSON into the target format.\r\n\r\nThe python-based [csvkit][1] will intelligently parse the CSV, and comes with a tool `csvjson` which will do a much better job of turning the CSV into JSON. This can then be piped through jq to convert the flat JSON output by csvkit into the target form.\r\n\r\nWith the data provided by the OP, for the desired output, this as as simple as:\r\n\r\n```\r\ncsvjson --no-header-row  |\r\n  jq &#39;.[] | {occurrences: [{ position: [.a, .b], taxo: {espece: .c}}]}&#39;\r\n```\r\n\r\nNote that csvjson automatically detects `;` as the delimiter, and without a header row in the input, assigns the json keys as `a`, `b`, and `c`.\r\n\r\nThe same also applies to writing *to* CSV files -- `csvkit` can read a JSON array or new-line delimited JSON, and intelligently output a CSV via `in2csv`.\r\n\r\n  [1]: https://csvkit.readthedocs.io/en/latest/\r\n",
                "title": "Converting CSV to JSON in bash"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1559378739,
                "creation_date": 1559378739,
                "answer_id": 56405170,
                "question_id": 44780761,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you want to go crazy, you can write a parser using jq. Here&#39;s my implementation which can be thought of as the inverse of the `@csv` filter. Throw this into your .jq file.\r\n\r\n    def do_if(pred; update):\r\n        if pred then update else . end;\r\n    def _parse_delimited($_delim; $_quot; $_nl; $_skip):\r\n        [($_delim, $_quot, $_nl, $_skip)|explode[]] as [$delim, $quot, $nl, $skip] |\r\n        [0,1,2,3,4,5] as [$s_start,$s_next_value,$s_read_value,$s_read_quoted,$s_escape,$s_final] |\r\n        def _append($arr; $value):\r\n            $arr + [$value];\r\n        def _do_start($c):\r\n            if $c == $nl then\r\n                [$s_start, null, null, _append(.[3]; [&quot;&quot;])]\r\n            elif $c == $delim then\r\n                [$s_next_value, null, [&quot;&quot;], .[3]]\r\n            elif $c == $quot then\r\n                [$s_read_quoted, [], [], .[3]]\r\n            else\r\n                [$s_read_value, [$c], [], .[3]]\r\n            end;\r\n        def _do_next_value($c):\r\n            if $c == $nl then\r\n                [$s_start, null, null, _append(.[3]; _append(.[2]; &quot;&quot;))]\r\n            elif $c == $delim then\r\n                [$s_next_value, null, _append(.[2]; &quot;&quot;), .[3]]\r\n            elif $c == $quot then\r\n                [$s_read_quoted, [], .[2], .[3]]\r\n            else\r\n                [$s_read_value, [$c], .[2], .[3]]\r\n            end;\r\n        def _do_read_value($c):\r\n            if $c == $nl then\r\n                [$s_start, null, null, _append(.[3]; _append(.[2]; .[1]|implode))]\r\n            elif $c == $delim then\r\n                [$s_next_value, null, _append(.[2]; .[1]|implode), .[3]]\r\n            else\r\n                [$s_read_value, _append(.[1]; $c), .[2], .[3]]\r\n            end;\r\n        def _do_read_quoted($c):\r\n            if $c == $quot then\r\n                [$s_escape, .[1], .[2], .[3]]\r\n            else\r\n                [$s_read_quoted, _append(.[1]; $c), .[2], .[3]]\r\n            end;\r\n        def _do_escape($c):\r\n            if $c == $nl then\r\n                [$s_start, null, null, _append(.[3]; _append(.[2]; .[1]|implode))]\r\n            elif $c == $delim then\r\n                [$s_next_value, null, _append(.[2]; .[1]|implode), .[3]]\r\n            else\r\n                [$s_read_quoted, _append(.[1]; $c), .[2], .[3]]\r\n            end;\r\n        def _do_final($c):\r\n            .;\r\n        def _do_finalize:\r\n            if .[0] == $s_start then\r\n                [$s_final, null, null, .[3]]\r\n            elif .[0] == $s_next_value then\r\n                [$s_final, null, null, _append(.[3]; [&quot;&quot;])]\r\n            elif .[0] == $s_read_value then\r\n                [$s_final, null, null, _append(.[3]; _append(.[2]; .[1]|implode))]\r\n            elif .[0] == $s_read_quoted then\r\n                [$s_final, null, null, _append(.[3]; _append(.[2]; .[1]|implode))]\r\n            elif .[0] == $s_escape then\r\n                [$s_final, null, null, _append(.[3]; _append(.[2]; .[1]|implode))]\r\n            else # .[0] == $s_final\r\n                .\r\n            end;\r\n        reduce explode[] as $c (\r\n            [$s_start,null,null,[]];\r\n            do_if($c != $skip;\r\n                if .[0] == $s_start then\r\n                    _do_start($c)\r\n                elif .[0] == $s_next_value then\r\n                    _do_next_value($c)\r\n                elif .[0] == $s_read_value then\r\n                    _do_read_value($c)\r\n                elif .[0] == $s_read_quoted then\r\n                    _do_read_quoted($c)\r\n                elif .[0] == $s_escape then\r\n                    _do_escape($c)\r\n                else # .[0] == $s_final\r\n                    _do_final($c)\r\n                end\r\n            )\r\n        )\r\n        | _do_finalize[3][];\r\n    def parse_delimited($delim; $quot; $nl; $skip):\r\n        _parse_delimited($delim; $quot; $nl; $skip);\r\n    def parse_delimited($delim; $quot; $nl):\r\n        parse_delimited($delim; $quot; $nl; &quot;\\r&quot;);\r\n    def parse_delimited($delim; $quot):\r\n        parse_delimited($delim; $quot; &quot;\\n&quot;);\r\n    def parse_delimited($delim):\r\n        parse_delimited($delim; &quot;\\&quot;&quot;);\r\n    def parse_csv:\r\n        parse_delimited(&quot;,&quot;);\r\n\r\nFor your data, you would want to change the delimiter to semicolons.\r\n\r\n    $ cat se.csv\r\n    -21.3214077;55.4851413;Ruizia cordata\r\n    -21.3213078;55.4849803;Cossinia pinnata\r\n    $ jq -R &#39;parse_delimited(&quot;;&quot;)&#39; se.csv\r\n    [\r\n      &quot;-21.3214077&quot;,\r\n      &quot;55.4851413&quot;,\r\n      &quot;Ruizia cordata&quot;\r\n    ]\r\n    [\r\n      &quot;-21.3213078&quot;,\r\n      &quot;55.4849803&quot;,\r\n      &quot;Cossinia pinnata&quot;\r\n    ]\r\n\r\nThis will work fine for most inputs to parse a line at a time, but if your data has literal newlines, you will want to read the entire file as a string.\r\n\r\n    $ cat input.csv\r\n    Year,Make,Model,Description,Price\r\n    1997,Ford,E350,&quot;ac, abs, moon&quot;,3000.00\r\n    1999,Chevy,&quot;Venture &quot;&quot;Extended Edition&quot;&quot;&quot;,&quot;&quot;,4900.00\r\n    1999,Chevy,&quot;Venture &quot;&quot;Extended Edition, Very Large&quot;&quot;&quot;,,5000.00\r\n    1996,Jeep,Grand Cherokee,&quot;MUST SELL!\r\n    air, moon roof, loaded&quot;,4799.00\r\n    $ jq -Rs &#39;parse_csv&#39; input.csv\r\n    [\r\n      &quot;Year&quot;,\r\n      &quot;Make&quot;,\r\n      &quot;Model&quot;,\r\n      &quot;Description&quot;,\r\n      &quot;Price&quot;\r\n    ]\r\n    [\r\n      &quot;1997&quot;,\r\n      &quot;Ford&quot;,\r\n      &quot;E350&quot;,\r\n      &quot;ac, abs, moon&quot;,\r\n      &quot;3000.00&quot;\r\n    ]\r\n    [\r\n      &quot;1999&quot;,\r\n      &quot;Chevy&quot;,\r\n      &quot;Venture \\&quot;Extended Edition\\&quot;&quot;,\r\n      &quot;&quot;,\r\n      &quot;4900.00&quot;\r\n    ]\r\n    [\r\n      &quot;1999&quot;,\r\n      &quot;Chevy&quot;,\r\n      &quot;Venture \\&quot;Extended Edition, Very Large\\&quot;&quot;,\r\n      &quot;&quot;,\r\n      &quot;5000.00&quot;\r\n    ]\r\n    [\r\n      &quot;1996&quot;,\r\n      &quot;Jeep&quot;,\r\n      &quot;Grand Cherokee&quot;,\r\n      &quot;MUST SELL!\\nair, moon roof, loaded&quot;,\r\n      &quot;4799.00&quot;\r\n    ]\r\n\r\n\r\n",
                "title": "Converting CSV to JSON in bash"
            },
            {
                "up_vote_count": 111,
                "is_accepted": false,
                "score": 110,
                "last_activity_date": 1635462753,
                "last_edit_date": 1635462753,
                "creation_date": 1606870647,
                "answer_id": 65100738,
                "question_id": 44780761,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a python one-liner/script that&#39;ll do the trick:\r\n\r\n```lang-sh\r\ncat my.csv | python -c &#39;import csv, json, sys; print(json.dumps([dict(r) for r in csv.DictReader(sys.stdin)]))&#39;\r\n```",
                "title": "Converting CSV to JSON in bash"
            },
            {
                "up_vote_count": 17,
                "is_accepted": false,
                "score": 17,
                "last_activity_date": 1608150117,
                "creation_date": 1608150117,
                "answer_id": 65330593,
                "question_id": 44780761,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "John Kerl&#39;s [Miller](https://github.com/johnkerl/miller) tool has this built-in:\r\n\r\n```\r\nmlr --c2j --jlistwrap cat INPUT.csv &gt; OUTPUT.json\r\n```\r\n",
                "title": "Converting CSV to JSON in bash"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1631129105,
                "last_edit_date": 1631129105,
                "creation_date": 1631099815,
                "answer_id": 69102032,
                "question_id": 44780761,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "A version of Jstaabs answer that avoids storing the whole dictionary structure in memory before printing, in case the CSV file is large.\r\n\r\n```python\r\nimport csv, json, sys\r\n\r\nfor r in csv.DictReader(sys.stdin):\r\n    print(dict(r))\r\n```\r\n\r\nNote this outputs JSON lines format and not exactly JSON.\r\n\r\nHere&#39;s a version which outputs a proper JSON array, at the expense of being longer.\r\n\r\n```python\r\nimport csv, json, sys\r\n\r\nsys.stdout.write(&#39;[&#39;)\r\n\r\nfirst = True\r\nfor r in csv.DictReader(sys.stdin):\r\n    if not first:\r\n        sys.stdout.write(&#39;,&#39;)\r\n    first = False\r\n    json.dump(dict(r), sys.stdout)\r\n\r\nsys.stdout.write(&#39;]&#39;)\r\n```",
                "title": "Converting CSV to JSON in bash"
            },
            {
                "up_vote_count": 6,
                "is_accepted": false,
                "score": 6,
                "last_activity_date": 1656495737,
                "creation_date": 1656495737,
                "answer_id": 72799186,
                "question_id": 44780761,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is the Ruby one-liner solution:\r\n```\r\nruby -r json -r csv -e &#39;puts CSV.parse(STDIN, headers:true).map(&amp;:to_h).to_json&#39; &lt; INPUT.csv \r\n```",
                "title": "Converting CSV to JSON in bash"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1662143151,
                "creation_date": 1662143151,
                "answer_id": 73586673,
                "question_id": 44780761,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "For anyone looking for a php one-liner solution:\r\n\r\n    php -r &#39;echo json_encode(array_map(&#39;&#39;str_getcsv&#39;&#39;, file(&#39;&#39;file.csv&#39;&#39;)));&#39;\r\n\r\nIf you need to specify a different delimiter:\r\n\r\n    php -r &#39;echo json_encode(array_map(fn($line) =&gt; str_getcsv($line, &#39;&#39;;&#39;&#39;), file(&#39;&#39;file.csv&#39;&#39;)));&#39;\r\n\r\nYou might also use some flags when using json_decode:\r\n\r\nhttps://www.php.net/manual/pt_BR/function.json-encode.php",
                "title": "Converting CSV to JSON in bash"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1662805152,
                "creation_date": 1662805152,
                "answer_id": 73671024,
                "question_id": 44780761,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is another way using [Miller][1] (mlr)\r\n\r\n    mlr --implicit-csv-header --icsv --fs &#39;;&#39; --ojson label position,taxo,espece example.csv\r\n\r\nwhich will produce the following\r\n\r\n```\r\n[\r\n{\r\n  &quot;position&quot;: -21.3214077,\r\n  &quot;taxo&quot;: 55.4851413,\r\n  &quot;espece&quot;: &quot;Ruizia cordata&quot;\r\n},\r\n{\r\n  &quot;position&quot;: -21.3213078,\r\n  &quot;taxo&quot;: 55.4849803,\r\n  &quot;espece&quot;: &quot;Cossinia pinnata&quot;\r\n}\r\n]\r\n```\r\n\r\nor if you use `--ojsonl` (JSON line) instead of plain JSON will generate the following\r\n\r\n```\r\n{&quot;position&quot;: -21.3214077, &quot;taxo&quot;: 55.4851413, &quot;espece&quot;: &quot;Ruizia cordata&quot;}\r\n{&quot;position&quot;: -21.3213078, &quot;taxo&quot;: 55.4849803, &quot;espece&quot;: &quot;Cossinia pinnata&quot;}\r\n```\r\n\r\n\r\n  [1]: https://miller.readthedocs.io/",
                "title": "Converting CSV to JSON in bash"
            }
        ],
        "is_answered": true,
        "answer_count": 12,
        "score": 75,
        "last_activity_date": 1662805152,
        "creation_date": 1498567819,
        "last_edit_date": 1504224006,
        "question_id": 44780761,
        "body_markdown": "Trying to convert a CSV file into a JSON \r\n\r\nHere is two sample lines : \r\n\r\n    -21.3214077;55.4851413;Ruizia cordata\r\n    -21.3213078;55.4849803;Cossinia pinnata\r\n\r\nI would like to get something like : \r\n\r\n    &quot;occurrences&quot;: [\r\n                     {\r\n    \t\t\t\t&quot;position&quot;: [-21.3214077, 55.4851413],\r\n    \t\t\t\t&quot;taxo&quot;: {\r\n    \t\t\t\t\t&quot;espece&quot;: &quot;Ruizia cordata&quot;\r\n                     },\r\n                     ...\r\n                 }]\r\n\r\nHere is my script : \r\n\r\n        echo &#39;&quot;occurences&quot;: [ &#39;\r\n    \r\n    cat se.csv | while read -r line\r\n      do\r\n          IFS=&#39;;&#39; read -r -a array &lt;&lt;&lt; $line;\r\n          echo -n -e &#39;{ &quot;position&quot;: [&#39; ${array[0]}\r\n          echo -n -e &#39;,&#39; ${array[1]} &#39;]&#39;\r\n          echo -e &#39;, &quot;taxo&quot;: {&quot;espece&quot;:&quot;&#39; ${array[2]} &#39;&quot;&#39;\r\n    done\r\n    echo &quot;]&quot;;\r\n\r\nI get really strange results : \r\n\r\n \r\n\r\n       &quot;occurences&quot;: [ \r\n     &quot;&quot;position&quot;: [ -21.3214077, 55.4851413 ], &quot;taxo&quot;: {&quot;espece&quot;:&quot; Ruizia cordata\r\n     &quot;&quot;position&quot;: [ -21.3213078, 55.4849803 ], &quot;taxo&quot;: {&quot;espece&quot;:&quot; Cossinia pinnata\r\n\r\nWhat is wrong with my code ? \r\n\r\n",
        "link": "https://stackoverflow.com/questions/44780761/converting-csv-to-json-in-bash",
        "title": "Converting CSV to JSON in bash"
    },
    {
        "tags": [
            "json",
            "list",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3842961,
                    "reputation": 93062,
                    "user_id": 3185459,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/u8EuP.jpg?s=256",
                    "display_name": "RomanPerekhrest",
                    "link": "https://stackoverflow.com/users/3185459/romanperekhrest"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1498581368,
                "post_id": 44783294,
                "comment_id": 76551869,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1498659187,
                "last_edit_date": 1498659187,
                "creation_date": 1498582727,
                "answer_id": 44785931,
                "question_id": 44783294,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "With a tiny bit of familiarity with jq, the first problem is trivial, so I won&#39;t say more than give a solution:\r\n\r\n    map( {box_id, max_items: (.number_items | max) } )\r\n\r\nThe requirements for the second problem are a bit unclear, but you can easily tweak the following to meet your needs.  First, a helper function,  `differences`:\r\n\r\n    # Input: an array\r\n    # Output: a non-empty stream of non-negative integers\r\n    def differences:\r\n      def abs: if . &lt; 0 then - . else . end;\r\n      map( select(. != null) )\r\n      | if length == 0 then 0\r\n        elif length == 1 then (.[0]|abs)\r\n        else range(1;length) as $i | ( .[$i] - .[$i - 1] ) | abs end;  \r\n\r\nYou could then use this like so:\r\n \r\n    map( {box_id, sumAD: ( [.number_items | differences] | add) } )\r\n\r\nHowever it would be better (from a memory usage standpoint) to take advantage of the fact that `differences` emits a stream:\r\n\r\n    def sigma(s): reduce s as $x (0; . + $x);\r\n    map( {box_id, sumAD: ( sigma(.number_items | differences) ) } )\r\n\r\n\r\n",
                "title": "Processing JSON files containing lists of integers using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1498659187,
        "creation_date": 1498574762,
        "question_id": 44783294,
        "body_markdown": "I&#39;m currently looking into using `jq` to process JSON files that contain lists of integers, such as the example below —\r\n\r\n    [\r\n      {\r\n        &quot;box_id&quot;: 1,\r\n        &quot;number_items&quot;: [\r\n          4,\r\n          6,\r\n          7,\r\n          5\r\n        ]\r\n      },\r\n      {\r\n        &quot;box_id&quot;: 3,\r\n        &quot;number_items&quot;: [\r\n          15,\r\n          null,\r\n          15,\r\n          9\r\n        ]\r\n      },\r\n      {\r\n        &quot;box_id&quot;: 6,\r\n        &quot;number_items&quot;: [\r\n          2,\r\n          4,\r\n          0,\r\n          1\r\n        ]\r\n      }\r\n    ]\r\n\r\nFirst, I&#39;m trying to get the maximum for each `box_id`. Just getting the maximum values is relatively straightforward with e.g. `jq &#39;.[].number_items | max`, which returns\r\n\r\n    7\r\n    15\r\n    4\r\n\r\nHowever, I would like to store this into a new JSON file, like so —\r\n\r\n    [\r\n      {\r\n        &quot;box_id&quot;: 1,\r\n        &quot;max_items&quot;: 7\r\n      },\r\n      {\r\n        &quot;box_id&quot;: 3,\r\n        &quot;max_items&quot;: 15\r\n      },\r\n      {\r\n        &quot;box_id&quot;: 6,\r\n        &quot;max_items&quot;: 4\r\n      }\r\n    ]\r\n\r\nThe other part is somewhat more involved — how to find the sum of absolute differences of consecutive entries in the lists for each `box_id`? As example, consider `[4,6,7,5]`, which corresponds to differences `[6-4=2, 7-6=1, 5-7=-2]` = `[2,1,-2]`. The sum of absolute values of that one is `2+1+2` = `5`. Note that the lists can contain `null` values. These entries should be removed, so that in the case of `[15,null,15,9]` we get `[15,15,9]` which corresponds to differences `[0,-6]` and to absolute sum `6`.",
        "link": "https://stackoverflow.com/questions/44783294/processing-json-files-containing-lists-of-integers-using-jq",
        "title": "Processing JSON files containing lists of integers using jq"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1498583467,
                "creation_date": 1498583467,
                "answer_id": 44786149,
                "question_id": 44785007,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Your jq filter as given (i.e. without quotation marks) looks fine, so let&#39;s assume you have successfully placed the text (hopefully formatted for readability :-) in a file, say format.jq\r\n\r\nThen you would run something like this:\r\n\r\n    jq -f format.jq dreamlines_cruises.json",
                "title": "JQ filter file input under windows"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1498583467,
        "creation_date": 1498579466,
        "question_id": 44785007,
        "body_markdown": "I actually use jq (1.5) with Windows 10 to Format different json files. I tried today to move the filters to a filter file to cut the length of my cmd commands.\r\nI copied the filter directly from the command with all Quotations but i received an Syntax error. I tried to remove the qotations or Change them to &#39; but i still receive the Syntax error:\r\n\r\n    jq: error: syntax error, unexpected IDENT, expecting $end (Windows cmd shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n[.cruises[] | { nid: .cruise_nid, shipcategory: .ship_category, ship: .ship_title, company: .company_title, includeflight: .includes_flight, nights, waypoints: .waypoint_cities, title: .route_title}] C:\\import\\dreamlines_cruises.json &gt; C:\\Import\\import_cruises.json  \r\n\r\n\r\nAny tips?\r\n\r\nRegards Timo",
        "link": "https://stackoverflow.com/questions/44785007/jq-filter-file-input-under-windows",
        "title": "JQ filter file input under windows"
    },
    {
        "tags": [
            "json",
            "bash",
            "environment-variables",
            "sh",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1498590042,
                "creation_date": 1498590042,
                "answer_id": 44787908,
                "question_id": 44785326,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "I would suggest you adopt a significantly less error-prone strategy. I am not sure about the wisdom of any of this, but the following achieves most of what you seem to be trying to do.  In any case, please note that `--argjson x v` expects `v` to be valid JSON: `{c:2}` is not valid JSON.\r\n\r\n    #!/bin/bash\r\n    \r\n    JQ=jq\r\n    \r\n    function jq_add {\r\n       $JQ --argjson q1 &quot;$1&quot;  --argjson q2 &quot;$2&quot;  &#39;.[$q1] += $q2&#39;\r\n    }\r\n    \r\n    \r\n    v=&#39;{&quot;a&quot;:{&quot;b&quot;:1}}&#39;\r\n    v=$(echo &quot;$v&quot; | jq_add &#39;&quot;a&quot;&#39; &#39;{&quot;c&quot;:2}&#39;)\r\n    echo &quot;$v&quot;\r\n\r\n",
                "title": "dynamic editing json strings using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1498594075,
        "creation_date": 1498580535,
        "last_edit_date": 1498594075,
        "question_id": 44785326,
        "body_markdown": "Can I make a json structure dynamically editable storing the json data back and forth in a shell string using the jq tool.\r\n\r\nfor example what I was trying was to add a field in a structure like in this working code:\r\n\r\n    echo &#39;{&quot;a&quot;:{&quot;b&quot;:1}}&#39; | jq -c &#39;.a |= .+ {c:2}&#39;\r\n    {&quot;a&quot;:{&quot;b&quot;:1,&quot;c&quot;:2}}\r\n\r\nBut using a shell fucntion like this:\r\n\r\n    jq_add () {\r\n     eval $1=\\&quot;$(eval echo \\$$1 | $JQ --argjson q1 &quot;$(printf &#39;\\&quot;%s\\&quot;&#39;     &quot;$2&quot;)&quot; --argjson q2 &quot;$(printf &#39;\\&quot;%s\\&quot;&#39; &quot;$3&quot;)&quot; &#39;.[$q1] |= .+ $q2&#39;)\\&quot;\r\n    }\r\n    \r\n    v=&#39;{&quot;a&quot;:{&quot;b&quot;:1}}&#39;\r\n    jq_add v &quot;a&quot; &quot;{c:2}&quot;\r\n    echo $v\r\n\r\nThe answer is: \r\n**jq: error (at &lt;stdin&gt;:1): object ({&quot;b&quot;:1}) and array ([&quot;{c:2}&quot;]) cannot be added**\r\n",
        "link": "https://stackoverflow.com/questions/44785326/dynamic-editing-json-strings-using-jq",
        "title": "dynamic editing json strings using jq"
    },
    {
        "tags": [
            "json",
            "object",
            "jq",
            "declarative"
        ],
        "answers": [
            {
                "up_vote_count": 6,
                "is_accepted": false,
                "score": 6,
                "last_activity_date": 1498591801,
                "last_edit_date": 1498591801,
                "creation_date": 1498585732,
                "answer_id": 44786762,
                "question_id": 44786396,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Fixed it using\r\n\r\n    $ docker-machine inspect default |\r\n      jq &#39;{ConfigVersion,\r\n           Driver: (.Driver|{MachineName, CPU, Memory}),\r\n           DriverName}&#39;\r\n    {\r\n      &quot;ConfigVersion&quot;: 3,\r\n      &quot;Driver&quot;: {\r\n        &quot;MachineName&quot;: &quot;default&quot;,\r\n        &quot;CPU&quot;: 2,\r\n        &quot;Memory&quot;: 5120\r\n      },\r\n      &quot;DriverName&quot;: &quot;virtualbox&quot;\r\n    }",
                "title": "Select multiple fields using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 4,
        "last_activity_date": 1498805572,
        "creation_date": 1498584423,
        "last_edit_date": 1498805572,
        "question_id": 44786396,
        "body_markdown": "I am trying to filter docker-machine&#39;s output using the following jq filter.\r\n\r\n    docker-machine inspect default | jq &#39;{ConfigVersion, .Driver.{MachineName, CPU, Memory}, DriverName}&#39;\r\n\r\nThe original json for the first command is here\r\n\r\n    {\r\n        &quot;ConfigVersion&quot;: 3,\r\n        &quot;Driver&quot;: {\r\n            &quot;IPAddress&quot;: &quot;192.168.99.100&quot;,\r\n            &quot;MachineName&quot;: &quot;default&quot;,\r\n            &quot;SSHUser&quot;: &quot;docker&quot;,\r\n            &quot;SSHPort&quot;: 52314,\r\n            &quot;SSHKeyPath&quot;: &quot;/Users/apatil/.docker/machine/machines/default/id_rsa&quot;,\r\n            &quot;StorePath&quot;: &quot;/Users/apatil/.docker/machine&quot;,\r\n            &quot;SwarmMaster&quot;: false,\r\n            &quot;SwarmHost&quot;: &quot;tcp://0.0.0.0:3376&quot;,\r\n            &quot;SwarmDiscovery&quot;: &quot;&quot;,\r\n            &quot;VBoxManager&quot;: {},\r\n            &quot;HostInterfaces&quot;: {},\r\n            &quot;CPU&quot;: 2,\r\n            &quot;Memory&quot;: 5120,\r\n            &quot;DiskSize&quot;: 20000,\r\n            &quot;NatNicType&quot;: &quot;82540EM&quot;,\r\n            &quot;Boot2DockerURL&quot;: &quot;&quot;,\r\n            &quot;Boot2DockerImportVM&quot;: &quot;&quot;,\r\n            &quot;HostDNSResolver&quot;: false,\r\n            &quot;HostOnlyCIDR&quot;: &quot;192.168.99.1/24&quot;,\r\n            &quot;HostOnlyNicType&quot;: &quot;82540EM&quot;,\r\n            &quot;HostOnlyPromiscMode&quot;: &quot;deny&quot;,\r\n            &quot;UIType&quot;: &quot;headless&quot;,\r\n            &quot;HostOnlyNoDHCP&quot;: false,\r\n            &quot;NoShare&quot;: false,\r\n            &quot;DNSProxy&quot;: true,\r\n            &quot;NoVTXCheck&quot;: false,\r\n            &quot;ShareFolder&quot;: &quot;&quot;\r\n        },\r\n        &quot;DriverName&quot;: &quot;virtualbox&quot;,\r\n        &quot;HostOptions&quot;: {\r\n            &quot;Driver&quot;: &quot;&quot;,\r\n            &quot;Memory&quot;: 0,\r\n            &quot;Disk&quot;: 0,\r\n            &quot;EngineOptions&quot;: {\r\n                &quot;ArbitraryFlags&quot;: [],\r\n                &quot;Dns&quot;: null,\r\n                &quot;GraphDir&quot;: &quot;&quot;,\r\n                &quot;Env&quot;: [],\r\n                &quot;Ipv6&quot;: false,\r\n                &quot;InsecureRegistry&quot;: [],\r\n                &quot;Labels&quot;: [],\r\n                &quot;LogLevel&quot;: &quot;&quot;,\r\n                &quot;StorageDriver&quot;: &quot;&quot;,\r\n                &quot;SelinuxEnabled&quot;: false,\r\n                &quot;TlsVerify&quot;: true,\r\n                &quot;RegistryMirror&quot;: [],\r\n                &quot;InstallURL&quot;: &quot;https://get.docker.com&quot;\r\n            },\r\n            &quot;SwarmOptions&quot;: {\r\n                &quot;IsSwarm&quot;: false,\r\n                &quot;Address&quot;: &quot;&quot;,\r\n                &quot;Discovery&quot;: &quot;&quot;,\r\n                &quot;Agent&quot;: false,\r\n                &quot;Master&quot;: false,\r\n                &quot;Host&quot;: &quot;tcp://0.0.0.0:3376&quot;,\r\n                &quot;Image&quot;: &quot;swarm:latest&quot;,\r\n                &quot;Strategy&quot;: &quot;spread&quot;,\r\n                &quot;Heartbeat&quot;: 0,\r\n                &quot;Overcommit&quot;: 0,\r\n                &quot;ArbitraryFlags&quot;: [],\r\n                &quot;ArbitraryJoinFlags&quot;: [],\r\n                &quot;Env&quot;: null,\r\n                &quot;IsExperimental&quot;: false\r\n            },\r\n            &quot;AuthOptions&quot;: {\r\n                &quot;CertDir&quot;: &quot;/Users/apatil/.docker/machine/certs&quot;,\r\n                &quot;CaCertPath&quot;: &quot;/Users/apatil/.docker/machine/certs/ca.pem&quot;,\r\n                &quot;CaPrivateKeyPath&quot;: &quot;/Users/apatil/.docker/machine/certs/ca-key.pem&quot;,\r\n                &quot;CaCertRemotePath&quot;: &quot;&quot;,\r\n                &quot;ServerCertPath&quot;: &quot;/Users/apatil/.docker/machine/machines/default/server.pem&quot;,\r\n                &quot;ServerKeyPath&quot;: &quot;/Users/apatil/.docker/machine/machines/default/server-key.pem&quot;,\r\n                &quot;ClientKeyPath&quot;: &quot;/Users/apatil/.docker/machine/certs/key.pem&quot;,\r\n                &quot;ServerCertRemotePath&quot;: &quot;&quot;,\r\n                &quot;ServerKeyRemotePath&quot;: &quot;&quot;,\r\n                &quot;ClientCertPath&quot;: &quot;/Users/apatil/.docker/machine/certs/cert.pem&quot;,\r\n                &quot;ServerCertSANs&quot;: [],\r\n                &quot;StorePath&quot;: &quot;/Users/apatil/.docker/machine/machines/default&quot;\r\n            }\r\n        },\r\n        &quot;Name&quot;: &quot;default&quot;\r\n    }\r\n\r\n\r\nI am getting the following error from jq for the command above\r\n\r\n    $ docker-machine inspect default | jq &#39;{ConfigVersion, .Driver.{MachineName, CPU, Memory}, DriverName}&#39;\r\n    jq: error: syntax error, unexpected FIELD (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n    {ConfigVersion, .Driver.{MachineName, CPU, Memory}, DriverName}\r\n    jq: error: syntax error, unexpected &#39;}&#39;, expecting $end (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n    {ConfigVersion, .Driver.{MachineName, CPU, Memory}, DriverName}\r\n    jq: 2 compile errors",
        "link": "https://stackoverflow.com/questions/44786396/select-multiple-fields-using-jq",
        "title": "Select multiple fields using jq"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 6,
                "is_accepted": false,
                "score": 5,
                "last_activity_date": 1498616050,
                "creation_date": 1498616050,
                "answer_id": 44792595,
                "question_id": 44792241,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You can initialize a variable to an empty object `{}` and add the key/values `{($key):$value}` for each iteration, re-injecting the result in the same variable  :\r\n\r\n\t#!/bin/bash\r\n\r\n\tdeclare -A dict=()\r\n\r\n\tdict[&quot;foo&quot;]=1\r\n\tdict[&quot;bar&quot;]=2\r\n\tdict[&quot;baz&quot;]=3\r\n\r\n\tdata=&#39;{}&#39;\r\n\r\n\tfor i in &quot;${!dict[@]}&quot;\r\n\tdo\r\n\t    data=$(jq -n --arg data &quot;$data&quot; \\\r\n\t                 --arg key &quot;$i&quot;     \\\r\n\t                 --arg value &quot;${dict[$i]}&quot; \\\r\n\t                 &#39;$data | fromjson + { ($key) : ($value | tonumber) }&#39;)\r\n\tdone\r\n\r\n\techo &quot;$data&quot;",
                "title": "Constructing a JSON object from a bash associative array"
            },
            {
                "up_vote_count": 23,
                "is_accepted": true,
                "score": 22,
                "last_activity_date": 1498709308,
                "last_edit_date": 1498709308,
                "creation_date": 1498617414,
                "answer_id": 44792751,
                "question_id": 44792241,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "There are many possibilities, but given that you already have written a bash `for` loop, you might like to begin with this variation of your script:\r\n\r\n    #!/bin/bash\r\n    # Requires bash with associative arrays\r\n    declare -A dict\r\n    \r\n    dict[&quot;foo&quot;]=1\r\n    dict[&quot;bar&quot;]=2\r\n    dict[&quot;baz&quot;]=3\r\n    \r\n    for i in &quot;${!dict[@]}&quot;\r\n    do\r\n        echo &quot;$i&quot; \r\n        echo &quot;${dict[$i]}&quot;\r\n    done |\r\n    jq -n -R &#39;reduce inputs as $i ({}; . + { ($i): (input|(tonumber? // .)) })&#39;\r\n\r\nThe result reflects the ordering of keys produced by the bash `for` loop:\r\n\r\n    {\r\n      &quot;bar&quot;: 2,\r\n      &quot;baz&quot;: 3,\r\n      &quot;foo&quot;: 1\r\n    }\r\n\r\nIn general, the approach based on feeding jq the key-value pairs, with one key on a line followed by the corresponding value on the next line, has much to recommend it. A generic solution following this general scheme, but using NUL as the &quot;line-end&quot; character, is given below.\r\n\r\n### Keys and Values as JSON Entities\r\n\r\nTo make the above more generic, it would be better to present the keys and values as JSON entities.  In the present case, we could write:\r\n\r\n    for i in &quot;${!dict[@]}&quot;\r\n    do\r\n        echo &quot;\\&quot;$i\\&quot;&quot;\r\n        echo &quot;${dict[$i]}&quot;\r\n    done | \r\n    jq -n &#39;reduce inputs as $i ({}; . + { ($i): input })&#39;\r\n\r\n### Other Variations\r\nJSON keys must be JSON strings, so it may take some work to ensure that the desired mapping from bash keys to JSON keys is implemented. Similar remarks apply to the mapping from bash array values to JSON values.  One way to handle arbitrary bash keys would be to let jq do the conversion: \r\n\r\n    printf &quot;%s&quot; &quot;$i&quot; | jq -Rs .\r\n\r\nYou could of course do the same thing with the bash array values, and let jq check whether the value can be converted to a number or to some other JSON type as desired (e.g. using `fromjson? // .`).\r\n\r\n### A Generic Solution\r\n\r\nHere is a generic solution along the lines mentioned in the jq FAQ and advocated by @CharlesDuffy. It uses NUL as the delimiter when passing the bash keys and values to jq, and has the advantage of only requiring one call to jq.  If desired, the filter `fromjson? // .` can be omitted or replaced by another one.\r\n\r\n    declare -A dict=( [$&#39;foo\\naha&#39;]=$&#39;a\\nb&#39; [bar]=2 [baz]=$&#39;{&quot;x&quot;:0}&#39; )\r\n    \r\n    for key in &quot;${!dict[@]}&quot;; do\r\n        printf &#39;%s\\0%s\\0&#39; &quot;$key&quot; &quot;${dict[$key]}&quot;\r\n    done |\r\n    jq -Rs &#39;\r\n      split(&quot;\\u0000&quot;)\r\n      | . as $a\r\n      | reduce range(0; length/2) as $i \r\n          ({}; . + {($a[2*$i]): ($a[2*$i + 1]|fromjson? // .)})&#39;\r\n\r\n\r\nOutput:\r\n\r\n    {\r\n      &quot;foo\\naha&quot;: &quot;a\\nb&quot;,\r\n      &quot;bar&quot;: 2,\r\n      &quot;baz&quot;: {\r\n        &quot;x&quot;: 0\r\n      }\r\n    }\r\n\r\n",
                "title": "Constructing a JSON object from a bash associative array"
            },
            {
                "up_vote_count": 5,
                "is_accepted": false,
                "score": 5,
                "last_activity_date": 1498860948,
                "last_edit_date": 1498860948,
                "creation_date": 1498622538,
                "answer_id": 44793442,
                "question_id": 44792241,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "This answer is from `nico103` on `freenode` `#jq`:\r\n\r\n    #!/bin/bash\r\n    \r\n    declare -A dict=()\r\n    \r\n    dict[&quot;foo&quot;]=1\r\n    dict[&quot;bar&quot;]=2\r\n    dict[&quot;baz&quot;]=3\r\n    \r\n    assoc2json() {\r\n        declare -n v=$1\r\n        printf &#39;%s\\0&#39; &quot;${!v[@]}&quot; &quot;${v[@]}&quot; |\r\n        jq -Rs &#39;split(&quot;\\u0000&quot;) | . as $v | (length / 2) as $n | reduce range($n) as $idx ({}; .[$v[$idx]]=$v[$idx+$n])&#39;\r\n    }\r\n    \r\n    assoc2json dict",
                "title": "Constructing a JSON object from a bash associative array"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1498682361,
                "creation_date": 1498682361,
                "answer_id": 44812157,
                "question_id": 44792241,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "This has been posted, and credited to nico103 on IRC, which is to say, me.\r\n\r\nThe thing that scares me, naturally, is that these associative array keys and values need quoting.  Here&#39;s a start that requires some additional work to dequote keys and values:\r\n\r\n    function assoc2json {\r\n        typeset -n v=$1\r\n        printf &#39;%q\\n&#39; &quot;${!v[@]}&quot; &quot;${v[@]}&quot; |\r\n            jq -Rcn &#39;[inputs] |\r\n                    . as $v |\r\n                    (length / 2) as $n |\r\n                    reduce range($n) as $idx ({}; .[$v[$idx]]=$v[$idx+$n])&#39;\r\n    }\r\n\r\n\r\n    $ assoc2json a\r\n    {&quot;foo\\\\ bar&quot;:&quot;1&quot;,&quot;b&quot;:&quot;bar\\\\ baz\\\\\\&quot;\\\\{\\\\}\\\\[\\\\]&quot;,&quot;c&quot;:&quot;$&#39;a\\\\nb&#39;&quot;,&quot;d&quot;:&quot;1&quot;}\r\n    $\r\n\r\nSo now all that&#39;s needed is a jq function that removes the quotes, which come in several flavors:\r\n\r\n - if the string starts with a single-quote (ksh) then it ends with a single quote and those need to be removed\r\n - if the string starts with a dollar sign and a single-quote and ends in a double-quote, then those need to be removed and internal backslash escapes need to be unescaped\r\n - else leave as-is\r\n\r\nI leave this last iterm as an exercise for the reader.\r\n\r\nI should note that I&#39;m using `printf` here as the iterator!\r\n",
                "title": "Constructing a JSON object from a bash associative array"
            },
            {
                "up_vote_count": 5,
                "is_accepted": false,
                "score": 5,
                "last_activity_date": 1677786832,
                "last_edit_date": 1677786832,
                "creation_date": 1664256164,
                "answer_id": 73862706,
                "question_id": 44792241,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "[bash 5.2](https://tiswww.case.edu/php/chet/bash/NEWS) introduces the `@k` [parameter transformation](https://www.gnu.org/savannah-checkouts/gnu/bash/manual/html_node/Shell-Parameter-Expansion.html &quot;scroll all the way down&quot;) which, makes this much easier. Like: \r\n```\r\n$ declare -A dict=([foo]=1 [bar]=2 [baz]=3)\r\n$ jq -n &#39;[$ARGS.positional | _nwise(2) | {(.[0]): .[1]}] | add&#39; --args &quot;${dict[@]@k}&quot;\r\n{\r\n  &quot;foo&quot;: &quot;1&quot;,\r\n  &quot;bar&quot;: &quot;2&quot;,\r\n  &quot;baz&quot;: &quot;3&quot;\r\n}\r\n```",
                "title": "Constructing a JSON object from a bash associative array"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1696436531,
                "last_edit_date": 1696436531,
                "creation_date": 1695998019,
                "answer_id": 77202804,
                "question_id": 44792241,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```\r\n$ declare -A d=([$&#39;foo\\naha&#39;]=$&#39;a\\nb&#39; [bar]=2 [baz]=$&#39;{&quot;x&quot;:0}&#39;)\r\n$ a2j=&#39;$ARGS.positional | [.[:$n], .[$n:]] | transpose | map({ (first): last }) | add&#39;\r\n$ jq -nc &quot;$a2j&quot; --argjson n ${#d[@]} --args &quot;${!d[@]}&quot; &quot;${d[@]}&quot;\r\n{&quot;bar&quot;:&quot;2&quot;,&quot;baz&quot;:&quot;{\\&quot;x\\&quot;:0}&quot;,&quot;foo\\naha&quot;:&quot;a\\nb&quot;}\r\n```\r\n\r\nThis combine arbitrary bash keys by [peak](https://stackoverflow.com/a/44792751/8344420), use of jq arg by\r\n[bertrand martel](https://stackoverflow.com/a/44792595/8344420), but use `${#d[@]}`, `${!d[@]}` and `${d[@]}` to get\r\nnumber of elements, keys and values in the array instead instead of\r\n`${d[@]@k}` by [oguz ismail](https://stackoverflow.com/a/73862706/8344420).\r\nThis allow a simple jq expression without `_nwise`.\r\n",
                "title": "Constructing a JSON object from a bash associative array"
            }
        ],
        "is_answered": true,
        "answer_count": 6,
        "score": 14,
        "last_activity_date": 1696436531,
        "creation_date": 1498612820,
        "last_edit_date": 1664256557,
        "question_id": 44792241,
        "body_markdown": "I would like to convert an associative array in bash to a JSON hash/dict. I would prefer to use JQ to do this as it is already a dependency and I can rely on it to produce well formed json. Could someone demonstrate how to achieve this?\r\n\r\n    #!/bin/bash\r\n    \r\n    declare -A dict=()\r\n    \r\n    dict[&quot;foo&quot;]=1\r\n    dict[&quot;bar&quot;]=2\r\n    dict[&quot;baz&quot;]=3\r\n    \r\n    for i in &quot;${!dict[@]}&quot;\r\n    do\r\n        echo &quot;key  : $i&quot;\r\n        echo &quot;value: ${dict[$i]}&quot;\r\n    done\r\n    \r\n    echo &#39;desired output using jq: { &quot;foo&quot;: 1, &quot;bar&quot;: 2, &quot;baz&quot;: 3 }&#39;\r\n",
        "link": "https://stackoverflow.com/questions/44792241/constructing-a-json-object-from-a-bash-associative-array",
        "title": "Constructing a JSON object from a bash associative array"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 5874110,
                    "reputation": 6084,
                    "user_id": 4625526,
                    "user_type": "registered",
                    "accept_rate": 50,
                    "profile_image": "https://www.gravatar.com/avatar/d30fbe656be0a90111b35cfb14a16df6?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Norbert",
                    "link": "https://stackoverflow.com/users/4625526/norbert"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1498682954,
                "post_id": 44812062,
                "comment_id": 76605171,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 1306358,
                    "reputation": 42647,
                    "user_id": 1255289,
                    "user_type": "registered",
                    "accept_rate": 89,
                    "profile_image": "https://www.gravatar.com/avatar/5ed02658b2440179f00eeff8beb7aa4c?s=256&d=identicon&r=PG",
                    "display_name": "miken32",
                    "link": "https://stackoverflow.com/users/1255289/miken32"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1498693527,
                "post_id": 44812062,
                "comment_id": 76608936,
                "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": 1498755090,
                "post_id": 44812062,
                "comment_id": 76642164,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 28,
                "is_accepted": true,
                "score": 27,
                "last_activity_date": 1664475230,
                "last_edit_date": 1664475230,
                "creation_date": 1498686988,
                "answer_id": 44813170,
                "question_id": 44812062,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Assuming the sequence of JSON objects is in a file named input.json, simply &quot;slurp&quot; it: \r\n\r\n    jq -s . input.json\r\n\r\nIf the objects are spread over multiple files, say `input*.json`, you can run: `jq -s . input*.json`.\r\n\r\n### Handling invalid JSON\r\n\r\nIf the &quot;objects&quot; are as originally shown (i.e., not strictly valid as JSON), then you could use a command-line tool such as `any-json`, `json5`, or `hjson` to convert them to JSON, one at a time.  If there is more than one quasi-JSON object per file, then you might be able to use `csplit` or `awk` to split up the file.\r\n\r\nAlternatively, if the objects follow the pattern established in the example, you could use GNU sed: `sed -z &#39;s/,\\(\\n}\\)/\\1/g&#39;`.",
                "title": "How concatenate multiple json objects with a delimiter comma using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 9,
        "last_activity_date": 1664475230,
        "creation_date": 1498682019,
        "last_edit_date": 1498742946,
        "question_id": 44812062,
        "body_markdown": "Here is my data:\r\n\r\n    {\r\n      &quot;ReferringUrl&quot;: &quot;N&quot;,\r\n      &quot;OpenAccess&quot;: &quot;0&quot;,\r\n      &quot;ItmId&quot;: &quot;1694738780&quot;\r\n    }\r\n    {\r\n      &quot;ReferringUrl&quot;: &quot;L&quot;,\r\n      &quot;OpenAccess&quot;: &quot;1&quot;,\r\n      &quot;ItmId&quot;: &quot;1347809133&quot;\r\n    }\r\n    \r\nI want it to be like this: \r\n\r\n    [\r\n     {\r\n      &quot;ReferringUrl&quot;: &quot;N&quot;,\r\n      &quot;OpenAccess&quot;: &quot;0&quot;,\r\n      &quot;ItmId&quot;: &quot;1694738780&quot;\r\n     },\r\n     {\r\n       &quot;ReferringUrl&quot;: &quot;L&quot;,\r\n       &quot;OpenAccess&quot;: &quot;1&quot;,\r\n       &quot;ItmId&quot;: &quot;1347809133&quot;\r\n     }\r\n    ]\r\n\r\nHow to make it by using jq library? I use bash. Thank you! :)",
        "link": "https://stackoverflow.com/questions/44812062/how-concatenate-multiple-json-objects-with-a-delimiter-comma-using-jq",
        "title": "How concatenate multiple json objects with a delimiter comma using jq"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq",
            "jsonlines"
        ],
        "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": 1498755004,
                "post_id": 44826701,
                "comment_id": 76642115,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 9,
                "is_accepted": true,
                "score": 9,
                "last_activity_date": 1498743561,
                "creation_date": 1498743561,
                "answer_id": 44826772,
                "question_id": 44826701,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Just use the [``--compact-output`` / ``-c``](https://stedolan.github.io/jq/manual/#Invokingjq) option:\r\n\r\n    cat file | jq -c\r\n\r\n(or, without feline abuse: ``jq -c &#39;.&#39; file``)",
                "title": "jq &#39;.&#39; formatted json file back to original json format using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1498806938,
        "creation_date": 1498743370,
        "last_edit_date": 1498806938,
        "question_id": 44826701,
        "body_markdown": "Here is my json: \r\n\r\n    [\r\n     {\r\n      &quot;ReferringUrl&quot;: &quot;N&quot;,\r\n      &quot;OpenAccess&quot;: &quot;0&quot;,\r\n      &quot;ItmId&quot;: &quot;1694738780&quot;\r\n     },\r\n     {\r\n      &quot;ReferringUrl&quot;: &quot;L&quot;,\r\n      &quot;OpenAccess&quot;: &quot;1&quot;,\r\n      &quot;ItmId&quot;: &quot;1347809133&quot;\r\n     }\r\n    ]\r\n\r\nI want it back to the original json format:\r\n\r\n    [{&quot;ReferringUrl&quot;: &quot;N&quot;,&quot;OpenAccess&quot;: &quot;0&quot;,&quot;ItmId&quot;: &quot;1694738780&quot;},{&quot;ReferringUrl&quot;: &quot;L&quot;,&quot;OpenAccess&quot;: &quot;1&quot;,&quot;ItmId&quot;: &quot;1347809133&quot;}]\r\n\r\nHow to use jq to do this? :) Thank you!",
        "link": "https://stackoverflow.com/questions/44826701/jq-formatted-json-file-back-to-original-json-format-using-jq",
        "title": "jq &#39;.&#39; formatted json file back to original json format using jq"
    },
    {
        "tags": [
            "json",
            "edit",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1498771019,
                "last_edit_date": 1498771019,
                "creation_date": 1498760857,
                "answer_id": 44832485,
                "question_id": 44831738,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "As the error message indicates, `{&quot;id&quot;=&quot;changed&quot;}` is wrong.  Perhaps you meant:\r\n\r\n    {&quot;id&quot;:&quot;changed&quot;}\r\n\r\nIf you are indeed simply trying to change `.id`, you could write:\r\n\r\n    if .id == &quot;clusterName&quot; then .id = &quot;changed&quot; else . end\r\n\r\nBtw, in future, it would be good if you followed the guidelines at http://stackoverflow.com/help/mcve \r\n\r\n### Answer to Revised Question\r\n\r\n    (.parameters[].id |= if . == &quot;clusterName&quot; then &quot;changed&quot; else . end)",
                "title": "Json update using Jq MAP"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1498805705,
        "creation_date": 1498758119,
        "last_edit_date": 1498805705,
        "question_id": 44831738,
        "body_markdown": "I am new to JQ and i figured this should get what i am looking for but it throws me error which unable to resolve.\r\n\r\n    cat aws_test_query_history_pipeline.json |  jq &#39;.parameters[] | map(if \r\n    .id == &quot;clusterName&quot;\r\n    then . + {&quot;id&quot;=&quot;changed&quot;}\r\n    else .\r\n    end\r\n    )&#39; &gt;&gt; test_krish.json\r\n    jq: error: syntax error, unexpected &#39;=&#39;, expecting &#39;}&#39; (Unix shell \r\n    quoting issues?) at &lt;top-level&gt;, line 2:\r\n    then . + {&quot;id&quot;=&quot;changed&quot;}              \r\n    jq: 1 compile error\r\n\r\n\r\nI know i am missing something silly please let me know what am i missing.\r\n\r\nUpdate to this question as i was missing some info on it.\r\n\r\nSorry about that. here is my sample \r\n\r\n     {\r\n    &quot;objects&quot;: [\r\n    {\r\n      &quot;connectionString&quot;: &quot;jdbc:mysql:\r\n      1.rds.amazonaws.com&quot;,\r\n      &quot;*password&quot;: &quot;&quot;,\r\n      &quot;name&quot;: &quot;Insights&quot;,\r\n      &quot;id&quot;: &quot;DataNodeId_XAL9t&quot;,\r\n      &quot;type&quot;: &quot;MySqlDataNode&quot;,\r\n      &quot;table&quot;: &quot;stas&quot;,\r\n      &quot;username&quot;: &quot;porta&quot;\r\n      },\r\n      {\r\n      &quot;dependsOn&quot;: { \r\n      .......\r\n     ]\r\n     &quot;parameters&quot;: [\r\n     {\r\n      &quot;id&quot;: &quot;clusterName&quot;,\r\n      &quot;description&quot;: &quot;Which region Cluster name to use&quot;,\r\n      &quot;type&quot;: &quot;String&quot;,\r\n      &quot;default&quot;: &quot;&quot;\r\n      },\r\n     {\r\n      &quot;id&quot;: &quot;password&quot;,\r\n      &quot;description&quot;: &quot;Password to use&quot;,\r\n      &quot;type&quot;: &quot;String&quot;,\r\n      &quot;default&quot;: &quot;&quot;\r\n     }\r\n     ]\r\n     } \r\nThe above is on a file.json when i run this command it just gets me parameter array changed as mentioned on the command but i would also need the remaining json file untouched\r\n \r\n    cat test.json | jq &#39;.parameters | if .id == &quot;clusterName&quot; then .id = \r\n    &quot;changed&quot; elif .id == &quot;password&quot; then .id = &quot;passchange&quot; else . end&#39; &gt; \r\n    test_krish.json  \r\n\r\nThe above command is just giving me \r\n\r\n     {\r\n    &quot;id&quot;: &quot;changed&quot;,\r\n    &quot;description&quot;: &quot;Which region Cluster name to use&quot;,\r\n    &quot;type&quot;: &quot;String&quot;,\r\n    &quot;default&quot;: &quot;&quot;\r\n    }\r\n    {\r\n    &quot;id&quot;: &quot;passchange&quot;,\r\n    &quot;description&quot;: &quot;Password to use&quot;,\r\n    &quot;type&quot;: &quot;String&quot;,\r\n    &quot;default&quot;: &quot;&quot;\r\n    }",
        "link": "https://stackoverflow.com/questions/44831738/json-update-using-jq-map",
        "title": "Json update using Jq MAP"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1498765815,
                "last_edit_date": 1498765815,
                "creation_date": 1498764268,
                "answer_id": 44833420,
                "question_id": 44832475,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The filter:\r\n\r\n    .[] | select( any(.Items[]; .Origin == &quot;Alert&quot;))\r\n\r\nproduces the first-mentioned admissible result.  If your jq does not have `any/2` then I&#39;d suggest upgrading.  If that&#39;s not an option, then you could use the following simple but rather inefficient filter instead:\r\n\r\n    .[] | select( .Items | map(.Origin) | index(&quot;Alert&quot;))\r\n\r\nOr:\r\n\r\n    .[] | select(reduce .Items[] as $item (false; . or ($item | .Origin == &quot;Alert&quot;)))\r\n",
                "title": "jq select objects that have specific value in nested json bash"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 5,
        "last_activity_date": 1498765815,
        "creation_date": 1498760819,
        "last_edit_date": 1498761460,
        "question_id": 44832475,
        "body_markdown": "this is my json.\r\n\r\n    [\r\n     {\r\n      &quot;time&quot;: &quot;2017-06-10 00:00:48-0400,317&quot;,\r\n      &quot;UserInfo&quot;: {\r\n        &quot;AppId&quot;: &quot;ONE_SEARCH&quot;,\r\n        &quot;UsageGroupId&quot;: &quot;92600&quot;,\r\n       },\r\n      &quot;Items&quot;: [\r\n        {\r\n         &quot;PublicationCode&quot;: &quot;&quot;,\r\n         &quot;OpenUrlRefId&quot;: &quot;&quot;,\r\n         &quot;ReferringUrl&quot;: &quot;N&quot;,\r\n         &quot;OpenAccess&quot;: &quot;0&quot;,\r\n         &quot;ItmId&quot;: &quot;1328515516&quot;\r\n        }\r\n       ]\r\n     },\r\n     {\r\n      &quot;time&quot;: &quot;2017-06-10 00:00:48-0400,548&quot;,\r\n      &quot;UserInfo&quot;: {\r\n        &quot;AppId&quot;: &quot;DIALOG&quot;,\r\n        &quot;UsageGroupId&quot;: &quot;1195735&quot;,\r\n      },\r\n      &quot;Items&quot;: [\r\n        {\r\n         &quot;Origin&quot;: &quot;Alert&quot;,\r\n         &quot;PublicationCode&quot;: &quot;&quot;,\r\n         &quot;NumberOfCopies&quot;: 1,\r\n         &quot;ItmId&quot;: &quot;1907446549&quot;\r\n        },\r\n        {\r\n         &quot;Origin&quot;: &quot;Alert&quot;,\r\n         &quot;PublicationCode&quot;: &quot;&quot;,\r\n         &quot;NumberOfCopies&quot;: 1,\r\n         &quot;ItmId&quot;: &quot;1907446950&quot;,\r\n        }\r\n      ]\r\n     }\r\n    ]\r\n\r\nI want use jq to extract the object that have &quot;Origin&quot;: &quot;Alert&quot; in its element &quot;Items&quot;. And the result should looks like this:\r\n\r\n    {\r\n     &quot;time&quot;: &quot;2017-06-10 00:00:48-0400,548&quot;,\r\n     &quot;UserInfo&quot;: {\r\n       &quot;AppId&quot;: &quot;DIALOG&quot;,\r\n       &quot;UsageGroupId&quot;: &quot;1195735&quot;,\r\n    },\r\n     &quot;Items&quot;: [\r\n       {\r\n        &quot;Origin&quot;: &quot;Alert&quot;,\r\n        &quot;PublicationCode&quot;: &quot;&quot;,\r\n        &quot;NumberOfCopies&quot;: 1,\r\n        &quot;ItmId&quot;: &quot;1907446549&quot;\r\n       },\r\n       {\r\n        &quot;Origin&quot;: &quot;Alert&quot;,\r\n        &quot;PublicationCode&quot;: &quot;&quot;,\r\n        &quot;NumberOfCopies&quot;: 1,\r\n        &quot;ItmId&quot;: &quot;1907446950&quot;,\r\n       }\r\n     ]\r\n    }\r\n\r\nOr this:\r\n\r\n    {\r\n     &quot;Items&quot;: [\r\n        {\r\n         &quot;Origin&quot;: &quot;Alert&quot;,\r\n         &quot;PublicationCode&quot;: &quot;&quot;,\r\n         &quot;NumberOfCopies&quot;: 1,\r\n         &quot;ItmId&quot;: &quot;1907446549&quot;,\r\n         &quot;ReasonCode&quot;: &quot;&quot;\r\n        },\r\n        {\r\n         &quot;Origin&quot;: &quot;Alert&quot;,\r\n         &quot;PublicationCode&quot;: &quot;&quot;,\r\n         &quot;NumberOfCopies&quot;: 1,\r\n         &quot;ItmId&quot;: &quot;1907446950&quot;,\r\n        }\r\n     ]\r\n    }\r\n\r\nHow to do it by using jq? I have tried several ways but most of them will just return an array with all children objects that include &quot;Origin&quot;:&quot;Alert&quot;. I need these children objects still keep there structure, because I need to know which of them happened together and which of them happened separately. \r\n\r\nBTW, the only value of &quot;Origin&quot; is &quot;Alert&quot;. So if you have any method to select an object with a given key name, it should also work.\r\n\r\nThank you! :) ",
        "link": "https://stackoverflow.com/questions/44832475/jq-select-objects-that-have-specific-value-in-nested-json-bash",
        "title": "jq select objects that have specific value in nested json bash"
    },
    {
        "tags": [
            "json",
            "object",
            "key",
            "jq",
            "flatten"
        ],
        "answers": [
            {
                "up_vote_count": 6,
                "is_accepted": true,
                "score": 6,
                "last_activity_date": 1498799739,
                "last_edit_date": 1498799739,
                "creation_date": 1498779752,
                "answer_id": 44836608,
                "question_id": 44836049,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The documentation, in my opinion, is excellent, but it helps to have some familiarity with `map` and some comfort level with pipes and filters.  Anyway, here&#39;s one map-oriented solution:\r\n\r\n    to_entries\r\n    | map( .key as $key\r\n           | .value\r\n           | to_entries\r\n           | map ( { ($key + &quot;-&quot; + .key): .value } ) | add ) | add\r\n\r\nHere&#39;s another, that works for arbitrarily-deeply nested JSON objects and arrays:\r\n\r\n    [paths(scalars) as $path | { ($path|join(&quot;-&quot;)): getpath($path) }] | add\r\n\r\nThere is of course a caveat here: if paths collide as a result of using &quot;-&quot; as the join character, some data may be lost.\r\n\r\n",
                "title": "How do I transform this nested object to a flattened object using jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 4,
        "last_activity_date": 1498799739,
        "creation_date": 1498776133,
        "last_edit_date": 1498799696,
        "question_id": 44836049,
        "body_markdown": "I need to transform this input into an unnested object using `jq`. In Python, I could transform it properly as follows.\r\n\r\n&lt;!-- language: lang-py --&gt;\r\n\r\n    output = {(k1 + &#39;-&#39; + k2): v2 for k1, v1 in input.iteritems() for k2, v2 in v1.iteritems()}\r\n\r\nBut I could not figure out how to do this in `jq`. The documentation for operating on nested objects is quite poor.\r\n\r\n&lt;!-- language: lang-json --&gt;\r\n\r\n    {\r\n        &quot;group1-permission&quot;: {\r\n            &quot;address&quot;: &quot;test1&quot;,\r\n            &quot;others&quot;: &quot;test2&quot;,\r\n            &quot;packet-capture&quot;: &quot;test3&quot;,\r\n            &quot;policy&quot;: &quot;test4&quot;,\r\n            &quot;schedule&quot;: &quot;test5&quot;,\r\n            &quot;service&quot;: &quot;test6&quot;\r\n        },\r\n        &quot;group2-permission&quot;: {\r\n            &quot;config&quot;: &quot;none&quot;,\r\n            &quot;data-access&quot;: &quot;none&quot;,\r\n            &quot;report-access&quot;: &quot;none&quot;,\r\n            &quot;threat-weight&quot;: &quot;none&quot;\r\n        },\r\n        &quot;group3-permission&quot;: {\r\n            &quot;antivirus&quot;: &quot;none&quot;,\r\n            &quot;application-control&quot;: &quot;none&quot;,\r\n            &quot;casi&quot;: &quot;none&quot;,\r\n            &quot;data-loss-prevention&quot;: &quot;none&quot;,\r\n            &quot;dnsfilter&quot;: &quot;none&quot;,\r\n            &quot;icap&quot;: &quot;none&quot;,\r\n            &quot;ips&quot;: &quot;none&quot;,\r\n            &quot;spamfilter&quot;: &quot;none&quot;,\r\n            &quot;voip&quot;: &quot;none&quot;,\r\n            &quot;waf&quot;: &quot;none&quot;,\r\n            &quot;webfilter&quot;: &quot;none&quot;\r\n        }\r\n    }\r\n\r\nThe output should look like this:\r\n\r\n&lt;!-- language: lang-json --&gt;\r\n\r\n    {\r\n        &quot;group1-permission-address&quot;: &quot;test1&quot;,\r\n        &quot;group1-permission-others&quot;: &quot;test2&quot;,\r\n        &quot;group1-permission-packet-capture&quot;: &quot;test3&quot;,\r\n        &quot;group1-permission-policy&quot;: &quot;test4&quot;,\r\n        &quot;group1-permission-schedule&quot;: &quot;test5&quot;,\r\n        &quot;group1-permission-service&quot;: &quot;test6&quot;,\r\n        &quot;group2-permission-config&quot;: &quot;none&quot;,\r\n        &quot;group2-permission-data-access&quot;: &quot;none&quot;,\r\n        &quot;group2-permission-report-access&quot;: &quot;none&quot;,\r\n        &quot;group2-permission-threat-weight&quot;: &quot;none&quot;,\r\n        &quot;group3-permission-antivirus&quot;: &quot;none&quot;,\r\n        &quot;group3-permission-application-control&quot;: &quot;none&quot;,\r\n        &quot;group3-permission-casi&quot;: &quot;none&quot;,\r\n        &quot;group3-permission-data-loss-prevention&quot;: &quot;none&quot;,\r\n        &quot;group3-permission-dnsfilter&quot;: &quot;none&quot;,\r\n        &quot;group3-permission-icap&quot;: &quot;none&quot;,\r\n        &quot;group3-permission-ips&quot;: &quot;none&quot;,\r\n        &quot;group3-permission-spamfilter&quot;: &quot;none&quot;,\r\n        &quot;group3-permission-voip&quot;: &quot;none&quot;,\r\n        &quot;group3-permission-waf&quot;: &quot;none&quot;,\r\n        &quot;group3-permission-webfilter&quot;: &quot;none&quot;\r\n    }",
        "link": "https://stackoverflow.com/questions/44836049/how-do-i-transform-this-nested-object-to-a-flattened-object-using-jq",
        "title": "How do I transform this nested object to a flattened object using jq?"
    },
    {
        "tags": [
            "json",
            "object",
            "merge",
            "edit",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1498798275,
                "creation_date": 1498798275,
                "answer_id": 44838795,
                "question_id": 44838619,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You could simply run:\r\n\r\n    jq --argfile aws aws.json &#39;.s3_blobstore_options += $aws&#39; model.json\r\n\r\nOr if the jq filter is in aws.jq:\r\n\r\n    jq --argfile aws aws.json -f aws.jq model.json\r\n\r\nThe idea here is that when applying `+` to JSON objects, the values in the RHS object take precedence.\r\n\r\nThere are other ways for the jq program to access the contents of aws.json ...\r\n",
                "title": "Update keypairs in one json file with another json using jq (at another level)"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1498799025,
        "creation_date": 1498797031,
        "last_edit_date": 1498799025,
        "question_id": 44838619,
        "body_markdown": "I have two files:\r\n\r\n    aws.json:\r\n    {\r\n      &quot;access_key_id&quot;: &quot;MYSECRETKEYID&quot;,\r\n      &quot;secret_access_key&quot;: &quot;mysecretaccesskey&quot;\r\n    }\r\n\r\n\r\n\r\n    model.json:\r\n    {\r\n        &quot;access_key_id&quot;: &quot;FREDSACCESSKEY&quot;,\r\n        &quot;secret_access_key&quot;: &quot;fredssecretaccesskey&quot;,\r\n        &quot;ntp_servers_string&quot;: &quot;1.2.3.4, 5.6.7.8&quot;,\r\n        &quot;metrics_ip&quot;: null,\r\n        &quot;pagerduty_enabled&quot;: false,\r\n        &quot;blobstore_type&quot;: &quot;s3&quot;,\r\n        &quot;s3_blobstore_options&quot;: {\r\n            &quot;endpoint&quot;: &quot;https://s3.amazonaws.com&quot;,\r\n            &quot;bucket_name&quot;: &quot;s3-mybucket&quot;,\r\n            &quot;access_key_id&quot;: &quot;vault-supplied-key&quot;,\r\n            &quot;secret_access_key&quot;: &quot;vault-supplied-key&quot;,\r\n            &quot;signature_version&quot;: &quot;4&quot;,\r\n            &quot;region&quot;: &quot;us-east-1&quot;\r\n        },\r\n        &quot;database_type&quot;: &quot;external&quot;\r\n    }\r\n\r\nand I would like to use jq to update a couple of values in the s3_blobstore_options key to the end result is this:\r\n\r\n    result.json:\r\n    \r\n    {\r\n        &quot;access_key_id&quot;: &quot;FREDSACCESSKEY&quot;,\r\n        &quot;secret_access_key&quot;: &quot;fredssecretaccesskey&quot;,\r\n        &quot;ntp_servers_string&quot;: &quot;1.2.3.4, 5.6.7.8&quot;,\r\n        &quot;metrics_ip&quot;: null,\r\n        &quot;pagerduty_enabled&quot;: false,\r\n        &quot;blobstore_type&quot;: &quot;s3&quot;,\r\n        &quot;s3_blobstore_options&quot;: {\r\n            &quot;endpoint&quot;: &quot;https://s3.amazonaws.com&quot;,\r\n            &quot;bucket_name&quot;: &quot;s3-mybucket&quot;,\r\n            &quot;access_key_id&quot;: &quot;MYSECRETKEYID&quot;,\r\n            &quot;secret_access_key&quot;: &quot;mysecretaccesskey&quot;,\r\n            &quot;signature_version&quot;: &quot;4&quot;,\r\n            &quot;region&quot;: &quot;us-east-1&quot;\r\n        },\r\n        &quot;database_type&quot;: &quot;external&quot;\r\n    }\r\n\r\nThe following code works perfectly, if the values are not nested:\r\n\r\n`jq --argfile override aws.json &#39;. + $override&#39; model.json &gt; result.json`\r\n\r\nAnyone know how to tell jq that I want to update the lower-level keys pairs, and not touch the upper level ones (i.e. `FREDSACCESSKEY`)?",
        "link": "https://stackoverflow.com/questions/44838619/update-keypairs-in-one-json-file-with-another-json-using-jq-at-another-level",
        "title": "Update keypairs in one json file with another json using jq (at another level)"
    },
    {
        "tags": [
            "json",
            "merge",
            "updates",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1498861106,
                "last_edit_date": 1498861106,
                "creation_date": 1498860096,
                "answer_id": 44855382,
                "question_id": 44855206,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "***jq*** solution:\r\n\r\n    jq --argfile bosh bosh.json &#39;with_entries( \r\n             if $bosh[.key] then .value = $bosh[.key] else . end)&#39; model.json\r\nThe output:\r\n\r\n    {\r\n      &quot;trusted_certificates&quot;: &quot;my-trusted-certs&quot;,\r\n      &quot;vm_password_type&quot;: &quot;generate&quot;\r\n    }\r\n\r\n\r\n----------\r\n\r\n- `if $bosh[.key] then .value = $bosh[.key] else . end` - update *model*&#39;s value only for matched keys\r\n",
                "title": "Update one JSON file values with values from another JSON using JQ"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1498862617,
                "last_edit_date": 1498862617,
                "creation_date": 1498860258,
                "answer_id": 44855405,
                "question_id": 44855206,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The requirements are not completely clear, but here&#39;s the solution to one interpretation.  This solution can easily be modified to match the other obvious interpretation.\r\n\r\nAssuming the file bosh.jq contains the following jq program:\r\n\r\n    reduce keys[] as $k (.; if $bosh|has($k) then .[$k] = $bosh[$k] else . end)\r\n\r\nthen the command:\r\n\r\n    jq --argfile bosh bosh.json -f bosh.jq model.json\r\n\r\nwill in effect emit the edited version of model.json.\r\n\r\n## Using with_entries\r\n\r\nIf you prefer a reduce-free approach, consider:\r\n\r\n    with_entries(.key as $k | if $bosh|has($k) then .value = $bosh[$k] else . end )\r\n\r\nNote that `if $bosh|has($k) ...` is NOT the same as `if $bosh[$k] ...`.",
                "title": "Update one JSON file values with values from another JSON using JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1499005836,
        "creation_date": 1498859029,
        "last_edit_date": 1499005836,
        "question_id": 44855206,
        "body_markdown": "So I have two JSON files:\r\n\r\n`bosh.json:`\r\n\r\n    {\r\n      &quot;key_pair_name&quot;: &quot;my-aws-keypair&quot;,\r\n      &quot;ssh_private_key&quot;: &quot;my-key-name&quot;,\r\n      &quot;trusted_certificates&quot;: &quot;my-trusted-certs&quot;\r\n    }\r\n\r\n`model.json:`\r\n\r\n    {\r\n      &quot;trusted_certificates&quot;: &quot;vault-supplied-value&quot;,\r\n      &quot;vm_password_type&quot;: &quot;generate&quot;\r\n    }\r\n\r\n\r\nand I want to update the model.json file with the bosh.json file so it looks like this:\r\n\r\n    {\r\n      &quot;trusted_certificates&quot;: &quot;my-trusted-certs&quot;,\r\n      &quot;vm_password_type&quot;: &quot;generate&quot;\r\n    }\r\n\r\nI tried this:\r\n\r\n    jq --argfile bosh bosh.json &#39;. += $bosh&#39; model.json\r\n\r\nbut I get too many keys\r\n\r\n    {\r\n      &quot;trusted_certificates&quot;: &quot;my-trusted-certs&quot;,\r\n      &quot;vm_password_type&quot;: &quot;generate&quot;,\r\n      &quot;key_pair_name&quot;: &quot;my-aws-keypair&quot;,\r\n      &quot;ssh_private_key&quot;: &quot;my-key-name&quot;\r\n    }\r\n\r\nand\r\n\r\n    jq --argfile bosh bosh.json &#39;. + $bosh&#39; model.json\r\n\r\n\r\nyeilds the same...\r\n\r\n    {\r\n      &quot;trusted_certificates&quot;: &quot;my-trusted-certs&quot;,\r\n      &quot;vm_password_type&quot;: &quot;generate&quot;,\r\n      &quot;key_pair_name&quot;: &quot;my-aws-keypair&quot;,\r\n      &quot;ssh_private_key&quot;: &quot;my-key-name&quot;\r\n    }\r\n\r\nwhile this\r\n\r\n    jq --argfile bosh bosh.json &#39;. = $bosh&#39; model.json\r\n\r\nyields the incorrect keys...\r\n\r\n    {\r\n      &quot;key_pair_name&quot;: &quot;my-aws-keypair&quot;,\r\n      &quot;ssh_private_key&quot;: &quot;my-key-name&quot;,\r\n      &quot;trusted_certificates&quot;: &quot;my-trusted-certs&quot;\r\n    }\r\n\r\nDoes anyone have any ideas how to get the expected results using jq?\r\nby the way, I cannot use the value of the key for the updates, as i will have unexpected results in other permutations...\r\n\r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/44855206/update-one-json-file-values-with-values-from-another-json-using-jq",
        "title": "Update one JSON file values with values from another JSON using JQ"
    },
    {
        "tags": [
            "json",
            "left-join",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3475378,
                    "reputation": 39744,
                    "user_id": 2908724,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/1xBJR.png?s=256",
                    "display_name": "bishop",
                    "link": "https://stackoverflow.com/users/2908724/bishop"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1498866604,
                "post_id": 44856098,
                "comment_id": 76692927,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 1936726,
                    "reputation": 637,
                    "user_id": 1744013,
                    "user_type": "registered",
                    "accept_rate": 75,
                    "profile_image": "https://www.gravatar.com/avatar/a5345af9ab1d18ab71b86c1c255e88c3?s=256&d=identicon&r=PG",
                    "display_name": "Ben Davis",
                    "link": "https://stackoverflow.com/users/1744013/ben-davis"
                },
                "reply_to_user": {
                    "account_id": 3475378,
                    "reputation": 39744,
                    "user_id": 2908724,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/1xBJR.png?s=256",
                    "display_name": "bishop",
                    "link": "https://stackoverflow.com/users/2908724/bishop"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1498866893,
                "post_id": 44856098,
                "comment_id": 76692992,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 3475378,
                    "reputation": 39744,
                    "user_id": 2908724,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/1xBJR.png?s=256",
                    "display_name": "bishop",
                    "link": "https://stackoverflow.com/users/2908724/bishop"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1498867181,
                "post_id": 44856098,
                "comment_id": 76693045,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1499230228,
                "last_edit_date": 1499230228,
                "creation_date": 1498882950,
                "answer_id": 44857297,
                "question_id": 44856098,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The following adopts an object-oriented approach to the task, and ignores keys other than &quot;rows&quot; and &quot;columns&quot; in the input.  \r\n\r\nThere are accordingly three steps:\r\n\r\n1. convert the tabular (columns/rows) representation of the &quot;database&quot; to an OO representation -- this is accomplished by `toOO`;\r\n2. perform the update -- accomplished by `left_join`;\r\n3. convert the OO representation back to the tabular form (`toDB`)\r\n\r\nThe main program is thus quite short: \r\n             \r\n    map(toOO) | left_join(.id) | toDB   \r\n\r\nThe helper functions, most of which are independently useful, are presented below but should appear before the main program above.\r\n\r\n### Helper Functions\r\n\r\n    # headers should be an array of strings\r\n    def objectify(headers):\r\n      . as $in\r\n      | reduce range(0; headers|length) as $i ({};\r\n          . + {(headers[$i]): $in[$i]} );\r\n    \r\n    def fromObject:\r\n      . as $in\r\n      | reduce keys_unsorted[] as $k ( {rows:[], columns:[]};\r\n         .columns += [$k] | .rows += [$in[$k]] );\r\n    \r\n    # Input: an array of object\r\n    # Output: a single object with array-valued keys formed from\r\n    # the input object by (blindly) concatenating the values\r\n    def merge:\r\n      def allkeys: map(keys) | add | unique;\r\n      allkeys as $allkeys\r\n      | reduce .[] as $in ({};\r\n         reduce $allkeys[] as $k (.;\r\n          . + {($k): (.[$k] + [$in[$k]]) } ));\r\n    \r\n    # id should be a filter such as .id\r\n    # Apply merge but do not replicate id\r\n    def merge_by(id):\r\n      merge | (id |= .[0] ) ;\r\n         \r\n    # Create an object-representation of the columns/rows database\r\n    def toOO:\r\n      .columns as $headers\r\n      | [.rows[] | objectify($headers)];\r\n    \r\n    def toDB:\r\n      map(fromObject)\r\n      | merge_by(.columns);\r\n\r\n    # Input: an array of two arrays, each consisting of objects forming a database.\r\n    # &quot;key&quot; specifies the (possibly composite) key to be used to form the\r\n    # left-join of the two databases. \r\n    # That is, objects are NOT added to the first database.\r\n    def left_join(key):\r\n      def updateObject(obj):\r\n        reduce .[] as $x ([];\r\n          if ($x|key) == (obj|key) \r\n          then . + [$x + obj] else . + [$x]\r\n          end);\r\n      reduce .[1][] as $x (.[0]; updateObject($x) );\r\n\r\n    \r\n\r\n### Output\r\n\r\n    {\r\n      &quot;columns&quot;: [\r\n        &quot;id&quot;,\r\n        &quot;name&quot;,\r\n        &quot;sex&quot;,\r\n        &quot;age&quot;\r\n      ],\r\n      &quot;rows&quot;: [\r\n        [\r\n          &quot;1&quot;,\r\n          &quot;Ben&quot;,\r\n          &quot;male&quot;,\r\n          &quot;25&quot;\r\n        ],\r\n        [\r\n          &quot;2&quot;,\r\n          &quot;Cathy&quot;,\r\n          &quot;female&quot;,\r\n          &quot;28&quot;\r\n        ]\r\n      ]\r\n    }\r\n\r\n### Using `JOIN` builtin\r\n\r\nIf your jq has `JOIN/4`, then it can be used to implement `left_join/1` as follows:\r\n\r\n    def left_join(key):\r\n      map(INDEX(key)) \r\n      | [ JOIN( .[1]; .[0][]; key; add) ] ;\r\n\r\nIn theory, this should be more efficient than the definition given above.    \r\n\r\n",
                "title": "Using SQL-style JOIN operator with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 4,
        "last_activity_date": 1499230228,
        "creation_date": 1498866518,
        "last_edit_date": 1498966825,
        "question_id": 44856098,
        "body_markdown": "I&#39;d like to use `jq` to do a left join on these two objects in an array by using the `jq` JOIN operator:\r\n\r\n    [\r\n      {\r\n        &quot;type&quot;: &quot;spreadsheet&quot;,\r\n        &quot;rows&quot;: [\r\n          [\r\n            &quot;1&quot;,\r\n            &quot;Ben&quot;,\r\n            &quot;male&quot;\r\n          ],\r\n          [\r\n            &quot;2&quot;,\r\n            &quot;Cathy&quot;,\r\n            &quot;female&quot;\r\n          ]\r\n        ],\r\n        &quot;columns&quot;: [\r\n          &quot;id&quot;,\r\n          &quot;name&quot;,\r\n          &quot;sex&quot;\r\n        ]\r\n      },\r\n      {\r\n        &quot;type&quot;: &quot;spreadsheet&quot;,\r\n        &quot;rows&quot;: [\r\n          [\r\n            &quot;1&quot;,\r\n            &quot;25&quot;\r\n          ],\r\n          [\r\n            &quot;2&quot;,\r\n            &quot;28&quot;\r\n          ]\r\n        ],\r\n        &quot;columns&quot;: [\r\n          &quot;id&quot;,\r\n          &quot;age&quot;\r\n        ]\r\n      }\r\n    ]\r\n\r\nto this:\r\n\r\n    {\r\n        &quot;type&quot;: &quot;spreadsheet&quot;,\r\n        &quot;rows&quot;: [\r\n          [\r\n            &quot;1&quot;,\r\n            &quot;Ben&quot;,\r\n            &quot;male&quot;,\r\n            &quot;25&quot;\r\n          ],\r\n          [\r\n            &quot;2&quot;,\r\n            &quot;Cathy&quot;,\r\n            &quot;female&quot;,\r\n            &quot;28&quot;\r\n          ]\r\n        ],\r\n        &quot;columns&quot;: [\r\n          &quot;id&quot;,\r\n          &quot;name&quot;,\r\n          &quot;sex&quot;,\r\n          &quot;age&quot;\r\n        ]\r\n    }\r\n\r\nThe [jq manual][1] references SQL-style operators like `INDEX` and `JOIN` but I can&#39;t find any examples online of how to use them. Like any join, I need to iterate over the rows in the first object and merge with rows found in the second object based on the `id` column.\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/#SQL-StyleOperators",
        "link": "https://stackoverflow.com/questions/44856098/using-sql-style-join-operator-with-jq",
        "title": "Using SQL-style JOIN operator with jq"
    },
    {
        "tags": [
            "arrays",
            "json",
            "jq",
            "blacklist"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1498871589,
                "creation_date": 1498871589,
                "answer_id": 44856535,
                "question_id": 44856484,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "From [jq manual][1] :\r\n\r\n&gt; As well as normal arithmetic subtraction on numbers, the - operator\r\n&gt; can be used on arrays to remove all occurrences of the second array’s\r\n&gt; elements from the first array.\r\n\r\nthis would do : \r\n\r\n    jq &#39;{ &quot;enabled_zones&quot;: (.zones - .disabled_zones) }&#39; data.json\r\n\r\n\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/",
                "title": "Deriving an array from other arrays with jq (cf. Python list comprehensions)"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1499068222,
        "creation_date": 1498870832,
        "last_edit_date": 1499068222,
        "question_id": 44856484,
        "body_markdown": "Given the following json containing two arrays:\r\n\r\n    {&quot;zones&quot;:[&quot;dev01&quot;,&quot;dev02&quot;,&quot;dev03&quot;,&quot;dev04&quot;,&quot;dev05&quot;,&quot;dev06&quot;,&quot;dev07&quot;,&quot;dev08&quot;,&quot;dev09&quot;,&quot;dev10&quot;,&quot;dev11&quot;,&quot;dev12&quot;,&quot;dev13&quot;,&quot;dev14&quot;,&quot;dev15&quot;,&quot;dev16&quot;,&quot;dev17&quot;,&quot;dev18&quot;,&quot;dev19&quot;,&quot;dev20&quot;],&quot;disabled_zones&quot;:[&quot;dev01&quot;,&quot;dev05&quot;,&quot;dev06&quot;,&quot;dev08&quot;,&quot;dev10&quot;,&quot;dev11&quot;,&quot;dev12&quot;,&quot;dev13&quot;,&quot;dev14&quot;,&quot;dev15&quot;,&quot;dev16&quot;,&quot;dev17&quot;,&quot;dev18&quot;,&quot;dev19&quot;,&quot;dev20&quot;]}\r\n\r\nI wish to derive a third array containing items that occur in the first array but not the second:\r\n\r\n    {&quot;enabled_zones&quot;:[&quot;dev02&quot;,&quot;dev03&quot;,&quot;dev04&quot;,&quot;dev07&quot;,&quot;dev09&quot;]}\r\n\r\nI would like to use `jq` for this task\r\n\r\nIn python I would use a list comprehension to achieve this:\r\n\r\n    &gt;&gt;&gt; zones = [&quot;dev01&quot;,&quot;dev02&quot;,&quot;dev03&quot;,&quot;dev04&quot;,&quot;dev05&quot;,&quot;dev06&quot;,&quot;dev07&quot;,&quot;dev08&quot;,&quot;dev09&quot;,&quot;dev10&quot;,&quot;dev11&quot;,&quot;dev12&quot;,&quot;dev13&quot;,&quot;dev14&quot;,&quot;dev15&quot;,&quot;dev16&quot;,&quot;dev17&quot;,&quot;dev18&quot;,&quot;dev19&quot;,&quot;dev20&quot;]\r\n    &gt;&gt;&gt; disabled_zones = [&quot;dev01&quot;,&quot;dev05&quot;,&quot;dev06&quot;,&quot;dev08&quot;,&quot;dev10&quot;,&quot;dev11&quot;,&quot;dev12&quot;,&quot;dev13&quot;,&quot;dev14&quot;,&quot;dev15&quot;,&quot;dev16&quot;,&quot;dev17&quot;,&quot;dev18&quot;,&quot;dev19&quot;,&quot;dev20&quot;]\r\n    &gt;&gt;&gt; enabled_zones = [x for x in zones if x not in disabled_zones]\r\n    &gt;&gt;&gt; print(enabled_zones)\r\n    [&#39;dev02&#39;, &#39;dev03&#39;, &#39;dev04&#39;, &#39;dev07&#39;, &#39;dev09&#39;]\r\n\r\nI am currently trying to loop over items in array1 using `foreach` and checking if they exist in array2 using `in` but I&#39;m struggling with the syntax.\r\n\r\nHow can I achieve this using `jq`? \r\n",
        "link": "https://stackoverflow.com/questions/44856484/deriving-an-array-from-other-arrays-with-jq-cf-python-list-comprehensions",
        "title": "Deriving an array from other arrays with jq (cf. Python list comprehensions)"
    },
    {
        "tags": [
            "arrays",
            "json",
            "bash",
            "parsing",
            "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": 1499045712,
                "post_id": 44876522,
                "comment_id": 76731804,
                "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": 1499046426,
                "post_id": 44876522,
                "comment_id": 76731916,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 7265194,
                    "reputation": 430,
                    "user_id": 5540205,
                    "user_type": "registered",
                    "accept_rate": 81,
                    "profile_image": "https://www.gravatar.com/avatar/e24980a9bd646d4f17d23324bfed60d6?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Nobody",
                    "link": "https://stackoverflow.com/users/5540205/nobody"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1499046671,
                "post_id": 44876522,
                "comment_id": 76731959,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1499045454,
                "creation_date": 1499045454,
                "answer_id": 44876654,
                "question_id": 44876522,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You can use `.[0]` to return the first array item : \r\n\r\n    echo &quot;$word&quot; | jq &#39;if type==&quot;array&quot; then .[0] else . end&#39;",
                "title": "Parsing json using jq depending upon the type"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1499045454,
        "creation_date": 1499043791,
        "last_edit_date": 1499044305,
        "question_id": 44876522,
        "body_markdown": "I want to parse a json depending upon it&#39;s type since it varies at times. If the json is a array I need to get the first element or if it&#39;s not I need just that element! Below is a simpler version of it which I tried to work on.\r\n\r\n    #!/bin/bash\r\n    \r\n    word=&#39;[0,1]&#39;\r\n    word=$(echo $word | jq &#39;if type==&quot;array&quot; then &quot;&#39;$word[0]&#39;&quot; else &quot;&#39;$word&#39;&quot; end&#39;)\r\n    echo $word\r\n\r\n\r\nIt outputs `&quot;[0,1][0]&quot;` where as I expected the passing condition to be assigned to the variable, which is just 0. Because in the below case it just printed &quot;yes&quot;. \r\n\r\n    #!/bin/bash\r\n    \r\n    word=&#39;[0,1]&#39;\r\n    word=$(echo $word | jq &#39;if type==&quot;array&quot; then &quot;yes&quot; else &quot;no&quot; end&#39;)\r\n    echo $word\r\n\r\nWhy is there a difference and how to achieve the former?",
        "link": "https://stackoverflow.com/questions/44876522/parsing-json-using-jq-depending-upon-the-type",
        "title": "Parsing json using jq depending upon the type"
    },
    {
        "tags": [
            "amazon-web-services",
            "aws-cli",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1499094918,
                "post_id": 44888773,
                "comment_id": 76756049,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 1887592,
                    "reputation": 6946,
                    "user_id": 1706504,
                    "user_type": "registered",
                    "accept_rate": 62,
                    "profile_image": "https://i.sstatic.net/CZUjl.jpg?s=256",
                    "display_name": "maafk",
                    "link": "https://stackoverflow.com/users/1706504/maafk"
                },
                "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": 1499095929,
                "post_id": 44888773,
                "comment_id": 76756648,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1499095535,
                "creation_date": 1499095535,
                "answer_id": 44889242,
                "question_id": 44888773,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You seem to be looking for a &quot;select&quot; query along the following lines:\r\n\r\n    .AutoScalingGroups[]\r\n    | select(.AutoScalingGroupName | test(&quot;group&quot;))\r\n    | .AutoScalingGroupARN\r\n\r\nGiven the example aws output at\r\nhttp://docs.aws.amazon.com/cli/latest/reference/autoscaling/describe-auto-scaling-groups.html\r\n\r\nthe above filter produces:\r\n\r\n    &quot;arn:aws:autoscaling:us-west-2:123456789012:autoScalingGroup:930d940e-891e-4781-a11a-7b0acd480f03:autoScalingGroupName/my-auto-scaling-group&quot;\r\n\r\n\r\nIf you want both the Name and ARN, then just grab them both, e.g.:\r\n\r\n    .AutoScalingGroups[]\r\n     | select(.AutoScalingGroupName | test(&quot;group&quot;))\r\n     | {AutoScalingGroupName, AutoScalingGroupARN}",
                "title": "aws cli and jq - return objects where attributes match patterns"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1499096360,
        "creation_date": 1499093989,
        "last_edit_date": 1499096360,
        "question_id": 44888773,
        "body_markdown": "I have more than 100 Auto Scaling Groups.\r\n\r\nI&#39;d like to be able to search my Auto Scaling groups based on a regex of the AutoScalingGroupName and return the AutoScalingGroupARN(s) (if exists).\r\n\r\nSo far I have:\r\n\r\n   \r\n    aws autoscaling describe-auto-scaling-groups | jq &#39;.AutoScalingGroups[].AutoScalingGroupName | capture(&quot;(?&lt;result&gt;my-regex-pattern)&quot;)&#39;\r\n\r\nWhile this does return the AutoScalingGroupNames, I&#39;d like to also return the AutoScalingGroupARN rather than do another command using the output from the previous command.\r\n\r\nSo given the following output from `aws autoscaling describe-auto-scaling-groups`:\r\n\r\n    {\r\n        &quot;AutoScalingGroups&quot;: [\r\n            {\r\n                &quot;AutoScalingGroupARN&quot;: &quot;arn:aws:autoscaling:us-east-1:123456789012:autoScalingGroup:208e9fe9-3a9b-4f30-9b47-855f4a7ee671:autoScalingGroupName/abc-app-dev-as-1IZQABPFDAV2A&quot;,\r\n                &quot;AutoScalingGroupName&quot;: &quot;abc-app-dev-as-1IZQABPFDAV2A&quot;,\r\n                &quot;...&quot;: &quot;more output&quot;\r\n            },\r\n            {\r\n                &quot;AutoScalingGroupARN&quot;: &quot;arn:aws:autoscaling:us-east-1:123456789012:autoScalingGroup:c6463f9a-7fa1-41de-a39b-7996d2b8cbb1:autoScalingGroupName/foo-app-dev-as-1IZQABPFDAV2A&quot;,\r\n                &quot;AutoScalingGroupName&quot;: &quot;foo-app-dev-as-1IZQABPFDAV2A&quot;,\r\n                &quot;...&quot;: &quot;more output&quot;\r\n            }\r\n            {\r\n                &quot;AutoScalingGroupARN&quot;: &quot;arn:aws:autoscaling:us-east-1:123456789012:autoScalingGroup:6a659b27-1ea7-4d39-8a8b-790153033b39:autoScalingGroupName/abc-app-prod-as-1IZQABPFDAV2A&quot;,\r\n                &quot;AutoScalingGroupName&quot;: &quot;abc-app-prod-as-1IZQABPFDAV2A&quot;,\r\n                &quot;...&quot;: &quot;more output&quot;\r\n            },\r\n            {\r\n                &quot;Lots more&quot;: &quot;Like the above&quot;\r\n            }\r\n        ]\r\n    }\r\n\r\nAnd am only interested in `AutoScalingGroupName` matching `/abc-app.+/`, I&#39;d want the output of:\r\n\r\n    {\r\n        &quot;results&quot;: [\r\n             {\r\n                &quot;AutoScalingGroupARN&quot;: &quot;arn:aws:autoscaling:us-east-1:123456789012:autoScalingGroup:208e9fe9-3a9b-4f30-9b47-855f4a7ee671:autoScalingGroupName/abc-app-dev-as-1IZQABPFDAV2A&quot;,\r\n                &quot;AutoScalingGroupName&quot;: &quot;abc-app-dev-as-1IZQABPFDAV2A&quot;\r\n            },\r\n            {\r\n                &quot;AutoScalingGroupARN&quot;: &quot;arn:aws:autoscaling:us-east-1:123456789012:autoScalingGroup:6a659b27-1ea7-4d39-8a8b-790153033b39:autoScalingGroupName/abc-app-prod-as-1IZQABPFDAV2A&quot;,\r\n                &quot;AutoScalingGroupName&quot;: &quot;abc-app-prod-as-1IZQABPFDAV2A&quot;\r\n            }\r\n        ]\r\n    }\r\n\r\nIs there a way to do this?",
        "link": "https://stackoverflow.com/questions/44888773/aws-cli-and-jq-return-objects-where-attributes-match-patterns",
        "title": "aws cli and jq - return objects where attributes match patterns"
    },
    {
        "tags": [
            "icalendar",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1499099171,
                "post_id": 44890243,
                "comment_id": 76758416,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1499151468,
                "creation_date": 1499151468,
                "answer_id": 44898967,
                "question_id": 44890243,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Use *update-assignment* operator `|=`:\r\n\r\n    jq &#39;.VCALENDAR[0].VEVENT |= map(select(.UID | contains(&quot;google.com&quot;)))&#39; base.json\r\nThe output:\r\n\r\n    {\r\n      &quot;VCALENDAR&quot;: [\r\n        {\r\n          &quot;PRODID&quot;: &quot;-//Google Inc//Google Calendar 70.9054//EN&quot;,\r\n          &quot;VERSION&quot;: &quot;2.0&quot;,\r\n          &quot;CALSCALE&quot;: &quot;GREGORIAN&quot;,\r\n          &quot;METHOD&quot;: &quot;PUBLISH&quot;,\r\n          &quot;X-WR-CALNAME&quot;: &quot;Events - TS Cinnaminson&quot;,\r\n          &quot;X-WR-TIMEZONE&quot;: &quot;America/New_York&quot;,\r\n          &quot;VTIMEZONE&quot;: [\r\n            {\r\n              &quot;TZID&quot;: &quot;America/New_York&quot;,\r\n              &quot;X-LIC-LOCATION&quot;: &quot;America/New_York&quot;,\r\n              &quot;DAYLIGHT&quot;: [\r\n                {\r\n                  &quot;TZOFFSETFROM&quot;: &quot;-0500&quot;,\r\n                  &quot;TZOFFSETTO&quot;: &quot;-0400&quot;,\r\n                  &quot;TZNAME&quot;: &quot;EDT&quot;,\r\n                  &quot;DTSTART&quot;: &quot;19700308T020000&quot;,\r\n                  &quot;RRULE&quot;: &quot;FREQ=YEARLY;BYMONTH=3;BYDAY=2SU&quot;\r\n                }\r\n              ],\r\n              &quot;STANDARD&quot;: [\r\n                {\r\n                  &quot;TZOFFSETFROM&quot;: &quot;-0400&quot;,\r\n                  &quot;TZOFFSETTO&quot;: &quot;-0500&quot;,\r\n                  &quot;TZNAME&quot;: &quot;EST&quot;,\r\n                  &quot;DTSTART&quot;: &quot;19701101T020000&quot;,\r\n                  &quot;RRULE&quot;: &quot;FREQ=YEARLY;BYMONTH=11;BYDAY=1SU&quot;\r\n                }\r\n              ]\r\n            }\r\n          ],\r\n          &quot;VEVENT&quot;: [\r\n            {\r\n              &quot;DTSTART&quot;: &quot;20170731T233000Z&quot;,\r\n              &quot;DTEND&quot;: &quot;20170801T003000Z&quot;,\r\n              &quot;DTSTAMP&quot;: &quot;20170626T155902Z&quot;,\r\n              &quot;UID&quot;: &quot;va6vhj4qba2rll8epdmccnjs@google.com&quot;,\r\n              &quot;CREATED&quot;: &quot;20170523T010707Z&quot;,\r\n              &quot;DESCRIPTION&quot;: &quot;&quot;,\r\n              &quot;LAST-MODIFIED&quot;: &quot;20170523T010707Z&quot;,\r\n              &quot;LOCATION&quot;: &quot;&quot;,\r\n              &quot;SEQUENCE&quot;: &quot;0&quot;,\r\n              &quot;STATUS&quot;: &quot;CONFIRMED&quot;,\r\n              &quot;SUMMARY&quot;: &quot;Service&quot;,\r\n              &quot;TRANSP&quot;: &quot;OPAQUE&quot;\r\n            }\r\n          ]\r\n        }\r\n      ]\r\n    }\r\n\r\n",
                "title": "&quot;Unmerging&quot; merged google calendar data with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1499151468,
        "creation_date": 1499099111,
        "last_edit_date": 1499102972,
        "question_id": 44890243,
        "body_markdown": "I have ical data containing a calendar owner&#39;s events (UID contains google.com) and events imported from hebcal.com (UID contains hebcal). I&#39;d like to use jq to to make two separate and complete ical files. ical2json converts the .ics to .json . So far I have managed to isolate the data with \r\n\r\n    cat basic.json | jq &#39;.VCALENDAR[].VEVENT[] | select(.UID | contains(&quot;google.com&quot;))&#39;\r\n\r\nHow do I recreate the original structure including just the google.com or hebal.com data?\r\n\r\nHere&#39;s sample json of the whole structure with two events, one from google, one from hebcal. So imagine producing the same structure, but with just google events.\r\n\r\n    {\r\n      &quot;VCALENDAR&quot;: [\r\n        {\r\n          &quot;PRODID&quot;: &quot;-//Google Inc//Google Calendar 70.9054//EN&quot;,\r\n          &quot;VERSION&quot;: &quot;2.0&quot;,\r\n          &quot;CALSCALE&quot;: &quot;GREGORIAN&quot;,\r\n          &quot;METHOD&quot;: &quot;PUBLISH&quot;,\r\n          &quot;X-WR-CALNAME&quot;: &quot;Events - TS Cinnaminson&quot;,\r\n          &quot;X-WR-TIMEZONE&quot;: &quot;America/New_York&quot;,\r\n          &quot;VTIMEZONE&quot;: [\r\n            {\r\n              &quot;TZID&quot;: &quot;America/New_York&quot;,\r\n              &quot;X-LIC-LOCATION&quot;: &quot;America/New_York&quot;,\r\n              &quot;DAYLIGHT&quot;: [\r\n                {\r\n                  &quot;TZOFFSETFROM&quot;: &quot;-0500&quot;,\r\n                  &quot;TZOFFSETTO&quot;: &quot;-0400&quot;,\r\n                  &quot;TZNAME&quot;: &quot;EDT&quot;,\r\n                  &quot;DTSTART&quot;: &quot;19700308T020000&quot;,\r\n                  &quot;RRULE&quot;: &quot;FREQ=YEARLY;BYMONTH=3;BYDAY=2SU&quot;\r\n                }\r\n              ],\r\n              &quot;STANDARD&quot;: [\r\n                {\r\n                  &quot;TZOFFSETFROM&quot;: &quot;-0400&quot;,\r\n                  &quot;TZOFFSETTO&quot;: &quot;-0500&quot;,\r\n                  &quot;TZNAME&quot;: &quot;EST&quot;,\r\n                  &quot;DTSTART&quot;: &quot;19701101T020000&quot;,\r\n                  &quot;RRULE&quot;: &quot;FREQ=YEARLY;BYMONTH=11;BYDAY=1SU&quot;\r\n                }\r\n              ]\r\n            }\r\n          ],\r\n          &quot;VEVENT&quot;: [\r\n            {\r\n              &quot;DTSTART;VALUE=DATE&quot;: &quot;20170930&quot;,\r\n              &quot;DTEND;VALUE=DATE&quot;: &quot;20171001&quot;,\r\n              &quot;DTSTAMP&quot;: &quot;20170626T155902Z&quot;,\r\n              &quot;UID&quot;: &quot;hebcal-20170930-6d1036bc2e3a7c743225174c4feb5d1f&quot;,\r\n              &quot;URL&quot;: &quot;http://hebcal.com/h/yom-kippur&quot;,\r\n              &quot;CLASS&quot;: &quot;PUBLIC&quot;,\r\n              &quot;CREATED&quot;: &quot;20170603T024831Z&quot;,\r\n              &quot;DESCRIPTION&quot;: &quot;Day of Atonement\\\\n\\\\nhttp://hebcal.com/h/yom-kippur&quot;,\r\n              &quot;LAST-MODIFIED&quot;: &quot;20170626T153742Z&quot;,\r\n              &quot;LOCATION&quot;: &quot;&quot;,\r\n              &quot;SEQUENCE&quot;: &quot;0&quot;,\r\n              &quot;STATUS&quot;: &quot;CONFIRMED&quot;,\r\n              &quot;SUMMARY&quot;: &quot;Yom Kippur&quot;,\r\n              &quot;TRANSP&quot;: &quot;OPAQUE&quot;,\r\n              &quot;X-MICROSOFT-CDO-BUSYSTATUS&quot;: &quot;OOF&quot;\r\n            },\r\n            {\r\n              &quot;DTSTART&quot;: &quot;20170731T233000Z&quot;,\r\n              &quot;DTEND&quot;: &quot;20170801T003000Z&quot;,\r\n              &quot;DTSTAMP&quot;: &quot;20170626T155902Z&quot;,\r\n              &quot;UID&quot;: &quot;va6vhj4qba2rll8epdmccnjs@google.com&quot;,\r\n              &quot;CREATED&quot;: &quot;20170523T010707Z&quot;,\r\n              &quot;DESCRIPTION&quot;: &quot;&quot;,\r\n              &quot;LAST-MODIFIED&quot;: &quot;20170523T010707Z&quot;,\r\n              &quot;LOCATION&quot;: &quot;&quot;,\r\n              &quot;SEQUENCE&quot;: &quot;0&quot;,\r\n              &quot;STATUS&quot;: &quot;CONFIRMED&quot;,\r\n              &quot;SUMMARY&quot;: &quot;Service&quot;,\r\n              &quot;TRANSP&quot;: &quot;OPAQUE&quot;\r\n            }\r\n          ]\r\n        }\r\n      ]\r\n    }\r\n\r\n\r\nDesired output is:\r\n\r\n    {\r\n      &quot;VCALENDAR&quot;: [\r\n        {\r\n          &quot;PRODID&quot;: &quot;-//Google Inc//Google Calendar 70.9054//EN&quot;,\r\n          &quot;VERSION&quot;: &quot;2.0&quot;,\r\n          &quot;CALSCALE&quot;: &quot;GREGORIAN&quot;,\r\n          &quot;METHOD&quot;: &quot;PUBLISH&quot;,\r\n          &quot;X-WR-CALNAME&quot;: &quot;Events - TS Cinnaminson&quot;,\r\n          &quot;X-WR-TIMEZONE&quot;: &quot;America/New_York&quot;,\r\n          &quot;VTIMEZONE&quot;: [\r\n            {\r\n              &quot;TZID&quot;: &quot;America/New_York&quot;,\r\n              &quot;X-LIC-LOCATION&quot;: &quot;America/New_York&quot;,\r\n              &quot;DAYLIGHT&quot;: [\r\n                {\r\n                  &quot;TZOFFSETFROM&quot;: &quot;-0500&quot;,\r\n                  &quot;TZOFFSETTO&quot;: &quot;-0400&quot;,\r\n                  &quot;TZNAME&quot;: &quot;EDT&quot;,\r\n                  &quot;DTSTART&quot;: &quot;19700308T020000&quot;,\r\n                  &quot;RRULE&quot;: &quot;FREQ=YEARLY;BYMONTH=3;BYDAY=2SU&quot;\r\n                }\r\n              ],\r\n              &quot;STANDARD&quot;: [\r\n                {\r\n                  &quot;TZOFFSETFROM&quot;: &quot;-0400&quot;,\r\n                  &quot;TZOFFSETTO&quot;: &quot;-0500&quot;,\r\n                  &quot;TZNAME&quot;: &quot;EST&quot;,\r\n                  &quot;DTSTART&quot;: &quot;19701101T020000&quot;,\r\n                  &quot;RRULE&quot;: &quot;FREQ=YEARLY;BYMONTH=11;BYDAY=1SU&quot;\r\n                }\r\n              ]\r\n            }\r\n          ],\r\n          &quot;VEVENT&quot;: [\r\n            {\r\n              &quot;DTSTART&quot;: &quot;20170731T233000Z&quot;,\r\n              &quot;DTEND&quot;: &quot;20170801T003000Z&quot;,\r\n              &quot;DTSTAMP&quot;: &quot;20170626T155902Z&quot;,\r\n              &quot;UID&quot;: &quot;va6vhj4qba2rll8epdmccnjs@google.com&quot;,\r\n              &quot;CREATED&quot;: &quot;20170523T010707Z&quot;,\r\n              &quot;DESCRIPTION&quot;: &quot;&quot;,\r\n              &quot;LAST-MODIFIED&quot;: &quot;20170523T010707Z&quot;,\r\n              &quot;LOCATION&quot;: &quot;&quot;,\r\n              &quot;SEQUENCE&quot;: &quot;0&quot;,\r\n              &quot;STATUS&quot;: &quot;CONFIRMED&quot;,\r\n              &quot;SUMMARY&quot;: &quot;Service&quot;,\r\n              &quot;TRANSP&quot;: &quot;OPAQUE&quot;\r\n            }\r\n          ]\r\n        }\r\n      ]   \r\n    }",
        "link": "https://stackoverflow.com/questions/44890243/unmerging-merged-google-calendar-data-with-jq",
        "title": "&quot;Unmerging&quot; merged google calendar data with jq"
    },
    {
        "tags": [
            "macos",
            "shell",
            "curl",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6153628,
                    "reputation": 1469,
                    "user_id": 4797324,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Z47xY.png?s=256",
                    "display_name": "toma",
                    "link": "https://stackoverflow.com/users/4797324/toma"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1499108537,
                "post_id": 44892244,
                "comment_id": 76762684,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1499110507,
                "last_edit_date": 1499110507,
                "creation_date": 1499108399,
                "answer_id": 44892361,
                "question_id": 44892244,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "    $ value=$(curl -X GET https://apitest.onkore.com/onkore/api/v1/storeCategories | \r\n      jq &#39;.[2] | ._id&#39;)\r\n    $ echo &quot;$value&quot;\r\n    &quot;59178d2a4ca53714085a0903&quot;\r\n\r\nIn other words, &quot;curl -X GET curl -X GET&quot; is incorrect.\r\n\r\nP.S. You might want to use the -r command-line option of jq. ",
                "title": "How to assign string value to variable from curl and jq in shell script?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1499110507,
        "creation_date": 1499107844,
        "question_id": 44892244,
        "body_markdown": "I am trying to assign a string I get from curl and jq to a variable. this is my code below, but it doesn&#39;t work. I am a Mac user.\r\n\r\n    value=$(curl -X GET curl -X GET https://apitest.onkore.com/onkore/api/v1/storeCategories | jq &#39;.[2] | ._id&#39;)",
        "link": "https://stackoverflow.com/questions/44892244/how-to-assign-string-value-to-variable-from-curl-and-jq-in-shell-script",
        "title": "How to assign string value to variable from curl and jq in shell script?"
    },
    {
        "tags": [
            "arrays",
            "select",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1499151834,
                "creation_date": 1499151834,
                "answer_id": 44899111,
                "question_id": 44898870,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The following filter produces the output exactly as described:\r\n\r\n    map(select(.time))\r\n    | map(.time), map(.data.power.current)\r\n\r\nThis is parsed as map(...) | ( map(...), map(...) ), thus resulting in a stream consisting of two JSON arrays.",
                "title": "jq split array into two arrays"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": -2,
                "last_activity_date": 1499153269,
                "creation_date": 1499153269,
                "answer_id": 44899597,
                "question_id": 44898870,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "first of all you can create a new json object. Before creting operation you should collect data in new array like this;\r\n\r\n    var timeData=[];\r\n    var currentData=[];\r\n    var mergedJsonData={};\r\n    \r\n    var yourJsonDataLenght= JSON.yourJsonData.length;\r\n    \r\n    for (infoIndex = 0; infoIndex &lt; yourJsonDataLenght; infoIndex++) {\r\n    \r\n        timeData.push(JSON.yourJsonData.time[infoIndex]);\r\n        currentData.push(JSON.yourJsonData.time[infoIndex].power.current);\r\n    }\r\n    \r\n    mergedJsonData.push(timeData); \r\n    mergedJsonData.push(currentData); ",
                "title": "jq split array into two arrays"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1499153269,
        "creation_date": 1499151199,
        "question_id": 44898870,
        "body_markdown": "I am new to jq and still trying to learn the basics of JSON, so please, excuse my lack of knowledge.\r\nI find the tool amazingly fast, but I am struggling to get the results I need. I am sure it&#39;s possible as I&#39;ve made it once by accident :(\r\nI have input data, such as\r\n\r\n    [\r\n      {&quot;time&quot;:1499150456,&quot;data&quot;:{&quot;power&quot;:{&quot;bus&quot;:3.88,&quot;shunt&quot;:6.98,&quot;load&quot;:3.89,&quot;current&quot;:76.00},&quot;light&quot;:{&quot;light&quot;:21}}},\r\n      {&quot;time&quot;:1499150516,&quot;data&quot;:{&quot;power&quot;:{&quot;bus&quot;:3.93,&quot;shunt&quot;:1.67,&quot;load&quot;:3.93,&quot;current&quot;:16.20},&quot;light&quot;:{&quot;light&quot;:21}}},\r\n      {&quot;time&quot;:1499150576,&quot;data&quot;:{&quot;power&quot;:{&quot;bus&quot;:3.92,&quot;shunt&quot;:5.58,&quot;load&quot;:3.93,&quot;current&quot;:25.30},&quot;light&quot;:{&quot;light&quot;:21}}},\r\n      {}\r\n    ]\r\nI want to extract it into something like\r\n\r\n      [\r\n       1499150456,\r\n       1499150516,\r\n       1499150576\r\n      ]\r\n      [\r\n       76.00,\r\n       16.20,\r\n       25.30\r\n      ]\r\nWhat I used so far was:\r\n\r\n    cat inputFile.json | jq -C &#39;.[] | select (length &gt; 0)&#39;\r\n\r\nwhich outputs nice initial array without the last empty record.\r\nNext, I am able to do\r\n\r\n    cat inputFile.json | jq -C &#39;.[] | select (length &gt; 0) | .time, .data.power.current&#39;\r\nThe result is very close, but not exactly what I need.\r\nI wanted to use map(.time) that I found in some example, but that resulted in an error - not sure how to use it and the examples did not work for me so far.",
        "link": "https://stackoverflow.com/questions/44898870/jq-split-array-into-two-arrays",
        "title": "jq split array into two arrays"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1499172525,
                "creation_date": 1499172525,
                "answer_id": 44906465,
                "question_id": 44903686,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "By looking at this https://stackoverflow.com/a/34227629/2434479, I was able to find my way around this problem, so I will keep it here as a reference for someone who might find him self in a similar situation.\r\n\r\nSo one way of doing it would be:\r\n\r\n    ❯ http ... | jq &#39;.[] | to_entries[] | [.key, (.value.shifts | length)] | @csv&#39;\r\n\r\nAnd when specific key by index needed, say 4th in row:\r\n\r\n    ❯ http|curl ... | jq &#39;.[] | keys_unsorted[3] as $k | &quot;\\($k), \\(.[$k].shifts | length)&quot;&#39;\r\n\r\n",
                "title": "obtain value from unknown string key property, using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1499172525,
        "creation_date": 1499164715,
        "question_id": 44903686,
        "body_markdown": "I have data structured like this:\r\n\r\n    {\r\n      &quot;data&quot;: {\r\n        &quot;2017-06-20&quot;: {\r\n          &quot;shifts&quot;: [\r\n            {\r\n              &quot;id&quot;: 24,\r\n              &quot;shift_request_id&quot;: 24,\r\n              &quot;created_at&quot;: &quot;2017-06-27 15:10:50&quot;,\r\n              &quot;updated_at&quot;: &quot;2017-06-27 15:10:50&quot;\r\n            },\r\n            {\r\n              &quot;id&quot;: 38,\r\n              &quot;shift_request_id&quot;: 38,\r\n              &quot;created_at&quot;: &quot;2017-06-27 15:10:50&quot;,\r\n              &quot;updated_at&quot;: &quot;2017-06-27 15:10:50&quot;\r\n            },\r\n            {\r\n              &quot;id&quot;: 85,\r\n              &quot;shift_request_id&quot;: 85,\r\n              &quot;created_at&quot;: &quot;2017-06-27 15:10:51&quot;,\r\n              &quot;updated_at&quot;: &quot;2017-06-27 15:10:51&quot;\r\n            }\r\n          ]\r\n        },\r\n    \t...\r\n    \t...\r\n    \t...\r\n    \t...\r\n        &quot;2017-06-21&quot;: {\r\n          &quot;shifts&quot;: [\r\n            {\r\n              &quot;id&quot;: 26,\r\n              &quot;shift_request_id&quot;: 26,\r\n              &quot;created_at&quot;: &quot;2017-06-27 15:10:50&quot;,\r\n              &quot;updated_at&quot;: &quot;2017-06-27 15:10:50&quot;\r\n            },\r\n            {\r\n              &quot;id&quot;: 28,\r\n              &quot;shift_request_id&quot;: 28,\r\n              &quot;created_at&quot;: &quot;2017-06-27 15:10:50&quot;,\r\n              &quot;updated_at&quot;: &quot;2017-06-27 15:10:50&quot;\r\n            },\r\n            {\r\n              &quot;id&quot;: 88,\r\n              &quot;shift_request_id&quot;: 88,\r\n              &quot;created_at&quot;: &quot;2017-06-27 15:10:51&quot;,\r\n              &quot;updated_at&quot;: &quot;2017-06-27 15:10:51&quot;\r\n            }\r\n          ]\r\n        }\r\n      }\r\n    }\r\n\r\nSo, with those date-like formatted keys, let&#39;s say I want to extract `shifts` from say, first such a key. I am not interested in extracting by particular date as that would be easy as specifying that date as a key, but rather selecting from the whole set, one of them or range, by numeric index, once obtained those keys.\r\n\r\nI tried:\r\n\r\n    jq &#39;.[] | keys&#39;\r\n\r\nwhich gives me an array of all keys, but then I don&#39;t know how would I extract array of shifts for a particular key indexed by number.\r\n\r\n    jq &#39;.[] | keys[3]&#39;\r\n\r\nwill give me the 4th key in a row, but then `.shifts` won&#39;t work on that, saying that it `Cannot index string with string &quot;shifts&quot;`\r\n",
        "link": "https://stackoverflow.com/questions/44903686/obtain-value-from-unknown-string-key-property-using-jq",
        "title": "obtain value from unknown string key property, using jq"
    },
    {
        "tags": [
            "linux",
            "raspberry-pi3",
            "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": 1499274500,
                "post_id": 44910010,
                "comment_id": 76840228,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1499224969,
                "last_edit_date": 1499224969,
                "creation_date": 1499224237,
                "answer_id": 44916457,
                "question_id": 44910010,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is an illustration of how you can achieve what you want using bash and jq:\r\n\r\n    # foo=$(curl &#39;{webservice_url}&#39;)\r\n    foo=&#39;{&quot;status&quot;: &quot;S&quot;, &quot;pin&quot;: &quot;P&quot;}&#39;\r\n    status=$(jq .status &lt;&lt;&lt; ${foo})\r\n    pin=$(jq .pin  &lt;&lt;&lt; ${foo})\r\n    \r\n    echo &quot;$status&quot;\r\n    echo &quot;$pin&quot;\r\n\r\nSince this involves one invocation of jq per variable, it might be worthwhile using an alternative approach.  If your bash has `readarray` (aka `mapfile`), then consider:\r\n\r\n    readarray -t lines &lt;&lt;&lt; $(jq -cr .status,.pin &lt;&lt;&lt; ${foo})\r\n    status=${lines[0]}\r\n    pin=${lines[1]}\r\n\r\nOtherwise:\r\n\r\n    i=0\r\n    while read -r line\r\n    do\r\n        i=$((i+1))\r\n        a[$i]=&quot;$line&quot;\r\n    done &lt; &lt;(jq -cr .status,.pin &lt;&lt;&lt; ${foo})\r\n\r\n### Using @tsv\r\nHere&#39;s a slightly different approach that relies on the fact that literal tabs cannot appear in JSON strings:\r\n\r\n    IFS=$&#39;\\t&#39; read status pin &lt; &lt;(jq -r &#39;[.status,.pin]|@tsv&#39; &lt;&lt;&lt; ${foo})\r\n\r\n",
                "title": "How to pass jq values to a variable in linux bash script"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1499224969,
        "creation_date": 1499183204,
        "question_id": 44910010,
        "body_markdown": "Can someone please help me out?\r\n\r\nI am working on a raspberry pi project and i wanted to control my pins from the cloud. I have this bash script that connects to a web service periodically to check this response. {&quot;status&quot;:1,&quot;pin&quot;:4}\r\n\r\nI am using jq and i was able to get the values that i need using&lt;br /&gt;\r\n    \r\n    source gpio\r\n\r\n    foo = $(curl &#39;{webservice_url}&#39;)\r\n    echo ${foo} | jq &#39;.status&#39;\r\n    echo ${foo} | jq &#39;.pin&#39;\r\n\r\n--------------------------------------\r\noutput : 1 and 4\r\n\r\nproblem is when i try to pass the value to a variable and use them it doesn&#39;t work\r\n\r\ni tried:\r\n\r\n     foo = $(curl &#39;{webservice_url}&#39;)\r\n     status = `${foo} | jq &#39;.status&#39;`\r\n     pin = `${foo} | jq &#39;.pin&#39;`\r\n\r\n     echo &quot;$status&quot;\r\n     echo &quot;$pin&quot;\r\n\r\nI tried using echo ${status} and still\r\nthe error says &lt;br /&gt;\r\n  status: command not found &lt;br /&gt;\r\n  pin: command not found\r\n     \r\n  \r\nalso i tried\r\n\r\n    source gpio\r\n    while true; do\r\n       foo = $(curl &#39;{webservice_url}&#39;)\r\n       gpio mode &quot;${foo} | jq &#39;.pin&#39;&quot; out\r\n       gpio write &quot;${foo} | jq &#39;.status&#39;&quot; 1 \r\n       sleep 1\r\n    done\r\n\r\nbut its not working.\r\n\r\nThank you in advance\r\n",
        "link": "https://stackoverflow.com/questions/44910010/how-to-pass-jq-values-to-a-variable-in-linux-bash-script",
        "title": "How to pass jq values to a variable in linux bash script"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1499272591,
                "post_id": 44929627,
                "comment_id": 76839168,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1499272966,
                "creation_date": 1499272966,
                "answer_id": 44931811,
                "question_id": 44929627,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "This is probably what you&#39;re looking for:\r\n\r\n    [{nid, title, nights, company: .operator.shortTitle, zone: .zones[0].title} \r\n     + (.sails[] | ({ sails_nid: .nid, arrival, departure } +\r\n                    (.cabins[] | { cabinname: .cabinType.title,\r\n    \t\t                       cabintype: .cabinType.kindName,\r\n    \t\t\t                   cabinnid: .cabinType.nid,\r\n    \t\t\t                   catalogPrice,\r\n    \t\t\t                   discountPrice,\r\n    \t\t\t                   discountPercentage,\r\n    \t\t\t                   currency } ))) ]\r\n\r\nHopefully the layout will clarify the difference with your jq filter.\r\n\r\n\r\n",
                "title": "JQ: Nested JSON Array transformation"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1499272966,
        "creation_date": 1499266354,
        "question_id": 44929627,
        "body_markdown": "Since some month ago i had a little problem with a jq Transformation (j1 1.5 on Windows 10). Since them the command worked excellent: `&quot;[{nid, title, nights, company: .operator.shortTitle, zone: .zones[0].title} \r\n+ (.sails[] | { sails_nid: .nid, arrival, departure } ) \r\n+ (.sails[].cabins[] | { cabinname: .cabinType.title, cabintype: .cabinType.kindName, cabinnid: .cabinType.nid,  catalogPrice, discountPrice, discountPercentage, currency } )]&quot;`. Since some days ago the api deliver &quot;bigger&quot; json files [JSON File][1]. With the jq command i got a lot of duplicates (with the attached file i got around 3146 objects, expected objects are arround 250). I tried to Change the jq command to avoid the duplicates but had no &quot;luck&quot; on that. \r\nThe json files contains a variable amount of sails (10 in these case), while each sail has a variable amount of cabins (25 in this case). Any tips how i can realize that? Regards timo\r\n\r\n\r\n  [1]: https://codeshare.io/5MejJq",
        "link": "https://stackoverflow.com/questions/44929627/jq-nested-json-array-transformation",
        "title": "JQ: Nested JSON Array transformation"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1702561,
                    "reputation": 3039,
                    "user_id": 1562258,
                    "user_type": "registered",
                    "accept_rate": 75,
                    "profile_image": "https://i.sstatic.net/RA7sS.jpg?s=256",
                    "display_name": "Ashish Kumar",
                    "link": "https://stackoverflow.com/users/1562258/ashish-kumar"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1499339914,
                "post_id": 44947370,
                "comment_id": 76869760,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": -1,
                "last_activity_date": 1499340320,
                "creation_date": 1499340320,
                "answer_id": 44947563,
                "question_id": 44947370,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "This should be as simple as that:\r\n\r\n&lt;!-- begin snippet: js hide: false console: true babel: false --&gt;\r\n\r\n&lt;!-- language: lang-js --&gt;\r\n\r\n    var data = {\r\n      &quot;body&quot;: [{\r\n        &quot;username&quot;: &quot;name1&quot;,\r\n        &quot;id&quot;: &quot;4444&quot;\r\n      }, {\r\n        &quot;username&quot;: &quot;name2&quot;,\r\n        &quot;id&quot;: &quot;5555&quot;\r\n      }],\r\n      &quot;meta&quot;: {\r\n        &quot;input&quot;: &quot;name1&quot;\r\n      }\r\n    };\r\n\r\n    function getID(data) {\r\n      var username = data.meta.input;\r\n      var userID;\r\n\r\n      for (i in data.body) {\r\n      \r\n        if (data.body[i].username === username) {\r\n          userID = data.body[i].id;\r\n          break;\r\n        }\r\n      }\r\n\r\n      return userID;\r\n    }\r\n\r\n    var id = getID(data);\r\n    alert(id);\r\n\r\n\r\n&lt;!-- end snippet --&gt;\r\n\r\n",
                "title": "Using jq to compare two fields from same json and printing some other field as a result"
            },
            {
                "up_vote_count": 10,
                "is_accepted": true,
                "score": 10,
                "last_activity_date": 1499340879,
                "creation_date": 1499340879,
                "answer_id": 44947745,
                "question_id": 44947370,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "***jq*** solution:\r\n\r\n    jq &#39;.meta.input as $meta | .body[] | select(.username == $meta).id&#39; input.json\r\nThe output:\r\n\r\n    &quot;4444&quot;\r\n\r\n\r\n----------\r\n- `.meta.input as $meta` - assigning `.meta.input` key value to `$meta` variable for further comparison\r\n\r\n",
                "title": "Using jq to compare two fields from same json and printing some other field as a result"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 7,
        "last_activity_date": 1521790292,
        "creation_date": 1499339731,
        "question_id": 44947370,
        "body_markdown": "I have json data in following format\r\n\r\n    {\r\n      &quot;body&quot;: [\r\n        {\r\n          &quot;username&quot;: &quot;name1&quot;,\r\n          &quot;id&quot;: &quot;4444&quot;\r\n        },\r\n        {\r\n          &quot;username&quot;: &quot;name2&quot;,\r\n          &quot;id&quot;: &quot;5555&quot;\r\n        }\r\n      ],\r\n      &quot;meta&quot;: {\r\n        &quot;input&quot;: &quot;name1&quot;\r\n      }}\r\nGiven this data I want to match the &quot;username&quot;s in the body with &quot;meta.input&quot; and if there is a match return/print related id.",
        "link": "https://stackoverflow.com/questions/44947370/using-jq-to-compare-two-fields-from-same-json-and-printing-some-other-field-as-a",
        "title": "Using jq to compare two fields from same json and printing some other field as a result"
    },
    {
        "tags": [
            "json",
            "object",
            "duplicates",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1499544839,
                "last_edit_date": 1499544839,
                "creation_date": 1499355776,
                "answer_id": 44953499,
                "question_id": 44948827,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "In words:\r\n\r\n&gt; .. to compare title from the first JSON line and the fourth JSON line, and if the title is the same I want to omit one of the entries.\r\n\r\nIn jq:\r\n\r\n    jq -s &#39;if .[0].title == .[3].title then del(.[0]) else . end&#39;\r\n\r\n----\r\nIn words:\r\n&gt; find and remove duplicates [based on .title]\r\n\r\nIn jq:\r\n\r\n    INDEX(.title) | [.[]]\r\n\r\nApart from brevity, the big advantage of using `INDEX/1` here (e.g. vs `unique` or `group_by`) is that it does NOT incur the cost of sorting.\r\n\r\n(If your jq does not have `INDEX` then simply copy its definition from https://github.com/stedolan/jq/blob/master/src/builtin.jq )\r\n\r\n----\r\n### Using the -f option\r\n\r\nAssuming you have jq 1.5 and that the file named program.jq contains the following text:\r\n\r\n    def INDEX(stream; idx_expr):\r\n      reduce stream as $row ({};\r\n        .[$row|idx_expr|\r\n          if type != &quot;string&quot; then tojson\r\n          else .\r\n          end] |= $row);\r\n    def INDEX(idx_expr): INDEX(.[]; idx_expr);\r\n    \r\n    INDEX(.title) | [.[]]\r\n\r\n\r\nyou can invoke jq as follows:\r\n\r\n    jq -s -f program.jq input\r\n\r\nwhere &quot;input&quot; is the name of the file containing the JSON lines (or JSON stream).\r\n\r\n### jq 1.4\r\nIf you only have access to jq 1.4, then you could use this variant:\r\n\r\n    def INDEX(stream; idx_expr):\r\n      reduce stream as $row ({};\r\n        .[$row|idx_expr|\r\n          if type != &quot;string&quot; then tojson\r\n          else .\r\n          end] |= $row);\r\n    \r\n    INDEX(.[]; .title) | [.[]]\r\n\r\n### jq 1.3\r\njq 1.3 is very out-of-date but if you cannot upgrade, then for present purposes, it will suffice to use the version immediately above, replacing `tojson` with `tostring`. Or even just:\r\n\r\n    def INDEX(f): map( {(f|tostring): . } ) | add;\r\n\r\n",
                "title": "jq filter to remove duplicates by comparing objects inside"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1499544839,
        "creation_date": 1499343878,
        "last_edit_date": 1499356299,
        "question_id": 44948827,
        "body_markdown": "I am trying to convert JSON lines to JSON and in the process trying to find and remove duplicates by comparing values from objects.\r\n\r\nFor example:\r\n    \r\n    {&quot;headline&quot;: &quot;sample headline 1&quot;, &quot;title&quot;: &quot;sample title 1&quot;, &quot;href&quot;: &quot;sample link 1&quot;, &quot;day&quot;: &quot; Fri, 7 Jul 2017 , 8:30PM &quot;, &quot;tags&quot;: &quot;tag1&quot;}\r\n    {&quot;headline&quot;: &quot;sample headline 2&quot;, &quot;title&quot;: &quot;sample title 2&quot;, &quot;href&quot;: &quot;sample link 2&quot;, &quot;day&quot;: &quot; Fri, 7 Jul 2017 , 8:30PM &quot;, &quot;tags&quot;: &quot;tag2&quot;}\r\n    {&quot;headline&quot;: &quot;sample headline 3&quot;, &quot;title&quot;: &quot;sample title 3&quot;, &quot;href&quot;: &quot;sample link &quot;, &quot;day&quot;: &quot; Fri, 7 Jul 2017 , 8:30PM &quot;, &quot;tags&quot;: &quot;tag3&quot;}\r\n    {&quot;headline&quot;: &quot;sample headline 4&quot;, &quot;title&quot;: &quot;sample title 1&quot;, &quot;href&quot;: &quot;sample link 4&quot;, &quot;day&quot;: &quot; Fri, 7 Jul 2017 , 8:30PM &quot;, &quot;tags&quot;: &quot;tag4&quot;}\r\n\r\nNow I want to compare `title` from the first JSON line and the fourth JSON line, and if the  title is the same I want to omit one of the entries.\r\n\r\nI have only been able to convert it to JSON and remove duplicates by comparing all objects:\r\n\r\n    jq --slurp [.[]] | unique\r\n\r\nbut this compares all objects inside whereas I want to compare only one object and remove the entire line. How can I do that?",
        "link": "https://stackoverflow.com/questions/44948827/jq-filter-to-remove-duplicates-by-comparing-objects-inside",
        "title": "jq filter to remove duplicates by comparing objects inside"
    },
    {
        "tags": [
            "json",
            "dictionary",
            "merge",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1499398619,
                "last_edit_date": 1499398619,
                "creation_date": 1499365897,
                "answer_id": 44956481,
                "question_id": 44954791,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You don&#39;t give details about the transformation you have in mind, but if you can specify the algorithm, then rest assured, it can be done in jq.\r\n\r\nPerhaps the thing you&#39;re missing is how to get jq to read the three files.  One way to proceed would be to use the invocation:\r\n\r\n    jq --argfile keyfile keyfile.json --argfile vault vault.json -f vault.jq input.json\r\n\r\nwhere vault.jq is the file containing your jq program, in which you would refer to the contents of keyfile.json as `$keyfile`, and similarly for the contents of vault.json\r\n\r\n### Simplifying keyfile.json\r\n\r\nSince you indicate you have some flexibility about the format of keyfile.json, and since it appears to hold path information, I would recommend considering adopting path specifications that can be used directly with the jq builtins `getpath` and `setpath`.\r\n\r\nFor example, consider this format for keyfile.json: \r\n\r\n    [ [&lt;path in input.json&gt;], [&lt;path in vault.json&gt; ], ... ]\r\n\r\nThe first two entries corresponding to your example would thus be:\r\n\r\n    [\r\n      [ [&quot;.cloud_cpi_key&quot;,&quot;value&quot;], [&quot;aws&quot;,&quot;access_key_id&quot;]],\r\n      [ [&quot;.cloud_cpi_secret&quot;], [&quot;aws&quot;, &quot;secret_access_key&quot;]]\r\n    ]\r\n\r\nTo use the &quot;vault&quot; as the basis for updates, your jq program would then be the one-liner:\r\n\r\n    reduce $keyfile[] as $p (.; setpath(($p|.[0]); $vault|getpath($p|.[1])))\r\n\r\n\r\n",
                "title": "update one json file with a second json based on third json with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1499398619,
        "creation_date": 1499359778,
        "last_edit_date": 1499376369,
        "question_id": 44954791,
        "body_markdown": "I have three JSON files:\r\n\r\n`vault.json:`\r\n\r\n    {\r\n      &quot;aws&quot;:\r\n      {\r\n        &quot;access_key_id&quot;: &quot;My-Key-id&quot;,\r\n        &quot;secret_access_key&quot;: &quot;My-Access-Key&quot;\r\n      },\r\n      &quot;ssl&quot;:\r\n      {\r\n        &quot;crt&quot;: &quot;My-Crt&quot;,\r\n        &quot;key&quot;: &quot;My-Key&quot;,\r\n        &quot;req&quot;: &quot;My-Req&quot;\r\n      }\r\n    }\r\n\r\n`input.json:`\r\n\r\n    {\r\n      &quot;.cloud_cpi_key&quot;: {\r\n        &quot;type&quot;: &quot;wildcard_domain&quot;,\r\n        &quot;configurable&quot;: true,\r\n        &quot;credential&quot;: false,\r\n        &quot;value&quot;: &quot;vault-supplied-value&quot;,\r\n        &quot;optional&quot;: false\r\n      },\r\n      &quot;.cloud_cpi_secret&quot;: {\r\n        &quot;type&quot;: &quot;wildcard_domain&quot;,\r\n        &quot;configurable&quot;: true,\r\n        &quot;credential&quot;: false,\r\n        &quot;value&quot;: &quot;vault-supplied-value&quot;,\r\n        &quot;optional&quot;: false\r\n      },\r\n      &quot;.properties.networking_point_of_entry&quot;: {\r\n        &quot;type&quot;: &quot;selector&quot;,\r\n        &quot;configurable&quot;: true,\r\n        &quot;credential&quot;: false,\r\n        &quot;value&quot;: &quot;external_ssl&quot;,\r\n        &quot;optional&quot;: false\r\n      },\r\n      &quot;.properties.networking_point_of_entry.external_ssl.ssl_rsa_certificate&quot;: {\r\n        &quot;type&quot;: &quot;rsa_cert_credentials&quot;,\r\n        &quot;configurable&quot;: true,\r\n        &quot;credential&quot;: true,\r\n        &quot;value&quot;: {\r\n          &quot;private_key_pem&quot;: &quot;vault-supplied-value&quot;,\r\n          &quot;cert_pem&quot;: &quot;vault-supplied-value&quot;\r\n        },\r\n        &quot;optional&quot;: false\r\n      }\r\n    }\r\n\r\n`keyfile.json`\r\n\r\n    {\r\n      &quot;.cloud_cpi_key.value&quot;: &quot;aws.access_key_id&quot;,\r\n      &quot;.cloud_cpi_secret&quot;: &quot;secret_access_key&quot;,\r\n      &quot;.properties.networking_point_of_entry.external_ssl.ssl_rsa_certificate.value.private_key_pem&quot;: &quot;ssl.key&quot;,\r\n      &quot;.properties.networking_point_of_entry.external_ssl.ssl_rsa_certificate.value.cert_pem&quot;: &quot;ssl.crt&quot;\r\n    }\r\n\r\nI&#39;d like to update the second json file, with the values from the first json, based on the third json.\r\ncan this be done via JQ to provide output.json?\r\n\r\n`output.json:`\r\n\r\n    {\r\n      &quot;.cloud_cpi_key&quot;: {\r\n        &quot;type&quot;: &quot;string&quot;,\r\n        &quot;configurable&quot;: true,\r\n        &quot;credential&quot;: true,\r\n        &quot;value&quot;: &quot;My-Key-id&quot;,\r\n        &quot;optional&quot;: false\r\n      },\r\n      &quot;.cloud_cpi_secret&quot;: {\r\n        &quot;type&quot;: &quot;string&quot;,\r\n        &quot;configurable&quot;: true,\r\n        &quot;credential&quot;: true,\r\n        &quot;value&quot;: &quot;My-Access-Key&quot;,\r\n        &quot;optional&quot;: false\r\n      },\r\n      &quot;.properties.networking_point_of_entry&quot;: {\r\n        &quot;type&quot;: &quot;selector&quot;,\r\n        &quot;configurable&quot;: true,\r\n        &quot;credential&quot;: false,\r\n        &quot;value&quot;: &quot;external_ssl&quot;,\r\n        &quot;optional&quot;: false\r\n      },\r\n      \r\n    &quot;.properties.networking_point_of_entry.external_ssl.ssl_rsa_certificate&quot;: {\r\n        &quot;type&quot;: &quot;rsa_cert_credentials&quot;,\r\n        &quot;configurable&quot;: true,\r\n        &quot;credential&quot;: true,\r\n        &quot;value&quot;: {\r\n          &quot;private_key_pem&quot;: &quot;My-Key&quot;,\r\n          &quot;cert_pem&quot;: &quot;My-Crt&quot;\r\n        },\r\n        &quot;optional&quot;: false\r\n      }\r\n    }\r\n\r\nI can modify keyfile.json any way I like to make things easier, like\r\n\r\n    {\r\n        &quot;fromkey&quot;: &quot;aws.access_key_id&quot;\r\n        &quot;tokey&quot;: &quot;.cloud_cpi_key.value&quot;\r\n    },\r\n    {   &quot;fromkey&quot;: ....\r\n    }\r\n\r\nBut no values may be placed in keyfile.json, only key names.\r\n\r\nAnd I can modify vault.json, to put things in arrays, or what-have-you, but I cannot change the lowest levels, i.e. I cannot change:\r\n\r\n    {\r\n        &quot;access_key_id&quot;: &quot;My-Key-id&quot;,\r\n        &quot;secret_access_key&quot;: &quot;My-Access-Key&quot;\r\n    }\r\n\r\nI cannot modify input.json.\r\nHow can I accomplish this with JQ?",
        "link": "https://stackoverflow.com/questions/44954791/update-one-json-file-with-a-second-json-based-on-third-json-with-jq",
        "title": "update one json file with a second json based on third json with jq"
    },
    {
        "tags": [
            "arrays",
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 6,
                "is_accepted": false,
                "score": 6,
                "last_activity_date": 1499418645,
                "creation_date": 1499418645,
                "answer_id": 44966901,
                "question_id": 44966762,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You can &quot;slurp&quot; your inputs:\r\n\r\n&gt; -s\t\tread (slurp) all inputs into an array; apply filter to it;\r\n\r\n(man jq)\r\n\r\nLike that:\r\n\r\n1.json\r\n\r\n    \r\n    {&quot;myArray&quot;:[1,2,3]}\r\n\r\n2.json\r\n\r\n    {&quot;myArray&quot;:[3,4,5]}\r\n\r\n`%jq -s &#39;[.[].myArray[]]&#39; 1.json 2.json`\r\n\r\n    [\r\n      1,\r\n      2,\r\n      3,\r\n      3,\r\n      4,\r\n      5\r\n    ]\r\n\r\n",
                "title": "Generate single JSON array from several input objects using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1499450362,
        "creation_date": 1499418250,
        "last_edit_date": 1499450362,
        "question_id": 44966762,
        "body_markdown": "I do have several similar JSON objects (e.g. in files):\r\n\r\n    file_1.json: {&quot;myArray&quot;:[{a},{b}]}\r\n    ...\r\n    file_n.json: {&quot;myArray&quot;:[{n},{m}]}\r\n\r\nI would like to transform all these files into one output with the following format, using jq and Linux or Windows command line tools:\r\n\r\n    result_file.json: [{a},{b},...,{n},{m}]\r\n\r\nSo, I just want one array having all the objects that can be found in the &quot;myArray&quot; arrays from the different inputs.\r\n\r\nCurrently I use this command, which separates the objects, but doesn&#39;t create an array that includes them:\r\n\r\n    type file_1.json file_n.json | jq &quot;.result[]&quot; &gt; result_file.json\r\n\r\n(replace type with cat on Linux)\r\n\r\nHow can I get the format right?",
        "link": "https://stackoverflow.com/questions/44966762/generate-single-json-array-from-several-input-objects-using-jq",
        "title": "Generate single JSON array from several input objects using jq"
    },
    {
        "tags": [
            "json",
            "bash",
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3083126,
                    "reputation": 14570,
                    "user_id": 4687135,
                    "user_type": "registered",
                    "accept_rate": 67,
                    "profile_image": "https://www.gravatar.com/avatar/386484f527a8df3c1fdd3e2dde112533?s=256&d=identicon&r=PG",
                    "display_name": "Eric Renouf",
                    "link": "https://stackoverflow.com/users/4687135/eric-renouf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1499473750,
                "post_id": 44981265,
                "comment_id": 76938013,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 11280798,
                    "reputation": 263,
                    "user_id": 8273311,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/4baba85760b79bc222af380ea155309a?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "tom",
                    "link": "https://stackoverflow.com/users/8273311/tom"
                },
                "reply_to_user": {
                    "account_id": 3083126,
                    "reputation": 14570,
                    "user_id": 4687135,
                    "user_type": "registered",
                    "accept_rate": 67,
                    "profile_image": "https://www.gravatar.com/avatar/386484f527a8df3c1fdd3e2dde112533?s=256&d=identicon&r=PG",
                    "display_name": "Eric Renouf",
                    "link": "https://stackoverflow.com/users/4687135/eric-renouf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1499473945,
                "post_id": 44981265,
                "comment_id": 76938051,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1499477238,
                "last_edit_date": 1499477238,
                "creation_date": 1499474113,
                "answer_id": 44981392,
                "question_id": 44981265,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You can use the [`@tsv`](https://stedolan.github.io/jq/manual/#Formatstringsandescaping) string formatter in combination with [`--raw-output`/`-r`](https://stedolan.github.io/jq/manual/#Invokingjq) option and split the output to `bash` array on tabs:\r\n\r\n    $ IFS=$&#39;\\t&#39;\r\n    $ x=($(jq -r &#39;.[] | .list_file | @tsv&#39; input.json))\r\n    $ for xx in &quot;${x[@]}&quot;; do echo &quot;$xx&quot;; done\r\n    /var/a.txt\r\n    /dev/b.txt\r\n\r\nFor `-r` will strip the outer quotes (useful for making `jq` filters talk to non-JSON-based systems), and `@tsv` will output an array as a series of tab-separated strings (tabs, newlines, etc. will be escaped).\r\n\r\nAlternatively, you use the `@sh` filter which outputs an array as a series of space-separated strings. However, to interpret such output, you have to `eval`uate it:\r\n\r\n    $ eval &quot;x=($(jq -r &#39;.[] | .list_file | @sh&#39; input.json))&quot;\r\n",
                "title": "Extract JSON value to shell variable using jq"
            },
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1499477086,
                "creation_date": 1499477086,
                "answer_id": 44981634,
                "question_id": 44981265,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "In order to handle all values properly, you need to use the `declare` command to incorporate the output of `jq` into an array assignment.\r\n\r\nHere&#39;s some input with some corner cases to worry about: whitespace, a newline, and a glob character.\r\n\r\n    $ cat input.json\r\n    [\r\n        {&quot;id&quot;:10,\r\n    \t&quot;list_file&quot;:[\r\n            &quot;/var/a b.txt&quot;,\r\n    \t    &quot;/dev/c\\nd.txt&quot;,\r\n            &quot;*&quot;]}\r\n    ]\r\n\r\nA `jq` command that extracts and outputs properly quoted strings for use by the shell:\r\n\r\n    $ $ jq -r &#39;.[] | .list_file[] | @sh&#39; input.json\r\n    &#39;/var/a b.txt&#39;\r\n    &#39;/dev/c\r\n    d.txt&#39;\r\n    &#39;*&#39;\r\n\r\nAnd a shell command that can make use of the output:\r\n\r\n    $ declare -a &quot;x=($(jq -r &#39;.[] | .list_file[] | @sh&#39; input.json))&quot;\r\n\r\nProof that it worked properly:\r\n\r\n    $ printf &#39;==%s==\\n&#39; &quot;${x[@]}&quot;\r\n    ==/var/a b.txt==\r\n    ==/dev/c\r\n    d.txt==\r\n    ==*==",
                "title": "Extract JSON value to shell variable using jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1499502329,
                "creation_date": 1499502329,
                "answer_id": 44984140,
                "question_id": 44981265,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "1. On a Mac, it&#39;s easy enough to install a bash with `readarray` (e.g. using homebrew: `brew install bash`), so in the following I&#39;ll assume it&#39;s available, but you could just as well use the `while read -r value` technique to read values on a line-by-line basis.  (One advantage of these line-oriented methods is that there&#39;s no need to fiddle with IFS.)\r\n\r\n2. For the problem at hand, there may be situations in which it would be better to retain the JSON representation of special characters, e.g &quot;\\n&quot; for NEWLINE, &quot;\\u0000&quot; for NUL, etc.  At any rate, a generic alternative to using `-r` is to use the `-c` command-line option instead, as illustrated below:\r\n\r\n&lt;/&gt;\r\n\r\n    $ readarray -t x &lt; &lt;(jq -n -c &#39;(&quot;\\u0001\\nb&quot;, &quot;c\\td&quot;, &quot;e\\u0000f&quot;)&#39;\r\n      | sed -e &#39;s/^\\&quot;//&#39; -e &#39;s/\\&quot;$//&#39; )\r\n    $ printf &quot;:%s:\\n&quot; &quot;${x[@]}&quot;\r\n    :\\u0001\\nb:\r\n    :c\\td:\r\n    :e\\u0000f:\r\n    \r\n",
                "title": "Extract JSON value to shell variable using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 4,
        "last_activity_date": 1499503864,
        "creation_date": 1499472897,
        "last_edit_date": 1499503864,
        "question_id": 44981265,
        "body_markdown": "I have a json response as shown below :\r\n\r\n    [\r\n     {&quot;id&quot;:10,\r\n     &quot;list_file&quot;:[&quot;/var/a.txt&quot;,\r\n                 &quot;/dev/b.txt&quot;]}\r\n    ]\r\n\r\nI need to extract values of list_file and store it shell variable as an array. I tried doing it looping through and reading the values.\r\n\r\n    #!/bin/bash\r\n    x=()\r\n    while read -r value\r\n    do\r\n      #echo &quot;$value&quot;\r\n      x+=(&quot;$value&quot;)\r\n    done &lt; &lt;(jq -r &#39;.[] | .list_file&#39; input.json)\r\n\r\nBut the extracted values in the array contains quotes, brackets and comma too.\r\n\r\n    [\r\n        &quot;/var/a.txt&quot;,\r\n        &quot;/dev/b.txt&quot;\r\n    ]\r\n   \r\nCould you please help me modify the code so that the array contains only the entries /var/a.txt and /dev/b.txt. Also, I tried readarray and map, but they won&#39;t work on Mac Osx. Any help would be really appreciated.",
        "link": "https://stackoverflow.com/questions/44981265/extract-json-value-to-shell-variable-using-jq",
        "title": "Extract JSON value to shell variable using jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 7,
                "is_accepted": true,
                "score": 7,
                "last_activity_date": 1499525034,
                "creation_date": 1499525034,
                "answer_id": 44987362,
                "question_id": 44985737,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "From [jq manual][1] : \r\n\r\n&gt; You can also look up fields of an object using syntax like .[&quot;foo&quot;]\r\n&gt; (.foo above is a shorthand version of this, but only for\r\n&gt; identifier-like strings).\r\n\r\nYou also need quotes and use `-r` if you want raw output : \r\n\r\n    jq -r &#39;.e[&quot;1&quot;].f&#39; test.json\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/",
                "title": "Invalid numeric literal with jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1638390480,
                "creation_date": 1638390480,
                "answer_id": 70190835,
                "question_id": 44985737,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I wrote a shell script function that calls the curl command, and pipes it into the jq command.\r\n\r\n    function getName {\r\n      curl http://localhost:123/getname/$1 | jq;\r\n    }\r\n    export -f getName\r\n\r\nWhen I ran this from the CLI, \r\n\r\n    getName jarvis\r\n\r\nI was getting this response:\r\n\r\n&gt; parse error: Invalid numeric literal at line 1, column 72\r\n\r\nI tried removing the | jq from the curl command, and I got back the result without jq parsing:\r\n\r\n    &lt;Map&gt;&lt;timestamp&gt;1234567890&lt;/timestamp&gt;&lt;status&gt;404&lt;/status&gt;&lt;error&gt;Not Found&lt;/error&gt;&lt;message&gt;....\r\n\r\nI first thought that I had a bad character in the curl command, or that I was using the function param $1 wrong.\r\n\r\nThen I counted the number of chars in the result string, and I noticed that the 72nd char in that string was the empty space between &quot;Not Found&quot;.\r\n\r\nThe underlying issue was that I didn&#39;t have a method named getname yet in my spring REST controller, so the response was coming back 404 Not Found.  But in addition, jq wasn&#39;t handling the empty space in the response except by outputting the error message.\r\n\r\nI&#39;m new to jq so maybe there is a way to get around the empty space issue, but that&#39;s for another day.\r\n",
                "title": "Invalid numeric literal with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 10,
        "last_activity_date": 1638390480,
        "creation_date": 1499513485,
        "question_id": 44985737,
        "body_markdown": "I have a large amount of JSON from a 3rd party system which I would like to pre-process with jq, but I am having difficulty composing the query, test case follows:\r\n\r\n    $ cat test.json\r\n    {\r\n      &quot;a&quot;: &quot;b&quot;,\r\n      &quot;c&quot;: &quot;d&quot;,\r\n      &quot;e&quot;: {\r\n             &quot;1&quot;: {\r\n    \t        &quot;f&quot;: &quot;g&quot;,\r\n    \t\t    &quot;h&quot;: &quot;i&quot;\r\n    \t      }\r\n           }\r\n    }\r\n    $ cat test.json|jq .e.1.f\r\n    jq: error: Invalid numeric literal at EOF at line 1, column 3 (while parsing &#39;.1.&#39;) at &lt;top-level&gt;, line 1:\r\n    .e.1.f\r\n\r\n\r\nHow would I get &quot;g&quot; as my output here? Or how do I cast that 1 to a &quot;1&quot; so it is handled correctly?",
        "link": "https://stackoverflow.com/questions/44985737/invalid-numeric-literal-with-jq",
        "title": "Invalid numeric literal with jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1499602492,
                "creation_date": 1499602492,
                "answer_id": 44996278,
                "question_id": 44995429,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The key to understanding here is that jq is stream-oriented.  `[&quot;a&quot;,&quot;b&quot;][]` produces a stream, ergo `. == [&quot;a&quot;,&quot;b&quot;][]` produces a stream.  `select` selects the items that produce truthy values in that stream.  \r\n\r\nTo gain an understanding of how jq works, it often helps to pull things apart.  In the present case, you could begin by trying: \r\n\r\n    echo &#39;[&quot;a&quot;,&quot;b&quot;,&quot;c&quot;,&quot;d&quot;]&#39; | jq &#39;.[] | (. == [&quot;a&quot;,&quot;b&quot;][])&#39;\r\n\r\n`debug` is also helpful, e.g.\r\n\r\n    echo &#39;[&quot;a&quot;,&quot;b&quot;,&quot;c&quot;,&quot;d&quot;]&#39; | jq &#39;.[] | select(debug == [&quot;a&quot;,&quot;b&quot;][])&#39;",
                "title": "How does a `select (. == [&quot;a&quot;,&quot;b&quot;][])` predicate work in JQ?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1499602492,
        "creation_date": 1499596401,
        "question_id": 44995429,
        "body_markdown": "I&#39;m looking for ways to select JSON entries based on an array that I provide as a literal:\r\n\r\n\r\n    $ echo &#39;[&quot;a&quot;,&quot;b&quot;,&quot;c&quot;,&quot;d&quot;]&#39; | jq &#39;.[] | select (. == [&quot;a&quot;,&quot;b&quot;][] )&#39;\r\n    &quot;a&quot;\r\n    &quot;b&quot;\r\n\r\n\r\nIn the code above, all entries are selected that are in the `[&quot;a&quot;,&quot;b&quot;]` array. However, I don&#39;t understand how the `. == [&quot;a&quot;,&quot;b&quot;][]` predicate works in detail and would be grateful for an explanation. The tricky part is the right-hand side of `==`.\r\n\r\nRelated:\r\n\r\n* https://stackoverflow.com/questions/34878915/jq-how-to-select-objects-based-on-a-whitelist-of-property-values\r\n\r\n",
        "link": "https://stackoverflow.com/questions/44995429/how-does-a-select-a-b-predicate-work-in-jq",
        "title": "How does a `select (. == [&quot;a&quot;,&quot;b&quot;][])` predicate work in JQ?"
    },
    {
        "tags": [
            "json",
            "bash",
            "casting",
            "command-line-arguments",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1499601645,
                "creation_date": 1499601645,
                "answer_id": 44996180,
                "question_id": 44995626,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "When you pass an argument via `--arg` it is treated as a string, not an int:\r\n\r\n&gt; --arg name value:  \r\n&gt;  \r\n&gt; This option passes a value to the jq program as a predefined variable. If you run jq with --arg foo bar, then $foo is available in the program and has the value &quot;bar&quot;. **Note that value will be treated as a string, so --arg foo 123 will bind $foo to &quot;123&quot;**.\r\n\r\nFrom [the docs](https://stedolan.github.io/jq/manual/) (emphases added)\r\n\r\nso it would seem that you cannot use `--arg` to pass a value to be used in a slice.  In this example, you could just use the shell expansion though:\r\n\r\n    jq &quot;.arr[0:$end_index]&quot; obj.json\r\n\r\nthe double quotes will have the shell expand your variable before passing it to `jq` (though other expansions will happen to, so make sure you mean them to happen.",
                "title": "jq: slicing array based on argument"
            },
            {
                "up_vote_count": 10,
                "is_accepted": true,
                "score": 10,
                "last_activity_date": 1499602924,
                "creation_date": 1499602924,
                "answer_id": 44996338,
                "question_id": 44995626,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "1. You can convert a string to a number using `tonumber`, as in:\r\n\r\n&lt;/&gt;\r\n\r\n    jq --arg eidx 1 &#39;.arr[0:($eidx|tonumber)]&#39;\r\n\r\n2. If your jq is sufficiently recent, you can use `--argjson` instead of `--arg`:\r\n\r\n&lt;/&gt;\r\n\r\n    jq --argjson eidx 1 &#39;.arr[0:$eidx]&#39;\r\n\r\n",
                "title": "jq: slicing array based on argument"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 7,
        "last_activity_date": 1499696392,
        "creation_date": 1499597744,
        "last_edit_date": 1499696392,
        "question_id": 44995626,
        "body_markdown": "I am trying to slice an array in jq where the end index is passed as an argument from the shell (bash):\r\n\r\n    end_index=7\r\n    cat obj.json | jq --arg eidx $end_index, &#39;.arr[0:$eidx]&#39;\r\n\r\nThis works as expected when the index is hard-coded\r\n\r\n    cat obj.json | jq &#39;.arr[0:7]&#39;\r\n\r\nbut in the example at the top, I get an error message\r\n\r\n    jq: error (at &lt;stdin&gt;:0): Start and end indices of an array slice must be numbers\r\n\r\nI suspect this might be to do with how jq handles variable substitution within the slice operator `[:]`, but none of my attempts to solve the problem, e.g. by enclosing the variable name in curly braces `.arr[0:${eidx}]`, has worked.",
        "link": "https://stackoverflow.com/questions/44995626/jq-slicing-array-based-on-argument",
        "title": "jq: slicing array based on argument"
    },
    {
        "tags": [
            "json",
            "nested",
            "export-to-csv",
            "jq",
            "data-extraction"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1499666719,
                "last_edit_date": 1499666719,
                "creation_date": 1499665684,
                "answer_id": 45004537,
                "question_id": 45004253,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The title of the question mentions CSV so I&#39;ll first illustrate how to produce valid CSV with @csv.\r\n\r\nWith your input (corrected to make it valid JSON), the invocation:\r\n\r\n    jq -r &#39;[.id, .slug, .&quot;**provider**&quot;.&quot;icons&quot;.&quot;color_code&quot; ] | @csv&#39;\r\n\r\nproduces:\r\n\r\n    100442,&quot;spredfns&quot;,&quot;65c6bb&quot;\r\n\r\n### Avoiding the quotation marks\r\nIf you don&#39;t want the enclosing quotation marks in the output, then you could use string interpolation, as in the original post.  If your jq supports `@tsv`, then an alternative would be to use it instead of @csv; the output would then be:\r\n\r\n    100442\tspredfns\t65c6bb\r\n\r\n### Including headers\r\n\r\nHeaders can be included like so:\r\n\r\n    ([&quot;id&quot;, &quot;slug&quot;, &quot;provider color_code&quot;],\r\n     [.id, .slug, .&quot;**provider**&quot;.&quot;icons&quot;.&quot;color_code&quot; ])\r\n    | @tsv\r\n\r\nIn this case the output would be:\r\n\r\n    id\tslug\tprovider color_code\r\n    100442\tspredfns\t65c6bb\r\n\r\n    \r\n### Older versions of jq\r\n\r\nIf you are using a version of jq that does not support the `.&quot;foo&quot;` syntax, use the primary `.[&quot;foo&quot;]` syntax instead, remembering to create a pipeline:\r\n\r\n     [.id, .slug, (.[&quot;**provider**&quot;] | .[&quot;icons&quot;] | .[&quot;color_code&quot;]) ]",
                "title": "jq converting some json keys into csv"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1499714295,
        "creation_date": 1499664071,
        "last_edit_date": 1499714295,
        "question_id": 45004253,
        "body_markdown": "I have json text that looks like the following\r\n\r\n   \r\n\r\n     {\r\n      &quot;requires_mfa_code&quot;: false,\r\n      &quot;key_vault&quot;: false,\r\n      &quot;id&quot;: 100442,\r\n      &quot;slug&quot;: &quot;spredfns&quot;,\r\n      &quot;name&quot;: &quot;Spredfns&quot;,\r\n      &quot;**provider**&quot;: {\r\n        &quot;icons&quot;: {\r\n          &quot;first_letter&quot;: &quot;s&quot;,\r\n          &quot;color_code&quot;: &quot;65c6bb&quot;,\r\n          &quot;large&quot;: &quot;https://assetsedfast_lg.png&quot;,\r\n          &quot;small&quot;: &quot;https://assets.dfast_sm.png&quot;\r\n        },\r\n        &quot;**capabilities**&quot;: {\r\n          &quot;has_ou&quot;: false,\r\n          &quot;has_import&quot;: false,\r\n          &quot;has_password_reset&quot;: false,\r\n          &quot;has_provision&quot;: false,\r\n          &quot;has_saml&quot;: false,\r\n          &quot;has_sync&quot;: false,\r\n          &quot;unsupported_browsers&quot;: [],\r\n          &quot;services&quot;: &quot;authenticatab\r\n    \r\nI am having trouble parsing the category text headers like capabilities and provider.I can only get requires_mfa_code and id and name.My code is below:\r\n\r\n   \r\n\r\n     curl  https://www.example.com/api/v2/organizations/78762/installations?page=1 &gt; test.txt; cat test.txt | jq &#39;.[] | &quot;\\(.id) \\(.name)&quot; &#39;\r\n\r\nCan anyone please assist? I would like to get **provider/color_code**\r\n\r\nGoal is below\r\n\r\n    id     slug     provider color_code\r\n    100442 spredfns    65c6bb\r\n\r\n",
        "link": "https://stackoverflow.com/questions/45004253/jq-converting-some-json-keys-into-csv",
        "title": "jq converting some json keys into csv"
    },
    {
        "tags": [
            "bash",
            "sed",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1852014,
                    "reputation": 24882,
                    "user_id": 1678362,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/8ba023d18099cde022b9e4394d5714c0?s=256&d=identicon&r=PG",
                    "display_name": "Aaron",
                    "link": "https://stackoverflow.com/users/1678362/aaron"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1499678567,
                "post_id": 45008223,
                "comment_id": 76989947,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1499678571,
                "post_id": 45008223,
                "comment_id": 76989950,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1499679470,
                "last_edit_date": 1499679470,
                "creation_date": 1499679371,
                "answer_id": 45008558,
                "question_id": 45008223,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "[Download and install jq](https://stedolan.github.io/jq/download/) - A command line `JSON` syntax aware parser which lets you modify `.json` files. For your example in question. \r\n\r\n    tmp=$(mktemp)    \r\n    jq &#39;.scripts.start = &quot;webpack-dev-server&quot; | del(.scripts.test)&#39; input.json &gt; &quot;$tmp&quot; &amp;&amp; mv &quot;$tmp&quot; input.json\r\n\r\nwill produce the final `.json` file as\r\n\r\n    {\r\n      &quot;name&quot;: &quot;test&quot;,\r\n      &quot;version&quot;: &quot;1.0.0&quot;,\r\n      &quot;description&quot;: &quot;&quot;,\r\n      &quot;main&quot;: &quot;index.js&quot;,\r\n      &quot;scripts&quot;: {\r\n        &quot;start&quot;: &quot;webpack-dev-server&quot;\r\n      },\r\n      &quot;author&quot;: &quot;&quot;,\r\n      &quot;license&quot;: &quot;ISC&quot;,\r\n      &quot;dependencies&quot;: {\r\n        &quot;nodemon&quot;: &quot;^1.11.0&quot;,\r\n        &quot;path&quot;: &quot;^0.12.7&quot;,\r\n        &quot;react&quot;: &quot;^15.6.1&quot;,\r\n        &quot;webpack&quot;: &quot;^3.1.0&quot;,\r\n        &quot;webpack-dev-server&quot;: &quot;^2.5.1&quot;\r\n      }\r\n    }\r\n\r\nYou can play with `jq` in a free-playground developed at [jqplay.org](https://jqplay.org/s/XtbyoZYr8K).\r\n\r\n",
                "title": "Replace an entire line in package.json using bash tools"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1499679526,
                "creation_date": 1499679526,
                "answer_id": 45008611,
                "question_id": 45008223,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "    $ sed -ie &#39;s/\\&quot;test\\&quot;: \\&quot;echo \\\\\\&quot;Error: no test specified\\\\\\&quot; &amp;&amp; exit 1\\&quot;/\\&quot;start\\&quot;: \\&quot;webpack-dev-server\\&quot;/g&#39; file\r\n    $ cat file\r\n    {\r\n      &quot;name&quot;: &quot;test&quot;,\r\n      &quot;version&quot;: &quot;1.0.0&quot;,\r\n      &quot;description&quot;: &quot;&quot;,\r\n      &quot;main&quot;: &quot;index.js&quot;,\r\n      &quot;scripts&quot;: {\r\n        &quot;start&quot;: &quot;webpack-dev-server&quot;\r\n      },\r\n      &quot;author&quot;: &quot;&quot;,\r\n      &quot;license&quot;: &quot;ISC&quot;,\r\n      &quot;dependencies&quot;: {\r\n        &quot;nodemon&quot;: &quot;^1.11.0&quot;,\r\n        &quot;path&quot;: &quot;^0.12.7&quot;,\r\n        &quot;react&quot;: &quot;^15.6.1&quot;,\r\n        &quot;webpack&quot;: &quot;^3.1.0&quot;,\r\n        &quot;webpack-dev-server&quot;: &quot;^2.5.1&quot;\r\n      }\r\n    }",
                "title": "Replace an entire line in package.json using bash tools"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1499679982,
                "creation_date": 1499679982,
                "answer_id": 45008769,
                "question_id": 45008223,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Another option using `jq` would be to simply overwrite the value of `.scripts`:\r\n\r\n    jq &#39;.scripts = { start: &quot;webpack-dev-server&quot; }&#39; file.json",
                "title": "Replace an entire line in package.json using bash tools"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 3,
        "last_activity_date": 1533920455,
        "creation_date": 1499678452,
        "last_edit_date": 1533920455,
        "question_id": 45008223,
        "body_markdown": "I am working on a command line that will install every required node for a nodejs project.\r\n\r\nCurrently you can do:\r\n\r\n    sudo gen-web-app express\r\n\r\nand this will genereate everything you need to start developing for expressjs.\r\n\r\nI&#39;m working now on\r\n    \r\n    sudo gen-web-app reactjs\r\n\r\nEverything is working except I have to go manually in the package.json and add the startup script to the file.\r\nI know this is possible using SED In BASH, but I need a little help using sed.\r\n\r\nThis is the file:\r\n\r\n    {\r\n      &quot;name&quot;: &quot;test&quot;,\r\n      &quot;version&quot;: &quot;1.0.0&quot;,\r\n      &quot;description&quot;: &quot;&quot;,\r\n      &quot;main&quot;: &quot;index.js&quot;,\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;author&quot;: &quot;&quot;,\r\n      &quot;license&quot;: &quot;ISC&quot;,\r\n      &quot;dependencies&quot;: {\r\n        &quot;nodemon&quot;: &quot;^1.11.0&quot;,\r\n        &quot;path&quot;: &quot;^0.12.7&quot;,\r\n        &quot;react&quot;: &quot;^15.6.1&quot;,\r\n        &quot;webpack&quot;: &quot;^3.1.0&quot;,\r\n        &quot;webpack-dev-server&quot;: &quot;^2.5.1&quot;\r\n      }\r\n    }\r\n\r\nI want to replace the following, but I would appreciate a little help :)\r\n\r\n    &quot;test&quot;: &quot;echo \\&quot;Error: no test specified\\&quot; &amp;&amp; exit 1&quot;\r\n\r\nwith\r\n\r\n    &quot;start&quot;: &quot;webpack-dev-server&quot;",
        "link": "https://stackoverflow.com/questions/45008223/replace-an-entire-line-in-package-json-using-bash-tools",
        "title": "Replace an entire line in package.json using bash tools"
    },
    {
        "tags": [
            "json",
            "key",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3842961,
                    "reputation": 93062,
                    "user_id": 3185459,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/u8EuP.jpg?s=256",
                    "display_name": "RomanPerekhrest",
                    "link": "https://stackoverflow.com/users/3185459/romanperekhrest"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1499723641,
                "post_id": 45022178,
                "comment_id": 77018737,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 10758007,
                    "reputation": 19,
                    "user_id": 7915361,
                    "user_type": "registered",
                    "accept_rate": 0,
                    "profile_image": "https://www.gravatar.com/avatar/fc833ed92e3dbe2507e106071793e159?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "user7915361",
                    "link": "https://stackoverflow.com/users/7915361/user7915361"
                },
                "reply_to_user": {
                    "account_id": 3842961,
                    "reputation": 93062,
                    "user_id": 3185459,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/u8EuP.jpg?s=256",
                    "display_name": "RomanPerekhrest",
                    "link": "https://stackoverflow.com/users/3185459/romanperekhrest"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1499723976,
                "post_id": 45022178,
                "comment_id": 77018845,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1499724065,
                "creation_date": 1499724065,
                "answer_id": 45022328,
                "question_id": 45022178,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "1. The sample input is not JSON, which does not allow fancy quotes to be used as string delimiters.  The following assumes the input has been corrected.\r\n\r\n2. The value of `.other` is a JSON string; you can use `fromjson` to change the string to a JSON object.\r\n\r\n3. `sort|unique` is redundant, as `unique` first sorts its input.\r\n\r\nPutting it all together:\r\n\r\n    $ jq  &#39;.other | fromjson | keys_unsorted | unique&#39; input.json\r\n    [\r\n      &quot;client_timestamp&quot;,\r\n      &quot;ios_page_index&quot;\r\n    ]\r\n    [\r\n      &quot;client_timestamp&quot;,\r\n      &quot;ios_index_path_row&quot;,\r\n      &quot;ios_page_index&quot;\r\n    ]\r\n\r\n(Using `keys_unsorted` saves one sort operation.)",
                "title": "How do I print the keyS from a json object using JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1499724065,
        "creation_date": 1499723288,
        "last_edit_date": 1499723617,
        "question_id": 45022178,
        "body_markdown": "Sample input\r\n\r\n\r\n    {\r\n     “event_timestamp”: “2016-03-16 13:19:53 UTC”,\r\n     “query”: “Plagiarism”,\r\n     “search_session_id”: “3605862756e95d26ac180&quot;,\r\n     “version”: “0.0.2&quot;,\r\n     “other”: “{\\“client_timestamp\\“:1458134393.932,\\&quot;ios_page_index\\&quot;:3}“,\r\n     “action”: “HIT_BOUNCE”\r\n    }\r\n    \r\n    {\r\n     “event_timestamp”: “2016-03-16 13:19:53 UTC”,\r\n     “query”: “Plagiarism”,\r\n     “search_session_id”: “3605862756e95d26ac180&quot;,\r\n     “version”: “0.0.2&quot;,\r\n     “other”:“{\\“client_timestamp\\“:1458134393.932,\\&quot;ios_page_index\\&quot;:3,\\&quot;ios_index_path_row\\&quot;:1}“,\r\n     “action”: “HIT_BOUNCE”\r\n    }\r\n\r\nI&#39;d like to output the unique key name in &quot;other&quot; field\r\n\r\n&quot;client_timestamp,\r\n\r\nios_page_index,\r\n\r\nios_index_path_row &quot;\r\n\r\n\r\n\r\nTried the following command but doesn&#39;t work so far\r\n\r\ncat sampleexample.json | jq &#39;.other|keys&#39; | sort | uniq &gt; other.json\r\n\r\nThanks in advance\r\n",
        "link": "https://stackoverflow.com/questions/45022178/how-do-i-print-the-keys-from-a-json-object-using-jq",
        "title": "How do I print the keyS from a json object using JQ"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1499750776,
                "creation_date": 1499750776,
                "answer_id": 45026026,
                "question_id": 45025624,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The following jq filter will produce the desired output if given input that is very similar to the example, but it is far from robust and glosses over some details that are unclear from the problem description. However, it should be easy enough to modify the filter in accordance with more precise specifications: \r\n\r\n    . as $in\r\n    | reduce paths(type == &quot;string&quot; and test(&quot;/&quot;)) as $path ({};\r\n        ($in|getpath($path)) as $x\r\n        | if ($path[-1]|type) == &quot;string&quot;\r\n          then .[$path[-1]] = $x\r\n          else .[$path[-2]|tostring] += [$x]\r\n          end )\r\n    | {binding: .}\r\n\r\nOutput:\r\n\r\n    {\r\n      &quot;binding&quot;: {\r\n        &quot;wf.example.input1&quot;: &quot;/path/to/file1&quot;,\r\n        &quot;wf.example.input3&quot;: [\r\n          &quot;/path/to/file3&quot;,\r\n          &quot;/path/to/file4&quot;\r\n        ]\r\n      }\r\n    }\r\n\r\n",
                "title": "Need to get all key value pairs from a JSON containing a specific character &#39;/&#39;"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1499750776,
        "creation_date": 1499748542,
        "last_edit_date": 1499749034,
        "question_id": 45025624,
        "body_markdown": "I have a specific json content for which I need to get all keys which contains the character / in their values.\r\n\r\n**JSON**\r\n\r\n    { &quot;dig&quot;:  &quot;sha256:d2aae00e4bc6424d8a6ae7639d41cfff8c5aa56fc6f573e64552a62f35b6293e&quot;,\r\n     &quot;name&quot;: &quot;example&quot;,\r\n     &quot;binding&quot;: { \r\n       &quot;wf.example.input1&quot;: &quot;/path/to/file1&quot;,\r\n       &quot;wf.example.input2&quot;: &quot;hello&quot;,\r\n       &quot;wf.example.input3&quot;:\r\n         [&quot;/path/to/file3&quot;,\r\n          &quot;/path/to/file4&quot;],\r\n       &quot;wf.example.input4&quot;: 44\r\n      }\r\n    }\r\n\r\nI know I can get all the keys containing file path or array of file paths using query `jq &#39;paths(type == &quot;string&quot; and contains(&quot;/&quot;))&#39;`. This would give me an output like:\r\n\r\n    [ &quot;binding&quot;, &quot;wf.example.input1&quot; ]\r\n    [ &quot;binding&quot;, &quot;wf.example.input3&quot;, 0]\r\n    [ &quot;binding&quot;, &quot;wf.example.input3&quot;, 1 ]\r\n\r\n\r\nNow that i have all the elements that contains some file paths as their values, is there a way to fetch both key and value for the same and then store them as another JSON? For example, in JSON mentioned for this question, I need to get the output as another JSON containing all the matched paths. My output JSON should look something like below.\r\n\r\n     { &quot;binding&quot;:\r\n       { &quot;wf.example.input1&quot;: &quot;/path/to/file1&quot;,\r\n         &quot;wf.example.input3&quot;: [ &quot;/path/to/file3&quot;, &quot;/path/to/file4&quot; ] \r\n       }\r\n     }",
        "link": "https://stackoverflow.com/questions/45025624/need-to-get-all-key-value-pairs-from-a-json-containing-a-specific-character",
        "title": "Need to get all key value pairs from a JSON containing a specific character &#39;/&#39;"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1899047,
                    "reputation": 1692,
                    "user_id": 1715318,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/89c64e752727d5c7363fdd1632c2de29?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Mosd",
                    "link": "https://stackoverflow.com/users/1715318/mosd"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1499757727,
                "post_id": 45027469,
                "comment_id": 77029807,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1499759448,
                "last_edit_date": 1499759448,
                "creation_date": 1499758694,
                "answer_id": 45028256,
                "question_id": 45027469,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Convert it to entries first, then you could build up your outputs for the keys and values.  For arrays of values, just go through all the values in the array, otherwise the value itself.\r\n\r\n    $ jq -r &#39;to_entries[] | &quot;name:\\(.key|tojson), value:\\(.value|(arrays[]//.)|tojson)&quot;&#39; input.json\r\n    name:&quot;wf.example.input1&quot;, value:&quot;/path/to/file1&quot;\r\n    name:&quot;wf.example.input3&quot;, value:&quot;/path/to/file3&quot;\r\n    name:&quot;wf.example.input3&quot;, value:&quot;/path/to/file4&quot;\r\n\r\n",
                "title": "Get key value mapping from a JSON with random string appended to them"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1499759448,
        "creation_date": 1499756222,
        "question_id": 45027469,
        "body_markdown": "I have a JSON string as seen below.\r\n\r\n**JSON**\r\n\r\n    {\r\n      &quot;wf.example.input1&quot;: &quot;/path/to/file1&quot;,\r\n      &quot;wf.example.input3&quot;: [\r\n        &quot;/path/to/file3&quot;,\r\n        &quot;/path/to/file4&quot;\r\n      ]\r\n    }\r\n\r\nI need a `list` output in below format.\r\n\r\n    name:&quot;wf.example.input1&quot;, value:&quot;/path/to/file1&quot;\r\n    name:&quot;wf.example.input3&quot;, value:&quot;/path/to/file3&quot;\r\n    name:&quot;wf.example.input3&quot;, value:&quot;/path/to/file4&quot;\r\n\r\nI know I can get all the keys using `jq &#39;keys&#39;` and also all the values can be fetched using `jq &#39;flatten&#39;`. But this doesn&#39;t give a list with all the mappings I need. So how do I get my desired output list mapping?",
        "link": "https://stackoverflow.com/questions/45027469/get-key-value-mapping-from-a-json-with-random-string-appended-to-them",
        "title": "Get key value mapping from a JSON with random string appended to them"
    },
    {
        "tags": [
            "json",
            "command-line",
            "nested",
            "key",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1499801128,
                "last_edit_date": 1499801128,
                "creation_date": 1499796320,
                "answer_id": 45041694,
                "question_id": 45034898,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The following filter produces the results you want, as shown below:\r\n\r\n    .paths\r\n    | to_entries\r\n    | map( .key as $path\r\n           | ( .value | to_entries[]\r\n               | if .key == &quot;get&quot; then &quot;GET&quot;\r\n                 elif .key == &quot;post&quot; then &quot;POST&quot; \r\n                 else empty end ) as $verb\r\n           | $verb + &quot; &quot; + $path )\r\n       \r\n\r\nOutput:\r\n\r\n    [\r\n      &quot;GET /pets&quot;,\r\n      &quot;POST /pets&quot;,\r\n      &quot;GET /pets/{petId}&quot;\r\n    ]\r\n\r\nYou may want to include more &quot;verbs&quot;, or handle the verbs programmatically, e.g.\r\n\r\n    .paths\r\n    | to_entries\r\n    | map(( .value | to_entries[] | .key | ascii_upcase ) + &quot; &quot; + .key)\r\n\r\n### Discussion\r\nThe key to the solution here is `to_entries`, which produces an array of objects of the form {&quot;key&quot;: _, &quot;value&quot;: _ }.  Apart from `map`, which here saves having to unpack the array and then repack it, the rest is syntax :-)\r\n\r\n",
                "title": "how to use jq to flatten nested keys in the json"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1499801401,
        "creation_date": 1499776746,
        "last_edit_date": 1499801401,
        "question_id": 45034898,
        "body_markdown": "I am currently trying to process below json using jq commandline\r\n\r\n    cat api-docs.json  | jq &#39;.paths&#39;\r\n\r\n    {\r\n    ...\r\n    ...\r\n\r\n      &quot;paths&quot;: {\r\n        &quot;/pets&quot;: {\r\n             &quot;get&quot;: {\r\n    ...\r\n    ...\r\n            &quot;post&quot;: {\r\n    ...\r\n    ...\r\n        &quot;/pets/{petId}&quot;: {\r\n             &quot;get&quot;: {\r\n    ...\r\n\r\n\r\nhttps://jqplay.org/s/GV2zMjbCWK \r\n\r\n\r\nI need a flattened info from swagger spec above\r\n\r\n    [ &quot;GET /pets&quot;, &quot;POST /pets&quot;, &quot;GET /pets/{petId}&quot; ]\r\n\r\n\r\nis this even possible with `jq` command ?\r\n\r\nwith below I get each value independently \r\n\r\n    .paths|{k:keys,v:map(keys)}\r\n\r\nBut what I need is a way to combine keys at nested level to get above result i.e array of  &quot;METHOD /PATH&quot;\r\n",
        "link": "https://stackoverflow.com/questions/45034898/how-to-use-jq-to-flatten-nested-keys-in-the-json",
        "title": "how to use jq to flatten nested keys in the json"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6527925,
                    "reputation": 91937,
                    "user_id": 7111561,
                    "user_type": "registered",
                    "accept_rate": 54,
                    "profile_image": "https://i.sstatic.net/SNnq7.png?s=256",
                    "display_name": "derHugo",
                    "link": "https://stackoverflow.com/users/7111561/derhugo"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1499789441,
                "post_id": 45039519,
                "comment_id": 77053383,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1647365821,
                "last_edit_date": 1647365821,
                "creation_date": 1499790587,
                "answer_id": 45040033,
                "question_id": 45039519,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You mean this?\r\n\r\n    jq -r &#39;.[].Generated&#39; file.json | while read -r val ; do\r\n        do_something &quot;${val}&quot;\r\n    done",
                "title": "How can I loop through my json with Bash"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1499803981,
                "last_edit_date": 1499803981,
                "creation_date": 1499791669,
                "answer_id": 45040362,
                "question_id": 45039519,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "If you want to use bash to loop through the JSON objects satisfying the condition, consider:\r\n\r\n    while read -r val ; do\r\n        echo &quot;${val}&quot;\r\n    done &lt; &lt;(jq -rc &#39;.[] | select(.Generated == &quot;@logon&quot;)&#39; file.json)\r\n\r\nOutput:\r\n\r\n    {&quot;Generated&quot;:&quot;@logon&quot;,&quot;Value&quot;:&quot;Unknown&quot;,&quot;LastRun&quot;:&quot;Never&quot;}\r\n    {&quot;Generated&quot;:&quot;@logon&quot;,&quot;Value&quot;:&quot;Unknown&quot;,&quot;LastRun&quot;:&quot;Never&quot;}\r\n\r\nThe -c option is needed if this approach to looping in bash is adopted.\r\n\r\n\r\nOf course it would be preferable to do as much processing of JSON objects within jq as possible.\r\n\r\nIf you want to loop through the top-level key-value pairs, then you will probably want to use `to_entries` or maybe `with_entries`.  For example, to print the keys of objects with .Generated == &quot;@logon&quot;:\r\n\r\n\r\n    $ jq -r &#39;to_entries[] | select(.value.Generated == &quot;@logon&quot;) | .key&#39; input.json\r\n    version\r\n    hostname\r\n\r\nNotice - no bash loop needed!\r\n    \r\n\r\n\r\n\r\n\r\n",
                "title": "How can I loop through my json with Bash"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1647365821,
        "creation_date": 1499789029,
        "question_id": 45039519,
        "body_markdown": "I have a json file which looks like this:\r\n\r\n    {\r\n      &quot;version&quot;: {\r\n        &quot;Generated&quot;: &quot;@logon&quot;,\r\n        &quot;Value&quot;: &quot;Unknown&quot;,\r\n        &quot;LastRun&quot;: &quot;Never&quot;\r\n      },\r\n      &quot;hostname&quot;: {\r\n        &quot;Generated&quot;: &quot;@logon&quot;,\r\n        &quot;Value&quot;: &quot;Unknown&quot;,\r\n        &quot;LastRun&quot;: &quot;Never&quot;\r\n      },\r\n      &quot;updates&quot;: {\r\n        &quot;Generated&quot;: &quot;@boot&quot;,\r\n        &quot;Value&quot;: &quot;Unknown&quot;,\r\n        &quot;LastRun&quot;: &quot;Never&quot;\r\n      }\r\n    }\r\n\r\nHow can I loop through each element in the json file in Bash which has as &quot;Generated&quot; value &quot;@logon&quot;? I guess I should use jq, but I didn&#39;t manage to find the right filter.",
        "link": "https://stackoverflow.com/questions/45039519/how-can-i-loop-through-my-json-with-bash",
        "title": "How can I loop through my json with Bash"
    },
    {
        "tags": [
            "javascript",
            "json",
            "bash",
            "shell",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1499793560,
                "last_edit_date": 1499793560,
                "creation_date": 1499793232,
                "answer_id": 45040831,
                "question_id": 45040597,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "using NodeJS I would write something like this:\r\n\r\n\r\n    const fs = require(&#39;fs&#39;);\r\n    let args = process.argv.map(val=&gt;val));\r\n    let contents = fs.readFileSync(args[0]);\r\n    \r\n    let obj = JSON.parse(contents);\r\n    \r\n    const proc = (obj, append)=&gt;{\r\n        for (prop in obj)\r\n        {\r\n            let p = obj[prop];\r\n            if (p.constructor!=Object)\r\n                continue;\r\n            if (append)\r\n            {\r\n                p.removable = true;\r\n                p.appendable = true;\r\n            }\r\n            proc(p, prop==&#39;properties&#39;);\r\n        }\r\n    };\r\n    \r\n    console.log(JSON.stringify(proc(obj), null, 2));\r\n\r\nAnd then in bash do:\r\n\r\n    find -name &#39;*\\.json&#39; -exec &#39;node proc.js {} &gt; {}.new&#39;\r\n\r\nI didn&#39;t test anything, everything is from my head, but for starting point should be good enough.",
                "title": "Append multiple lines after a certain pattern to several JSON files"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1499798265,
                "creation_date": 1499798265,
                "answer_id": 45042243,
                "question_id": 45040597,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Given that you want to apply the update to all objects that have a key named &quot;properties&quot;, wherever they occur, I&#39;d be inclined to use `walk/1`. In any case, to make things clearer and maybe easier, it will be helpful to define a helper function that will apply the update if the input is of the right type:\r\n\r\n    def update(obj):\r\n      if type == &quot;object&quot; and has(&quot;properties&quot;)\r\n      then .properties |= with_entries( .value += obj )\r\n      else .\r\n      end;\r\n\r\nUsing `walk/1`, the solution is now trivial:\r\n\r\n    walk( update({removable: true, appendable: true}) )\r\n\r\n### Robustification\r\nIt might be prudent to change the &quot;then&quot; line above to:\r\n\r\n    then .properties |= \r\n      with_entries( if .value | type == &quot;object&quot;\r\n                    then .value += obj\r\n                    else . end)\r\n\r\n",
                "title": "Append multiple lines after a certain pattern to several JSON files"
            }
        ],
        "is_answered": false,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1499798265,
        "creation_date": 1499792419,
        "last_edit_date": 1499793054,
        "question_id": 45040597,
        "body_markdown": "I have several JSON files that look like this\r\n\r\n    {\r\n    &quot;$schema&quot;: &quot;someURL&quot;,\r\n      &quot;id&quot;: &quot;someURL&quot;,\r\n      &quot;type&quot;: &quot;object&quot;,\r\n      &quot;properties&quot;: {\r\n        &quot;copyright&quot;: {\r\n          &quot;id&quot;: &quot;someURL&quot;,\r\n          &quot;type&quot;: &quot;object&quot;,\r\n          &quot;description&quot;: &quot;Setup for copyright link&quot;,\r\n          &quot;properties&quot;: {\r\n            &quot;translation&quot;: {\r\n              &quot;id&quot;: &quot;someURL&quot;,\r\n              &quot;type&quot;: &quot;string&quot;,\r\n              &quot;description&quot;: &quot;someString&quot;\r\n            },\r\n            &quot;url&quot;: {\r\n              &quot;id&quot;: &quot;someURL&quot;,\r\n              &quot;type&quot;: &quot;string&quot;,\r\n              &quot;description&quot;: &quot;someString&quot;\r\n            }\r\n          }...\r\nwhat I need to do is add a `removable` and `appendable` attribute to each item inside every instance of `properties` and set them to true. so the output should look like this:\r\n\r\n    {\r\n        &quot;$schema&quot;: &quot;someURL&quot;,\r\n          &quot;id&quot;: &quot;someURL&quot;,\r\n          &quot;type&quot;: &quot;object&quot;,\r\n          &quot;properties&quot;: {\r\n            &quot;copyright&quot;: {\r\n              &quot;removable&quot;: true,\r\n              &quot;appendable&quot;: true,\r\n              &quot;id&quot;: &quot;someURL&quot;,\r\n              &quot;type&quot;: &quot;object&quot;,\r\n              &quot;description&quot;: &quot;Setup for copyright link&quot;,\r\n              &quot;properties&quot;: {\r\n                &quot;translation&quot;: {\r\n                  &quot;removable&quot;: true,\r\n                  &quot;appendable&quot;: true,\r\n                  &quot;id&quot;: &quot;someURL&quot;,\r\n                  &quot;type&quot;: &quot;string&quot;,\r\n                  &quot;description&quot;: &quot;someString&quot;\r\n                },\r\n                &quot;url&quot;: {\r\n                  &quot;removable&quot;: true,\r\n                  &quot;appendable&quot;: true,\r\n                  &quot;id&quot;: &quot;someURL&quot;,\r\n                  &quot;type&quot;: &quot;string&quot;,\r\n                  &quot;description&quot;: &quot;someString&quot;\r\n                }\r\n              }...\r\n\r\nIs there a way to automate this? as in write a script that automatically adds these fields right below each item in properties?",
        "link": "https://stackoverflow.com/questions/45040597/append-multiple-lines-after-a-certain-pattern-to-several-json-files",
        "title": "Append multiple lines after a certain pattern to several JSON files"
    },
    {
        "tags": [
            "json",
            "windows",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1499806623,
                "last_edit_date": 1499806623,
                "creation_date": 1499806527,
                "answer_id": 45044304,
                "question_id": 45043970,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "As the error text says, you are running into Windows cmd shell quoting issues.  When you get such an error message, try echoing your command line (minus any redirections).\r\n\r\nOne workaround is to put the jq command text into a file, and invoke jq with the -f option.\r\n\r\nIf you want to avoid the -f option, try something like:\r\n\r\n    jq &quot;.Mappings.RegionMap.\\&quot;us-east-1\\&quot;.AMI&quot;\r\n\r\n(For older versions of jq: jq &quot;.Mappings.RegionMap | .[\\&quot;us-east-1\\&quot;].AMI&quot; )\r\n\r\n\r\n\r\n",
                "title": "Unable to extract value of key from a json file using jq on windows 64 bit OS"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1499806623,
        "creation_date": 1499805125,
        "last_edit_date": 1499805599,
        "question_id": 45043970,
        "body_markdown": "My `json` file is as follows\r\n\r\n    { \r\n    &quot;Mappings&quot; : {\r\n\t &quot;RegionMap&quot; : {\r\n\t   &quot;us-east-1&quot;      : { &quot;AMI&quot; : &quot;xxxxxx&quot; },\r\n\t   &quot;us-east-2&quot;      : { &quot;AMI&quot; : &quot;&quot; },\r\n\t   &quot;us-west-1&quot;      : { &quot;AMI&quot; : &quot;&quot; },\r\n\t   &quot;us-west-2&quot;      : { &quot;AMI&quot; : &quot;&quot; },\r\n\t   &quot;ca-central-1&quot;   : { &quot;AMI&quot; : &quot;&quot; },\r\n\t   &quot;eu-central-1&quot;   : { &quot;AMI&quot; : &quot;&quot; },\r\n\t   &quot;eu-west-1&quot;      : { &quot;AMI&quot; : &quot;&quot; },\r\n\t   &quot;eu-west-2&quot;      : { &quot;AMI&quot; : &quot;&quot; },\r\n\t   &quot;ap-south-1&quot; \t: { &quot;AMI&quot; : &quot;&quot; },\r\n\t   &quot;ap-southeast-1&quot; : { &quot;AMI&quot; : &quot;&quot; },\r\n\t   &quot;ap-southeast-2&quot; : { &quot;AMI&quot; : &quot;&quot; },\r\n\t   &quot;ap-northeast-1&quot; : { &quot;AMI&quot; : &quot;&quot; },\r\n\t   &quot;ap-northeast-2&quot; : { &quot;AMI&quot; : &quot;&quot; },\r\n\t   &quot;sa-east-1&quot;      : { &quot;AMI&quot; : &quot;&quot; }       \r\n\t   }\r\n      }\r\n     }\r\n\r\nI am trying to extract the value of `us-east-1` key. In the [jq playground][2], I was able to extract the value using the the following `filter`\r\n\r\n    .Mappings.RegionMap.&quot;us-east-1&quot;.AMI\r\n\r\nBut when try to run this filter using [jq][1] on my windows machine using the `command prompt`\r\n    \r\n     jq &#39;.Mappings.RegionMap.&quot;us-east-1&quot;.AMI&#39; &lt;filename&gt;\r\n\r\nI am getting this `error`\r\n    \r\n    jq: error: syntax error, unexpected INVALID_CHARACTER, expecting \r\n    $end (Windows cmd shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n    &#39;.Mappings.RegionMap.us-east-1.AMI&#39;\r\n    &#39;jq: 1 compile error\r\n\r\nI am using `jq version 1.5` on `Windows` Machine which has `64 bit OS`. \r\n\r\nCan somebody let me know as to what I am doing wrong?\r\n\r\n\r\n  [1]: https://github.com/stedolan/jq/wiki/Installation#windows-with-choco\r\n  [2]: https://jqplay.org/",
        "link": "https://stackoverflow.com/questions/45043970/unable-to-extract-value-of-key-from-a-json-file-using-jq-on-windows-64-bit-os",
        "title": "Unable to extract value of key from a json file using jq on windows 64 bit OS"
    },
    {
        "tags": [
            "json",
            "cygwin",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1499891426,
                "last_edit_date": 1499891426,
                "creation_date": 1499874206,
                "answer_id": 45062250,
                "question_id": 45061585,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The first issue that makes your input json invalid is this line (the 3rd line):\r\n\r\n    ...\r\n    &quot;Password&quot;:&quot;yyyyy&quot;  &lt;----\r\n    ...\r\nIt should be followed with `,`.&lt;br&gt;\r\n\r\nAfter fixing that, you can easily update the needed property value:\r\n\r\n    jq &#39;.Mappings.RegionMap[&quot;us-east-1&quot;].AMI = &quot;abcd&quot;&#39; oldfile &gt; newfile\r\n\r\n\r\n----------\r\n`newfile` contents:\r\n\r\n    {\r\n      &quot;Name&quot;: &quot;SA&quot;,\r\n      &quot;Password&quot;: &quot;yyyyy&quot;,\r\n      &quot;Mappings&quot;: {\r\n        &quot;RegionMap&quot;: {\r\n          &quot;us-east-1&quot;: {\r\n            &quot;AMI&quot;: &quot;abcd&quot;\r\n          },\r\n          &quot;us-east-2&quot;: {\r\n            &quot;AMI&quot;: &quot;&quot;\r\n          },\r\n          &quot;us-west-1&quot;: {\r\n            &quot;AMI&quot;: &quot;&quot;\r\n          },\r\n          &quot;us-west-2&quot;: {\r\n            &quot;AMI&quot;: &quot;&quot;\r\n          },\r\n          &quot;ca-central-1&quot;: {\r\n            &quot;AMI&quot;: &quot;&quot;\r\n          },\r\n          &quot;eu-central-1&quot;: {\r\n            &quot;AMI&quot;: &quot;&quot;\r\n          },\r\n          &quot;eu-west-1&quot;: {\r\n            &quot;AMI&quot;: &quot;&quot;\r\n          },\r\n          &quot;eu-west-2&quot;: {\r\n            &quot;AMI&quot;: &quot;&quot;\r\n          },\r\n          &quot;ap-south-1&quot;: {\r\n            &quot;AMI&quot;: &quot;&quot;\r\n          },\r\n          &quot;ap-southeast-1&quot;: {\r\n            &quot;AMI&quot;: &quot;&quot;\r\n          },\r\n          &quot;ap-southeast-2&quot;: {\r\n            &quot;AMI&quot;: &quot;&quot;\r\n          },\r\n          &quot;ap-northeast-1&quot;: {\r\n            &quot;AMI&quot;: &quot;&quot;\r\n          },\r\n          &quot;ap-northeast-2&quot;: {\r\n            &quot;AMI&quot;: &quot;&quot;\r\n          },\r\n          &quot;sa-east-1&quot;: {\r\n            &quot;AMI&quot;: &quot;&quot;\r\n          }\r\n        }\r\n      }\r\n    }\r\n\r\n",
                "title": "Update contents of file via jq using redirection operator"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1499891426,
        "creation_date": 1499872376,
        "last_edit_date": 1499874913,
        "question_id": 45061585,
        "body_markdown": "My `JSON` input file is as follows:\r\n\r\n    {\r\n    &quot;Name&quot;:&quot;SA&quot;,\r\n    &quot;Password&quot;:&quot;yyyyy&quot;,\r\n    &quot;Mappings&quot; : {\r\n    &quot;RegionMap&quot; : {\r\n       &quot;us-east-1&quot;      : { &quot;AMI&quot; : &quot;xxxxxx&quot; },\r\n       &quot;us-east-2&quot;      : { &quot;AMI&quot; : &quot;&quot; },\r\n       &quot;us-west-1&quot;      : { &quot;AMI&quot; : &quot;&quot; },\r\n       &quot;us-west-2&quot;      : { &quot;AMI&quot; : &quot;&quot; },\r\n       &quot;ca-central-1&quot;   : { &quot;AMI&quot; : &quot;&quot; },\r\n       &quot;eu-central-1&quot;   : { &quot;AMI&quot; : &quot;&quot; },\r\n       &quot;eu-west-1&quot;      : { &quot;AMI&quot; : &quot;&quot; },\r\n       &quot;eu-west-2&quot;      : { &quot;AMI&quot; : &quot;&quot; },\r\n       &quot;ap-south-1&quot;     : { &quot;AMI&quot; : &quot;&quot; },\r\n       &quot;ap-southeast-1&quot; : { &quot;AMI&quot; : &quot;&quot; },\r\n       &quot;ap-southeast-2&quot; : { &quot;AMI&quot; : &quot;&quot; },\r\n       &quot;ap-northeast-1&quot; : { &quot;AMI&quot; : &quot;&quot; },\r\n       &quot;ap-northeast-2&quot; : { &quot;AMI&quot; : &quot;&quot; },\r\n       &quot;sa-east-1&quot;      : { &quot;AMI&quot; : &quot;&quot; }       \r\n       }\r\n     }\r\n    }\r\n\r\nMy task is to update the value of the `AMI` key of `us-east-1` in the given json file and create the updated file as new file. I am using the [jq][1] plugin with redirection operator. It has [+][2] operator which can used to `overwrite` contents in an object.\r\n\r\nMy `expected` output is \r\n\r\n    {\r\n    &quot;Name&quot;:&quot;SA&quot;,\r\n    &quot;Password&quot;:&quot;yyyyy&quot;,\r\n    &quot;Mappings&quot; : {\r\n    &quot;RegionMap&quot; : {\r\n       &quot;us-east-1&quot;      : { &quot;AMI&quot; : &quot;abcd&quot; },\r\n       &quot;us-east-2&quot;      : { &quot;AMI&quot; : &quot;&quot; },\r\n       &quot;us-west-1&quot;      : { &quot;AMI&quot; : &quot;&quot; },\r\n       &quot;us-west-2&quot;      : { &quot;AMI&quot; : &quot;&quot; },\r\n       &quot;ca-central-1&quot;   : { &quot;AMI&quot; : &quot;&quot; },\r\n       &quot;eu-central-1&quot;   : { &quot;AMI&quot; : &quot;&quot; },\r\n       &quot;eu-west-1&quot;      : { &quot;AMI&quot; : &quot;&quot; },\r\n       &quot;eu-west-2&quot;      : { &quot;AMI&quot; : &quot;&quot; },\r\n       &quot;ap-south-1&quot;     : { &quot;AMI&quot; : &quot;&quot; },\r\n       &quot;ap-southeast-1&quot; : { &quot;AMI&quot; : &quot;&quot; },\r\n       &quot;ap-southeast-2&quot; : { &quot;AMI&quot; : &quot;&quot; },\r\n       &quot;ap-northeast-1&quot; : { &quot;AMI&quot; : &quot;&quot; },\r\n       &quot;ap-northeast-2&quot; : { &quot;AMI&quot; : &quot;&quot; },\r\n       &quot;sa-east-1&quot;      : { &quot;AMI&quot; : &quot;&quot; }       \r\n       }\r\n     }\r\n    }\r\n\r\n\r\nMy current command is not providing the expected output and its as follows:\r\n\r\n    jq &#39;.Mappings.RegionMap + { &quot;us-east-1&quot;:{&quot;AMI&quot;:&quot;abcd&quot;}}&#39; \r\n    &lt;OldfileName&gt; &gt; &lt;Newfilename&gt;\r\n\r\n\r\nCan somebody help me with achieving the expected output using redirection operator ?\r\n\r\nI am running the command on a `cygwin` environment and my [jq][1] version is `1.5` .\r\n\r\n**EDIT**\r\n\r\nAdded a commas after the Password Key\r\n\r\n  [1]: https://stedolan.github.io/jq/\r\n  [2]: https://stedolan.github.io/jq/manual/#Builtinoperatorsandfunctions",
        "link": "https://stackoverflow.com/questions/45061585/update-contents-of-file-via-jq-using-redirection-operator",
        "title": "Update contents of file via jq using redirection operator"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1499892685,
                "post_id": 45066954,
                "comment_id": 77107822,
                "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": 2,
                "creation_date": 1499892858,
                "post_id": 45066954,
                "comment_id": 77107928,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1499892945,
                "last_edit_date": 1499892945,
                "creation_date": 1499892287,
                "answer_id": 45067211,
                "question_id": 45066954,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Don&#39;t use `eval`. You could create a function to execute `curl`, for example:\r\n\r\n    get_secret_value() {\r\n        curl -s -L -H &quot;X-Vault-Token: $VAULT_TOKEN&quot; -X GET &quot;https://$VAULT_ADDR/v1/secret/$secret_path&quot;\r\n    }\r\n\r\n    secret_value=$(get_secret_value | jq --raw-output &#39;.data.value&#39;)\r\n\r\n",
                "title": "Bash/JQ - parse error: Expected separator between values at line 1, column 63"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1499892945,
        "creation_date": 1499891340,
        "question_id": 45066954,
        "body_markdown": "I&#39;m having what I suspect is a quoting error in a bash script.\r\n\r\n    SECRET_VALUE_CMD=&quot;curl -s -L -H \\&quot;X-Vault-Token: $VAULT_TOKEN\\&quot; -X GET \\&quot;https://$VAULT_ADDR/v1/secret/$secret_path\\&quot;&quot;\r\n    SECRET_VALUE_RESPONSE=$(eval $SECRET_VALUE_CMD)\r\n    SECRET_VALUE=$(echo &quot;$SECRET_VALUE_RESPONSE&quot; | jq --raw-output &#39;.data.value&#39;)\r\n\r\nWhen I execute this in my script, I get the following to stderr:\r\n\r\n    parse error: Expected separator between values at line 1, column 63\r\n\r\nand $SECRET_VALUE is blank. \r\n\r\nAn example of $SECRET_VALUE_RESPONSE is: \r\n\r\n    {&quot;request_id&quot;:&quot;XXXX-YYYY..,&quot;lease_id&quot;:&quot;&quot;,&quot;renewable&quot;:false,&quot;lease_duration&quot;:nnnnnn,&quot;data&quot;:{&quot;value&quot;:&quot;secret-value&quot;},&quot;wrap_info&quot;:null,&quot;warnings&quot;:null,&quot;auth&quot;:null}\r\n\r\nI&#39;ve tried adding escaped quotes around the parameters to eval and echo, but can&#39;t seem to find a working combination. Any help would be greatly appreciated!",
        "link": "https://stackoverflow.com/questions/45066954/bash-jq-parse-error-expected-separator-between-values-at-line-1-column-63",
        "title": "Bash/JQ - parse error: Expected separator between values at line 1, column 63"
    },
    {
        "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": 0,
                "creation_date": 1499911086,
                "post_id": 45069839,
                "comment_id": 77113461,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1499910391,
                "last_edit_date": 1499910391,
                "creation_date": 1499909787,
                "answer_id": 45070073,
                "question_id": 45069839,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "If your input contains only one JSON value, then `jq` isn&#39;t really buying you much here: all you need is to escape the few characters that are valid in JSON but that don&#39;t represent themselves in JSON strings, and you can easily do that using command-line utilities for general-purpose string processing.\r\n\r\nFor example:\r\n\r\n    perl -wpe &#39;\r\n        s/\\\\/\\\\&lt;backslash&gt;/g;\r\n        s/\\t/\\\\t/g;\r\n        s/\\n/\\\\n/g;\r\n        s/\\r/\\\\r/g;\r\n        s/&quot;/\\\\&quot;/g;\r\n        s/\\\\&lt;backslash&gt;/\\\\\\\\/g\r\n    &#39; ~/path/to/file/blah",
                "title": "How to get a formatted json string from a json object?"
            },
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1499927097,
                "last_edit_date": 1499927097,
                "creation_date": 1499911363,
                "answer_id": 45070269,
                "question_id": 45069839,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "`tojson` (or other json outputting filters) will not format the json. It will take on the usual compact form. There is a [feature request](https://github.com/stedolan/jq/issues/1360) out there for this so look out for that in a future version.\r\n\r\nYou could take advantage of jq&#39;s regular formatted output, but you&#39;ll want to stringify it. You could simulate stringifying by slurping in as raw input, the formatted output. This will read in all of the input as a single string. And since the input was just a json object, it&#39;ll produce a string representation of that object.\r\n\r\nIf you don&#39;t mind the extra jq calls, you could do this:\r\n\r\n    $ var=$(jq &#39;.&#39; input.json | jq -sR &#39;.&#39;)\r\n    $ echo &quot;$var&quot;\r\n    &quot;{\\n  \\&quot;test\\&quot;: {\\n    \\&quot;name\\&quot;: \\&quot;test\\&quot;,\\n    \\&quot;description\\&quot;: \\&quot;blah\\&quot;\\n  },\\n  \\&quot;test2\\&quot;: {\\n    \\&quot;name\\&quot;: \\&quot;test2\\&quot;,\\n    \\&quot;description\\&quot;: \\&quot;blah2\\&quot;\\n  }\\n}\\n&quot;\r\n\r\nThen of course if your input is already formatted, you could leave out the first jq call.",
                "title": "How to get a formatted json string from a json object?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 3,
        "last_activity_date": 1499958776,
        "creation_date": 1499907970,
        "last_edit_date": 1499958776,
        "question_id": 45069839,
        "body_markdown": "I&#39;m storing the output of `cat ~/path/to/file/blah | jq tojson` in a variable to be used later in a curl POST with JSON content. It works well, but it removes all line breaks. I understand line breaks are not supported in JSON, but I&#39;d like them to be replaced with `\\n` characters so when the data is used it isn&#39;t all one line.\r\n\r\nIs there a way to do this?\r\n\r\nExample:\r\n\r\n    {\r\n      &quot;test&quot;: {\r\n         &quot;name&quot;: &quot;test&quot;,\r\n         &quot;description&quot;: &quot;blah&quot;\r\n      },\r\n      &quot;test2&quot;: {\r\n         &quot;name&quot;: &quot;test2&quot;,\r\n         &quot;description&quot;: &quot;blah2&quot; \r\n      }\r\n    }\r\n\r\nbecomes\r\n\r\n    &quot;{\\&quot;test\\&quot;:{\\&quot;name\\&quot;:\\&quot;test\\&quot;,\\&quot;description\\&quot;:\\&quot;blah\\&quot;},\\&quot;test2\\&quot;:{\\&quot;name\\&quot;:\\&quot;test2\\&quot;,\\&quot;description\\&quot;:\\&quot;blah2\\&quot;}}&quot;\r\n\r\nbut I&#39;d like it to look like\r\n\r\n    {\\n  \\&quot;test\\&quot;: {\\n    \\&quot;name\\&quot;: \\&quot;test\\&quot;,\\n    \\&quot;description\\&quot;: \\&quot;blah\\&quot;\\n  },\\n  \\&quot;test2\\&quot;: {\\n    \\&quot;name\\&quot;: \\&quot;test2\\&quot;,\\n    \\&quot;description\\&quot;: \\&quot;blah2\\&quot; \\n  }\\n}\r\n\r\nI&#39;m actually only converting it to a JSON string so it is able to be posted as part of another JSON. When is it posted, I&#39;d like it to have the format it had originally which can be achieved if there are \\n characters.\r\n\r\nI can do this manually by doing \r\n\r\n`cat file | sed -E &#39;:a;N;$!ba;s/\\r{0,1}\\n/\\\\n/g&#39; | sed &#39;s/\\&quot;/\\\\&quot;/g&#39;)`\r\n\r\nbut this is not ideal.\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/45069839/how-to-get-a-formatted-json-string-from-a-json-object",
        "title": "How to get a formatted json string from a json object?"
    },
    {
        "tags": [
            "json",
            "linux",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1613587,
                    "reputation": 786618,
                    "user_id": 1491895,
                    "user_type": "registered",
                    "accept_rate": 69,
                    "profile_image": "https://www.gravatar.com/avatar/82f9e178a16364bf561d0ed4da09a35d?s=256&d=identicon&r=PG",
                    "display_name": "Barmar",
                    "link": "https://stackoverflow.com/users/1491895/barmar"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1500064870,
                "post_id": 45111137,
                "comment_id": 77194307,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 2141010,
                    "reputation": 124401,
                    "user_id": 1899640,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/47374ccb28e4b0d2454b64f7b975bc66?s=256&d=identicon&r=PG",
                    "display_name": "that other guy",
                    "link": "https://stackoverflow.com/users/1899640/that-other-guy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1500064918,
                "post_id": 45111137,
                "comment_id": 77194334,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 1613587,
                    "reputation": 786618,
                    "user_id": 1491895,
                    "user_type": "registered",
                    "accept_rate": 69,
                    "profile_image": "https://www.gravatar.com/avatar/82f9e178a16364bf561d0ed4da09a35d?s=256&d=identicon&r=PG",
                    "display_name": "Barmar",
                    "link": "https://stackoverflow.com/users/1491895/barmar"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1500065172,
                "post_id": 45111137,
                "comment_id": 77194449,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 97650,
                    "reputation": 1705,
                    "user_id": 264755,
                    "user_type": "registered",
                    "accept_rate": 69,
                    "profile_image": "https://www.gravatar.com/avatar/c8043700c53d254e2fd46424e5b03745?s=256&d=identicon&r=PG",
                    "display_name": "jasonmclose",
                    "link": "https://stackoverflow.com/users/264755/jasonmclose"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1500081903,
                "post_id": 45111137,
                "comment_id": 77198546,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1500065344,
                "creation_date": 1500065344,
                "answer_id": 45111396,
                "question_id": 45111137,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You can use commas at the top-level to get those fields. Use parentheses to group the expression that gets everything from `.values`.\r\n\r\n    jq &#39;.limit, .offset, (.values[] | .id, .type, .users.total, .users.profiles[].first_name, .users.profiles[].last_name)&#39;\r\n\r\n[DEMO][1]\r\n\r\n\r\n  [1]: https://jqplay.org/s/izjjHkDpdG",
                "title": "How to mix levels of json coming out of jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1500087448,
                "creation_date": 1500087448,
                "answer_id": 45114023,
                "question_id": 45111137,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "&gt; So it&#39;s &#39;limit&#39; and &#39;offset&#39; that are throwing me fits.\r\n\r\nIt looks like `to_entries` might be what you&#39;re looking for. Consider, for example:\r\n\r\n    to_entries[]\r\n    | select(.value | type != &quot;array&quot;) \r\n    | [.key, .value]\r\n    | join(&quot;: &quot;)\r\n    \r\n\r\nWith your JSON, this produces the lines you are having difficulty with, without any explicit mention of the key names:\r\n\r\n    limit: 10\r\n    offset: 20\r\n\r\nYou could then (for example) use the comma operator (`,`) to produce the other lines you want.\r\n\r\n\r\n\r\n    ",
                "title": "How to mix levels of json coming out of jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1500087448,
        "creation_date": 1500064089,
        "question_id": 45111137,
        "body_markdown": "So I am trying to pull out some JSON with jq.\r\n\r\nHere is an example:\r\n\r\n    {     \r\n        &quot;limit&quot;:10,\r\n        &quot;offset&quot;:20,   \r\n        &quot;values&quot;: [\r\n           {\r\n              &quot;id&quot;: &quot;abcd&quot;\r\n              &quot;type&quot;: &quot;file&quot;\r\n              &quot;users&quot;: {\r\n                 &quot;total&quot;: 2, \r\n                 &quot;profiles&quot;: [\r\n                    {\r\n                         &quot;first_name&quot;: &quot;John&quot;, \r\n                         &quot;last_name&quot;: &quot;Smith&quot;\r\n                    },\r\n                    {\r\n                         &quot;first_name&quot;: &quot;Sue&quot;, \r\n                         &quot;last_name&quot;: &quot;Johnson&quot;\r\n                    }\r\n                 ]\r\n              }\r\n           },\r\n           {\r\n              &quot;id&quot;: &quot;efgh&quot;\r\n              &quot;type&quot;: &quot;folder&quot;\r\n              &quot;users&quot;: {\r\n                 &quot;total&quot;: 1, \r\n                 &quot;profiles&quot;: [\r\n                    {\r\n                         &quot;first_name&quot;: &quot;Steve&quot;, \r\n                         &quot;last_name&quot;: &quot;Gold&quot;\r\n                    }\r\n                 ]\r\n              }\r\n           },\r\n        ] \r\n    }\r\n\r\nI would love to get the following in my result\r\n\r\n    limit:10\r\n    offset:20\r\n    id:abcd, type:file, [users.total:2, users.profiles.first_name: [John, Sue], users.profiles.last_name: [Smith, Johnson]], \r\n    id:efgh, type:folder, [users.total:1, users.profiles.first_name: [Steve], users.profiles.last_name: [Gold]], \r\n\r\nI know I can pipe this to jq, but I don&#39;t know how.  I can get stuff in an array easily, but I can&#39;t seem to figure out how to do it and add in the top level elements.  So it&#39;s &#39;limit&#39; and &#39;offset&#39; that are throwing me fits.\r\n\r\nI can get something out \r\n\r\n    jq &quot;.values[] | .users.total, .users[].first_name, .users[].last_name&quot;\r\n\r\nBut I cannot seem to figure out how to add in limit and offset.",
        "link": "https://stackoverflow.com/questions/45111137/how-to-mix-levels-of-json-coming-out-of-jq",
        "title": "How to mix levels of json coming out of jq"
    },
    {
        "tags": [
            "json",
            "bash",
            "shell",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1500068555,
                "creation_date": 1500068555,
                "answer_id": 45111983,
                "question_id": 45111742,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You have an array, where each element has a `partitions` field. You ask to get &quot;partitions&quot;, but you don&#39;t say from which element or elements in the array.\r\n\r\nHere&#39;s a complete, self-contained file:\r\n\r\n    [\r\n      {\r\n        &quot;partitions&quot;: [ &quot;name@website&quot; ]\r\n      },\r\n      {\r\n        &quot;partitions&quot;: [ &quot;more&quot; ]\r\n      }\r\n    ]\r\n\r\n\r\nYour expression produces the error you say:\r\n\r\n    $ jq &#39;.partitions&#39; file\r\n    jq: error (at file:8): Cannot index array with string &quot;partitions&quot;\r\n\r\nYou can get &quot;partitions&quot; for the first element:\r\n\r\n    $ jq &#39;.[0].partitions&#39; file\r\n    [\r\n      &quot;name@website&quot;\r\n    ]\r\n\r\nOr for each elements:\r\n\r\n    $ jq &#39;.[].partitions&#39; file\r\n    [\r\n      &quot;name@website&quot;\r\n    ]\r\n    [\r\n      &quot;more&quot;\r\n    ]\r\n\r\nOr join all the partitions from each element into one list:\r\n\r\n    $ jq &#39;map(.partitions) | add&#39; file\r\n    [\r\n      &quot;name@website&quot;,\r\n      &quot;more&quot;\r\n    ]",
                "title": "Beginner parsing with jq - Cannot index array with string"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1500068555,
        "creation_date": 1500067113,
        "question_id": 45111742,
        "body_markdown": "Here is a snippet of the output when I do a basic jq, what I want to get is the data of the partitions. \r\n\r\n    jq .\r\n\r\n \r\n\r\n    [\r\n     {\r\n    &quot;partitions&quot;: [\r\n      &quot;name@website\r\n    ],\r\n    &quot;os_pid&quot;: &quot;20458&quot;,\r\n    &quot;fd_used&quot;: 20,\r\n    &quot;fd_total&quot;: 1024,\r\n    &quot;sockets_used&quot;: 2,\r\n    &quot;sockets_total&quot;: 829,\r\n    &quot;mem_used&quot;: 41128152,\r\n\r\nWhen I do **jq &#39;.partitions&#39;** I get \r\n    Cannot index array with string &quot;partitions&quot; - Any thoughts as to why that happens?\r\n\r\n",
        "link": "https://stackoverflow.com/questions/45111742/beginner-parsing-with-jq-cannot-index-array-with-string",
        "title": "Beginner parsing with jq - Cannot index array with string"
    }
]