[
    {
        "tags": [
            "json",
            "bash",
            "formatting",
            "sh",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1548952818,
                "last_edit_date": 1548952818,
                "creation_date": 1548908243,
                "answer_id": 54453206,
                "question_id": 54453131,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is a solution:\r\n\r\n    jq -Rn &#39;{data: [ {IP: inputs} ] }&#39; input.txt\r\n\r\nIf this seems a bit magical, you might like to use the more mundane variant:\r\n\r\n    jq -Rn &#39;{data: [ inputs | {IP: .} ] }&#39; input.txt\r\n\r\nOf course, in practice, you might also want to remove extraneous whitespace in the input, filter out comments, perform validity checking or filter out invalid input ...\r\n\r\n",
                "title": "Formatting \\n list of IPv4 addresses into json"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1549234424,
        "creation_date": 1548907785,
        "question_id": 54453131,
        "body_markdown": "I have a list of IPv4 addresses being output in a list each separated by \\n. The program I would like to import these into is expecting it in this format:\r\n\r\n    {\r\n      &quot;data&quot;:[\r\n          { &quot;IP&quot;:&quot;127.0.0.1&quot;  },\r\n          { &quot;IP&quot;:&quot;192.168.0.1&quot; }\r\n      ]\r\n    }\r\n\r\nInput data for the above would have been this:\r\n\r\n    127.0.0.1\r\n    192.168.0.1\r\n\r\nI&#39;ve looked in the [jq cookbook](https://github.com/stedolan/jq/wiki/Cookbook) for ideas but the closest I&#39;ve been able to string together is using [] not {}, not inside data, and only has the value without key.\r\n\r\n    jq -sR &#39;[sub(&quot;\\n$&quot;;&quot;&quot;) | splits(&quot;\\n&quot;) | sub(&quot;^ +&quot;;&quot;&quot;) | [splits(&quot; +&quot;)]]&#39;\r\n\r\nOutputs:\r\n\r\n    [\r\n      [\r\n        &quot;127.0.0.1&quot;\r\n      ],\r\n      [\r\n        &quot;192.168.0.1&quot;\r\n      ]\r\n    ]\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/54453131/formatting-n-list-of-ipv4-addresses-into-json",
        "title": "Formatting \\n list of IPv4 addresses into json"
    },
    {
        "tags": [
            "json",
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1549039859,
                "post_id": 54480437,
                "comment_id": 95774697,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1601915505,
                "last_edit_date": 1601915505,
                "creation_date": 1549027879,
                "answer_id": 54480582,
                "question_id": 54480437,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can try another pipe to pass the result to jq command\r\n\r\n    platform json_dump platform_id | jq .elbName",
                "title": "Parse JSON file without having to save it in a file"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1549029234,
                "creation_date": 1549029234,
                "answer_id": 54480945,
                "question_id": 54480437,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Just pipe the program&#39;s output to jq:\r\n\r\n    platform json_dump platform_id | jq .elbName\r\n\r\nor whatever.\r\n\r\nPS: Use jq to get the value you want, not grep. Example of doing that.:\r\n\r\n    $ echo &#39;{&quot;elbName&quot;:&quot;foo&quot;}&#39; | jq .elbName\r\n    &quot;foo&quot;\r\n",
                "title": "Parse JSON file without having to save it in a file"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1549030369,
                "creation_date": 1549030369,
                "answer_id": 54481250,
                "question_id": 54480437,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I&#39;m assuming you have python :)\r\n\r\n    platform json_dump platform_id | python -c &#39;import sys,json; print(json.load(sys.stdin)[&quot;elbName&quot;])&#39; # a bit long ? :)\r\n\r\n",
                "title": "Parse JSON file without having to save it in a file"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": -1,
        "last_activity_date": 1601915505,
        "creation_date": 1549027358,
        "question_id": 54480437,
        "body_markdown": "I have a command that returns a JSON dump that won&#39;t get saved into any file.\r\n\r\nI have to parse a particular field from the JSON response without saving the output.\r\n\r\nI am able to achieve it if I save the output of the command and then parse it using `jq` and `grep` like this:\r\n\r\n    platform json_dump platform_id &gt;resp.json\r\n    jq . resp.json | grep elbName\r\n\r\nBut, I do not want to write the output of my command platform `json_dump platform_id` which is a JSON dump into any file. I want to parse the `elbName` directly from the out of the command.\r\n\r\nIs there a way I can do that?",
        "link": "https://stackoverflow.com/questions/54480437/parse-json-file-without-having-to-save-it-in-a-file",
        "title": "Parse JSON file without having to save it in a file"
    },
    {
        "tags": [
            "json",
            "key",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1549043175,
                "last_edit_date": 1549043175,
                "creation_date": 1549039502,
                "answer_id": 54483712,
                "question_id": 54483059,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The key here to accessing the key names is to use `keys`, `keys_unsorted`, or `to_entries`, e.g.\r\n\r\n    .data\r\n    | to_entries[]\r\n    | &quot;\\&quot;account_id\\&quot;: \\(.key): \\&quot;global_rating\\&quot;: \\(.value.global_rating)&quot;\r\n\r\n## JSON objects\r\n\r\nIf you wanted the output in the form of a stream of JSON objects:\r\n\r\n    | .data\r\n    | to_entries[]\r\n    | {account_id: .key} + (.value | {global_rating})",
                "title": "jq query where key is part of the data itself"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1549047304,
        "creation_date": 1549037103,
        "last_edit_date": 1549047304,
        "question_id": 54483059,
        "body_markdown": "I have the following JSON data from an API call.....\r\n\r\n    {\r\n      &quot;status&quot;: &quot;ok&quot;,\r\n      &quot;meta&quot;: {\r\n        &quot;count&quot;: 3\r\n      },\r\n      &quot;data&quot;: {\r\n        &quot;1030907370&quot;: {\r\n          &quot;client_language&quot;: &quot;en&quot;,\r\n          &quot;last_battle_time&quot;: 1548555418,\r\n          &quot;account_id&quot;: 1030907370,\r\n          &quot;created_at&quot;: 1525288212,\r\n          &quot;updated_at&quot;: 1548557165,\r\n          &quot;private&quot;: null,\r\n          &quot;global_rating&quot;: 3906,\r\n          &quot;clan_id&quot;: null,\r\n          &quot;nickname&quot;: &quot;aaa&quot;,\r\n          &quot;logout_at&quot;: 1548557161\r\n        },\r\n        &quot;1020786770&quot;: {\r\n          &quot;client_language&quot;: &quot;ja&quot;,\r\n          &quot;last_battle_time&quot;: 1548948444,\r\n          &quot;account_id&quot;: 1020786770,\r\n          &quot;created_at&quot;: 1465998341,\r\n          &quot;updated_at&quot;: 1548948547,\r\n          &quot;private&quot;: null,\r\n          &quot;global_rating&quot;: 4396,\r\n          &quot;clan_id&quot;: null,\r\n          &quot;nickname&quot;: &quot;bbb&quot;,\r\n          &quot;logout_at&quot;: 1548948544\r\n        },\r\n        &quot;1018984431&quot;: {\r\n          &quot;client_language&quot;: &quot;en&quot;,\r\n          &quot;last_battle_time&quot;: 1548550089,\r\n          &quot;account_id&quot;: 1018984431,\r\n          &quot;created_at&quot;: 1456254986,\r\n          &quot;updated_at&quot;: 1548550089,\r\n          &quot;private&quot;: null,\r\n          &quot;global_rating&quot;: 1666,\r\n          &quot;clan_id&quot;: null,\r\n          &quot;nickname&quot;: &quot;ccc&quot;,\r\n          &quot;logout_at&quot;: 1548550016\r\n        }\r\n      }\r\n\r\n}\r\n\r\nI would like to end up with something like .....\r\n\r\n&gt;   “account_id”: 1030907370,   “global_rating”: 3906\r\n&gt; \r\n&gt;   “account_id”: 1020786770,   “global_rating”: 3906\r\n&gt; \r\n&gt;   “account_id”: 1018984431,   “global_rating”: 3906\r\n\r\n\r\nThe fact that the &quot;account_id&quot; value is used a unique key is something I have not come across in tutorials and I need help with a jq query that will do the job.\r\nTks!\r\n",
        "link": "https://stackoverflow.com/questions/54483059/jq-query-where-key-is-part-of-the-data-itself",
        "title": "jq query where key is part of the data itself"
    },
    {
        "tags": [
            "json",
            "max",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 21,
                "is_accepted": true,
                "score": 21,
                "last_activity_date": 1663303966,
                "last_edit_date": 1663303966,
                "creation_date": 1549079741,
                "answer_id": 54489836,
                "question_id": 54489648,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`max` expects an array as input.\r\n\r\n    $ jq &#39;map(select(.platform == &quot;foo&quot;) .createdAt) | max&#39; file\r\n    1548912360000",
                "title": "How to get max value from JSON?"
            },
            {
                "up_vote_count": 5,
                "is_accepted": false,
                "score": 5,
                "last_activity_date": 1549084968,
                "last_edit_date": 1549084968,
                "creation_date": 1549080196,
                "answer_id": 54489865,
                "question_id": 54489648,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "One approach would be to make the selection and then use one of the array-oriented builtins `max` or `max_by` to find the maximum, e.g.\r\n\r\n    map(select(.platform==&quot;foo&quot;))\r\n    | max_by(.createdAt)\r\n    | .createdAt\r\n\r\nHowever, this approach is not very satisfactory as it requires more space than is strictly necessary.  For large arrays, a stream-oriented version of `max_by` would be better.\r\n\r\n## max_by\r\n\r\n    def max_by(s; f):\r\n      reduce s as $s (null;\r\n        if . == null then {s: $s, m: ($s|f)}\r\n        else  ($s|f) as $m\r\n        | if $m &gt; .m then {s: $s, m: $m} else . end\r\n        end)\r\n      | .s ;\r\n\r\n    max_by(.[] | select(.platform==&quot;foo&quot;); .createdAt)\r\n    | .createdAt\r\n  \r\n",
                "title": "How to get max value from JSON?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1711269814,
                "creation_date": 1711269814,
                "answer_id": 78213888,
                "question_id": 54489648,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Why not:\r\n\r\n    cat foo.json | jq -c &#39;.[] | select(.platform==&quot;foo&quot;) | .createdAt&#39; | sort -un | tail -1\r\n\r\nJSON -&gt; list of numbers -&gt; sort (unique) all by number, asc -&gt; get last (max)",
                "title": "How to get max value from JSON?"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 11,
        "last_activity_date": 1711269814,
        "creation_date": 1549077316,
        "last_edit_date": 1614356250,
        "question_id": 54489648,
        "body_markdown": "There is a json file like this:\r\n\r\n    [\r\n    {\r\n        &quot;createdAt&quot;: 1548729542000,\r\n        &quot;platform&quot;: &quot;foo&quot;\r\n    },\r\n    {\r\n        &quot;createdAt&quot;: 1548759398000,\r\n        &quot;platform&quot;: &quot;foo&quot;\r\n    },\r\n    {\r\n        &quot;createdAt&quot;: 1548912360000,\r\n        &quot;platform&quot;: &quot;foo&quot;\r\n    },\r\n    {\r\n        &quot;createdAt&quot;: 1548904550000,\r\n        &quot;platform&quot;: &quot;bar&quot;\r\n    }\r\n    ]\r\n\r\nNow I want to get the max createdAt of foo platform? how to implement it by using jq?\r\n\r\n    jq &#39;.[] | select(.platform==&quot;foo&quot;) | .createdAt | max&#39; foo.json\r\n    jq: error (at &lt;stdin&gt;:17): number (1548729542000) and number (1548729542000) cannot be iterated over\r\n\r\n    jq &#39;.[] | select(.platform==&quot;foo&quot;) | max_by(.createdAt)&#39; foo.json\r\n    jq: error (at &lt;stdin&gt;:17): Cannot index number with string &quot;createdAt&quot;\r\n    exit status 5\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/54489648/how-to-get-max-value-from-json",
        "title": "How to get max value from JSON?"
    },
    {
        "tags": [
            "json",
            "select",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1549082913,
                "last_edit_date": 1549082913,
                "creation_date": 1549082584,
                "answer_id": 54490058,
                "question_id": 54489969,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Your code selects names whereas you want to select parent objects of names. Following yields your desired output.\r\n\r\n    jq -r &#39;.[] | select(.name|test(&quot;Mail&quot;; &quot;i&quot;))[]&#39; file",
                "title": "How to filter JSON using jq on a single field, but display multiple fields?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1549284014,
        "creation_date": 1549081532,
        "last_edit_date": 1549213476,
        "question_id": 54489969,
        "body_markdown": "This is the sample data I have. I need to filter on &quot;name&quot; field and print pairs name, url for every name containing &quot;mail&quot;:\r\n\r\nSource data:\r\n\r\n     [\r\n         {\r\n             &quot;name&quot;: &quot;Yahoo&quot;,\r\n             &quot;url&quot;: &quot;https://www.yahoo.com/&quot;\r\n         },\r\n         {\r\n             &quot;name&quot;: &quot;Yahoo Mail&quot;,\r\n             &quot;url&quot;: &quot;https://mail.yahoo.com/&quot;\r\n         },\r\n         {\r\n             &quot;name&quot;: &quot;Google&quot;,\r\n             &quot;url&quot;: &quot;https://www.google.com/&quot;\r\n         },\r\n         {\r\n             &quot;name&quot;: &quot;Google Mail (Gmail)&quot;,\r\n             &quot;url&quot;: &quot;https://gmail.com/&quot;\r\n         }\r\n     ]\r\n\r\n\r\nDesired output:\r\n\r\n    Yahoo Mail\r\n    https://mail.yahoo.com/\r\n    Google Mail (Gmail)\r\n    https://gmail.com/\r\n\r\nHow do I do this in jq?\r\n\r\nSo far this finds all &quot;name&quot; that contains &quot;Mail&quot;, but how do I print &quot;url&quot; as well?\r\n\r\n    jq -r &#39;.[].name | select(test(&quot;Mail&quot;;&quot;i&quot;))&#39;\r\n\r\nproduces output:\r\n\r\n     Yahoo Mail\r\n     Google Mail (Gmail)\r\n\r\n",
        "link": "https://stackoverflow.com/questions/54489969/how-to-filter-json-using-jq-on-a-single-field-but-display-multiple-fields",
        "title": "How to filter JSON using jq on a single field, but display multiple fields?"
    },
    {
        "tags": [
            "json",
            "csv",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 6,
                "is_accepted": false,
                "score": 6,
                "last_activity_date": 1549129326,
                "creation_date": 1549129326,
                "answer_id": 54495712,
                "question_id": 54495664,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use raw mode (-r)\r\n\r\n```\r\njq -r &#39;.data | to_entries[] | [.key, .value.client_language, .value.global_rating] | @csv&#39;\r\n```\r\n\r\n&gt; --raw-output / -r:\r\n&gt; \r\n&gt; With this option, if the filter’s result is a string then it will be\r\n&gt; written directly to standard output rather than being formatted as a\r\n&gt; JSON string with quotes. This can be useful for making jq filters talk\r\n&gt; to non-JSON-based systems.",
                "title": "Using jq to create .csv file"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1549152057,
        "creation_date": 1549129008,
        "last_edit_date": 1549152057,
        "question_id": 54495664,
        "body_markdown": "This topic has been raised before, but the responses don&#39;t quite solve my problem which is detailed below.\r\n\r\nI have the following JSON file from an API call....\r\n\r\n    {\r\n      &quot;status&quot;: &quot;ok&quot;,\r\n      &quot;meta&quot;: {\r\n        &quot;count&quot;: 3\r\n      },\r\n      &quot;data&quot;: {\r\n        &quot;1030907370&quot;: {\r\n          &quot;client_language&quot;: &quot;en&quot;,\r\n          &quot;last_battle_time&quot;: 1548555418,\r\n          &quot;account_id&quot;: 1030907370,\r\n          &quot;created_at&quot;: 1525288212,\r\n          &quot;updated_at&quot;: 1548557165,\r\n          &quot;private&quot;: null,\r\n          &quot;global_rating&quot;: 3906,\r\n          &quot;clan_id&quot;: null,\r\n          &quot;nickname&quot;: &quot;Knightly_Gunner&quot;,\r\n          &quot;logout_at&quot;: 1548557161\r\n        },\r\n        &quot;1020786770&quot;: {\r\n          &quot;client_language&quot;: &quot;ja&quot;,\r\n          &quot;last_battle_time&quot;: 1548948444,\r\n          &quot;account_id&quot;: 1020786770,\r\n          &quot;created_at&quot;: 1465998341,\r\n          &quot;updated_at&quot;: 1548948547,\r\n          &quot;private&quot;: null,\r\n          &quot;global_rating&quot;: 4396,\r\n          &quot;clan_id&quot;: null,\r\n          &quot;nickname&quot;: &quot;black_black_boss&quot;,\r\n          &quot;logout_at&quot;: 1548948544\r\n        },\r\n        &quot;1018984431&quot;: {\r\n          &quot;client_language&quot;: &quot;en&quot;,\r\n          &quot;last_battle_time&quot;: 1548550089,\r\n          &quot;account_id&quot;: 1018984431,\r\n          &quot;created_at&quot;: 1456254986,\r\n          &quot;updated_at&quot;: 1548550089,\r\n          &quot;private&quot;: null,\r\n          &quot;global_rating&quot;: 1666,\r\n          &quot;clan_id&quot;: null,\r\n          &quot;nickname&quot;: &quot;doctordon&quot;,\r\n          &quot;logout_at&quot;: 1548550016\r\n        }\r\n      }\r\n    }\r\n\r\nUsing the following jq query....\r\n\r\n&gt; jq &#39;.data | to_entries[] | [.key, .value.client_language,\r\n&gt; .value.global_rating]&#39;\r\n\r\nI get the following output which is exactly the data I need, neatly packaged in arrays....\r\n\r\n    [\r\n      &quot;1030907370&quot;,\r\n      &quot;en&quot;,\r\n      3906\r\n    ]\r\n    [\r\n      &quot;1020786770&quot;,\r\n      &quot;ja&quot;,\r\n      4396\r\n    ]\r\n    [\r\n      &quot;1018984431&quot;,\r\n      &quot;en&quot;,\r\n      1666\r\n    ]\r\n\r\nI need to upload this data to an MS Access database so it therefore needs to be converted to a .csv file so my query now looks like this....\r\n\r\n&gt; jq &#39;.data | to_entries[] | [.key, .value.client_language,\r\n&gt; .value.global_rating] | @csv&#39;\r\n\r\nand the resulting output is....\r\n\r\n    &quot;\\&quot;1030907370\\&quot;,\\&quot;en\\&quot;,3906&quot;\r\n    &quot;\\&quot;1020786770\\&quot;,\\&quot;ja\\&quot;,4396&quot;\r\n    &quot;\\&quot;1018984431\\&quot;,\\&quot;en\\&quot;,1666&quot;\r\n\r\nbut this is NOT a true .csv file and doesn&#39;t work for MS Access or Excel. What I need is output that looks like this....\r\n\r\n    &quot;1030907370&quot;,&quot;en&quot;,3906\r\n    &quot;1020786770&quot;,&quot;ja&quot;,4396\r\n    &quot;1018984431&quot;,&quot;en&quot;,1666\r\n\r\n\r\nbut this is where my problem lies!. I would appreciate some help in achieving the required output from the jq query.\r\nTks!\r\n\r\n",
        "link": "https://stackoverflow.com/questions/54495664/using-jq-to-create-csv-file",
        "title": "Using jq to create .csv file"
    },
    {
        "tags": [
            "json",
            "shell",
            "join",
            "command-line",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1549300839,
                "last_edit_date": 1549300839,
                "creation_date": 1549228671,
                "answer_id": 54507678,
                "question_id": 54506913,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a simple solution using `INDEX/2`:\r\n\r\n    INDEX(.Customers[]; .Id) as $c\r\n    | .Reservations[]\r\n    | { ReservationId: .Id,\r\n        CustomerName: $c[.CustomerId].Name }\r\n        \r\n\r\nIf your jq does not have `INDEX/2` then now would be a good time to upgrade; otherwise, you can copy-and-paste its def from https://github.com/stedolan/jq/blob/master/src/builtin.jq, or you could use `INDEX/3` as defined below.\r\n\r\n## INDEX/3\r\n\r\n    def INDEX(s; k; v):\r\n      reduce s as $x ({}; .[$x|k] = ($x|v));\r\n\r\n    INDEX(.Customers[]; .Id; .Name) as $c\r\n    | .Reservations[]\r\n    | { ReservationId: .Id,\r\n        CustomerName: $c[.CustomerId] }",
                "title": "How to join JSON objects on particular fields using jq?"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1549300839,
        "creation_date": 1549223516,
        "last_edit_date": 1549231952,
        "question_id": 54506913,
        "body_markdown": "I have following JSON structure:\r\n\r\n    {\r\n      &quot;Reservations&quot;: [\r\n        {\r\n          &quot;Id&quot;: &quot;R-1&quot;,\r\n          &quot;CustomerId&quot;: &quot;1&quot;\r\n        },\r\n        {\r\n          &quot;Id&quot;: &quot;R-2&quot;,\r\n          &quot;CustomerId&quot;: &quot;2&quot;\r\n        }\r\n      ],\r\n      &quot;Customers&quot;: [\r\n        {\r\n          &quot;Id&quot;: &quot;1&quot;,\r\n          &quot;Name&quot;: &quot;customer 1&quot;\r\n        },\r\n        {\r\n          &quot;Id&quot;: &quot;2&quot;,\r\n          &quot;Name&quot;: &quot;customer 2&quot;\r\n        },\r\n        {\r\n          &quot;Id&quot;: &quot;3&quot;,\r\n          &quot;Name&quot;: &quot;customer 3&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\nI want to join `Reservations` with `Customers` and get something like this:\r\n\r\n    {\r\n      &quot;ReservationId&quot;: &quot;R-1&quot;,\r\n      &quot;CustomerName&quot;: &quot;customer 1&quot;\r\n    }\r\n    {\r\n      &quot;ReservationId&quot;: &quot;R-2&quot;,\r\n      &quot;CustomerName&quot;: &quot;customer 2&quot;\r\n    }\r\n\r\nI&#39;ve played with `jq` extensively, tried using multiple filters separated by comma, tried using variables, read the docs, but it seems like doing such a simple tasks is impossible with `jq`. Or, am I missing something?",
        "link": "https://stackoverflow.com/questions/54506913/how-to-join-json-objects-on-particular-fields-using-jq",
        "title": "How to join JSON objects on particular fields using jq?"
    },
    {
        "tags": [
            "json",
            "bash",
            "awk",
            "sed",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 8423,
                    "reputation": 757671,
                    "user_id": 15168,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/WtEI9.png?s=256",
                    "display_name": "Jonathan Leffler",
                    "link": "https://stackoverflow.com/users/15168/jonathan-leffler"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1549379760,
                "post_id": 54537225,
                "comment_id": 95876431,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 485250,
                    "reputation": 8652,
                    "user_id": 901444,
                    "user_type": "registered",
                    "accept_rate": 77,
                    "profile_image": "https://i.sstatic.net/nAQoU.jpg?s=256",
                    "display_name": "slashdottir",
                    "link": "https://stackoverflow.com/users/901444/slashdottir"
                },
                "reply_to_user": {
                    "account_id": 8423,
                    "reputation": 757671,
                    "user_id": 15168,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/WtEI9.png?s=256",
                    "display_name": "Jonathan Leffler",
                    "link": "https://stackoverflow.com/users/15168/jonathan-leffler"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1549379839,
                "post_id": 54537225,
                "comment_id": 95876488,
                "content_license": "CC BY-SA 4.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": 1549380284,
                "post_id": 54537225,
                "comment_id": 95876782,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8423,
                    "reputation": 757671,
                    "user_id": 15168,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/WtEI9.png?s=256",
                    "display_name": "Jonathan Leffler",
                    "link": "https://stackoverflow.com/users/15168/jonathan-leffler"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1549380319,
                "post_id": 54537225,
                "comment_id": 95876807,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1143565,
                    "reputation": 535973,
                    "user_id": 1126841,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa05233b2357f8d11c22ef4cfc7bb85c?s=256&d=identicon&r=PG",
                    "display_name": "chepner",
                    "link": "https://stackoverflow.com/users/1126841/chepner"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1549382117,
                "post_id": 54537225,
                "comment_id": 95877864,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 485250,
                    "reputation": 8652,
                    "user_id": 901444,
                    "user_type": "registered",
                    "accept_rate": 77,
                    "profile_image": "https://i.sstatic.net/nAQoU.jpg?s=256",
                    "display_name": "slashdottir",
                    "link": "https://stackoverflow.com/users/901444/slashdottir"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1549383996,
                "post_id": 54537225,
                "comment_id": 95878966,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1549384603,
                "last_edit_date": 1549384603,
                "creation_date": 1549379893,
                "answer_id": 54537590,
                "question_id": 54537225,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Pipe your command&#39;s output to [tag:jq]:\r\n\r\n    jq -s",
                "title": "Turn output of command into valid json?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1549380024,
                "creation_date": 1549380024,
                "answer_id": 54537642,
                "question_id": 54537225,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I came up with this solution\r\n\r\n    kubectl cluster-info dump | sed &quot;s/^}$/},/g&quot; | tr &#39;\\n&#39; &quot;~&quot; | sed &#39;s/^/[/g&#39; | sed &#39;s/$/]/g&#39; | tr &quot;~&quot; &quot;\\n&quot;\r\n\r\nwhich produces a json parseable result\r\n\r\n\r\n",
                "title": "Turn output of command into valid json?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1549380931,
                "creation_date": 1549380931,
                "answer_id": 54537924,
                "question_id": 54537225,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If the layout is as shown, then:\r\n\r\n    kubectl cluster-info dump |\r\n    { echo &quot;[&quot;; sed -e &#39;s/^}$/},/&#39; -e &#39;$s/^},$/}/&#39;; echo &quot;]&quot;; }\r\n\r\nwould do the job. This relies on the &quot;tons of JSON&quot; not having any line containing only `}` in the middle. Since JSON parsers aren&#39;t worried by spaces and newlines, there&#39;s no need to do more.\r\n\r\nYou can avoid the shell `{ …; }` notation with:\r\n\r\n    kubectl cluster-info dump |\r\n    sed -e &#39;1s/^/[/&#39; -e &#39;s/^}$/},/&#39; -e &#39;$s/^},$/}]/&#39;\r\n\r\nThe first `sed` commands adds a `[` to the start of the first line; the second changes each line consisting of just `}` to `},` (including the last line), but the third undoes that damage and adds the `]` instead.\r\n\r\nYou could even combine those `-e` commands into one separated by semicolons.  Personally, I prefer separate `-e` options to make it easer to read.  If they&#39;re more complex, I put each one on its own line, with backslash to continue the overall command over multiple lines.\r\n\r\n",
                "title": "Turn output of command into valid json?"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": -2,
        "last_activity_date": 1666425038,
        "creation_date": 1549378791,
        "last_edit_date": 1666425038,
        "question_id": 54537225,
        "body_markdown": "How can I use bash commands to convert the output of &#39;kubectl cluster-info dump&#39; into valid json?\r\n\r\nAs is, right now, it comes out like this (extremely abbreviated):\r\n\r\n    {\r\n        &quot;selfLink&quot;: &quot;/api/v1/nodes&quot;,\r\n        &quot;resourceVersion&quot;: &quot;24393&quot;,\r\n        &quot;Items&quot;: [tons of json]\r\n    }\r\n    {\r\n        &quot;selfLink&quot;: &quot;/api/v1/namespaces/default/events&quot;,\r\n        &quot;resourceVersion&quot;: &quot;24393&quot;,\r\n        &quot;Items&quot;: [tons of json]\r\n    }\r\n    ...\r\n    {\r\n        &quot;selfLink&quot;: &quot;/api/v1/namespaces/default/pods&quot;,\r\n        &quot;resourceVersion&quot;: &quot;24393&quot;,\r\n        &quot;Items&quot;: [tons of json]\r\n    }\r\n\r\n\r\nI would like to pipe the output of this command through sed or awk to translate this output into valid json, something like:\r\n\r\n    [{&quot;k&quot;,&quot;v&quot;,&quot;k2&quot;,&quot;v2&quot;},\r\n     {&quot;k&quot;,&quot;v&quot;,&quot;k2&quot;,&quot;v2&quot;},\r\n     ...\r\n     {&quot;k&quot;,&quot;v&quot;,&quot;k2&quot;,&quot;v2&quot;}]\r\n\r\nwhich I can then easily parse with json parsers like jq\r\n",
        "link": "https://stackoverflow.com/questions/54537225/turn-output-of-command-into-valid-json",
        "title": "Turn output of command into valid json?"
    },
    {
        "tags": [
            "json",
            "csv",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1549407508,
                "creation_date": 1549407508,
                "answer_id": 54544313,
                "question_id": 54544077,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "One approach would be to use `@csv`, e.g. along the lines of:\r\n\r\n    &lt; ec2.json jq -r &quot;[.[] | .private_ip] | @csv&quot;",
                "title": "jq - combine multple lines into single comma separated line"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1549414669,
        "creation_date": 1549405991,
        "last_edit_date": 1549414669,
        "question_id": 54544077,
        "body_markdown": "I need the IP output below to be printed in a single line like this &quot;10.88.4.92&quot;, &quot;10.88.5.203&quot;, &quot;10.87.5.215&quot;\r\n\r\n    cat ec2.json | jq &quot;.[] | .private_ip&quot;\r\n    \r\n    &quot;10.88.4.92&quot;\r\n    &quot;10.88.5.203&quot;\r\n    &quot;10.87.5.215&quot;\r\n\r\n\r\nHow to achieve this with jq",
        "link": "https://stackoverflow.com/questions/54544077/jq-combine-multple-lines-into-single-comma-separated-line",
        "title": "jq - combine multple lines into single comma separated line"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1549429176,
                "creation_date": 1549429176,
                "answer_id": 54546864,
                "question_id": 54546761,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You need to parse `last_values` as JSON value first. To do that, use `fromjson`:\r\n\r\n    jq &#39;.channel.last_values|fromjson.field1&#39; file",
                "title": "JQ - Cannot extract values from Ubibot json"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1550271216,
        "creation_date": 1549428356,
        "last_edit_date": 1549435304,
        "question_id": 54546761,
        "body_markdown": "I have a Ubibot ws-1 and I&#39;m trying to extract Timestamp, Temperature, Humidity, Light and voltage from `last_values` in the following JSON\r\n\r\nThe API JSON output is\r\n    \r\n\r\n    {\r\n      &quot;channel&quot;: {\r\n        &quot;channel_id&quot;: &quot;1111&quot;,\r\n        &quot;name&quot;: &quot;C-1111&quot;,\r\n        &quot;field1&quot;: &quot;Temperature&quot;,\r\n        &quot;field2&quot;: &quot;Humidity&quot;,\r\n        &quot;field3&quot;: &quot;Light&quot;,\r\n        &quot;field4&quot;: &quot;Voltage&quot;,\r\n        &quot;field5&quot;: &quot;WIFI RSSI&quot;,\r\n        &quot;field6&quot;: &quot;Vibration Index&quot;,\r\n        &quot;field7&quot;: &quot;Knocks&quot;,\r\n        &quot;field8&quot;: &quot;External Temperature Probe&quot;,\r\n        &quot;field9&quot;: &quot;Reed Sensor&quot;,\r\n        &quot;field10&quot;: null,\r\n        &quot;latitude&quot;: &quot;1&quot;,\r\n        &quot;longitude&quot;: &quot;1&quot;,\r\n        &quot;elevation&quot;: null,\r\n        &quot;created_at&quot;: &quot;2019-02-05T05:16:43Z&quot;,\r\n        &quot;updated_at&quot;: &quot;2019-02-05T06:11:38Z&quot;,\r\n        &quot;metadata&quot;: &quot;{\\&quot;fn_dp\\&quot;:900,\\&quot;fn_th\\&quot;:300,\\&quot;fn_light\\&quot;:300,\\&quot;fn_acc_act\\&quot;:0,\\&quot;thres_acc_min\\&quot;:0,\\&quot;fn_acc_tap1\\&quot;:0,\\&quot;fn_acc_tap2\\&quot;:0,\\&quot;fn_ext_t\\&quot;:300,\\&quot;fn_battery\\&quot;:7200,\\&quot;fn_485_th\\&quot;:0,\\&quot;fn_485_sth\\&quot;:0,\\&quot;net_mode\\&quot;:0,\\&quot;no_net_fn\\&quot;:1,\\&quot;cg_data_led\\&quot;:1,\\&quot;wifi_mode\\&quot;:1}&quot;,\r\n        &quot;tags&quot;: null,\r\n        &quot;public_flag&quot;: &quot;false&quot;,\r\n        &quot;url&quot;: null,\r\n        &quot;description&quot;: null,\r\n        &quot;write_key&quot;: &quot;1b0f2b31a6d522a376782a90f4be0270&quot;,\r\n        &quot;user_id&quot;: &quot;9186F150-9203-492B-B31A-77077E15E461&quot;,\r\n        &quot;last_entry_id&quot;: &quot;583&quot;,\r\n        &quot;last_entry_date&quot;: &quot;2019-02-05T19:12:47Z&quot;,\r\n        &quot;usage&quot;: &quot;96328&quot;,\r\n        &quot;device_id&quot;: &quot;17a867e84624895f6dab0346a4cba8cfd8279298&quot;,\r\n        &quot;status&quot;: &quot;{\\&quot;ssid\\&quot;:\\&quot;hydra1\\&quot;,\\&quot;status\\&quot;:\\&quot;ssid=wifi,usb=1\\&quot;,\\&quot;usb\\&quot;:\\&quot;1\\&quot;}&quot;,\r\n        &quot;status_date&quot;: &quot;1549393967&quot;,\r\n        &quot;last_ip&quot;: &quot;nn.nn.nn.nnn&quot;,\r\n        &quot;channel_icon&quot;: null,\r\n        &quot;product_id&quot;: &quot;ubibot-ws1&quot;,\r\n        &quot;plan_code&quot;: &quot;ubibot_free&quot;,\r\n        &quot;plan_start&quot;: &quot;2019-02-05T05:16:43Z&quot;,\r\n        &quot;plan_end&quot;: null,\r\n        &quot;bill_start&quot;: &quot;2019-02-05T05:16:43Z&quot;,\r\n        &quot;bill_end&quot;: &quot;2019-03-07T05:16:43Z&quot;,\r\n        &quot;traffic_out&quot;: &quot;188763&quot;,\r\n        &quot;traffic_in&quot;: &quot;33767&quot;,\r\n        &quot;full_dump&quot;: &quot;0&quot;,\r\n        &quot;renew&quot;: null,\r\n        &quot;last_values&quot;: &quot;{\\&quot;field1\\&quot;:{\\&quot;value\\&quot;:27.186996,\\&quot;created_at\\&quot;:\\&quot;2019-02-05T19:12:39Z\\&quot;},\\&quot;field3\\&quot;:{\\&quot;value\\&quot;:10.37,\\&quot;created_at\\&quot;:\\&quot;2019-02-05T19:12:39Z\\&quot;},\\&quot;field2\\&quot;:{\\&quot;value\\&quot;:29,\\&quot;created_at\\&quot;:\\&quot;2019-02-05T19:12:39Z\\&quot;},\\&quot;field5\\&quot;:{\\&quot;value\\&quot;:-35,\\&quot;created_at\\&quot;:\\&quot;2019-02-05T19:12:41Z\\&quot;},\\&quot;field4\\&quot;:{\\&quot;value\\&quot;:5,\\&quot;created_at\\&quot;:\\&quot;2019-02-05T17:27:38Z\\&quot;}}&quot;,\r\n        \r\n      }\r\n    }\r\n\r\nmy jq skills are very poor `.channel.last_values.&quot;\\(.field1)` gives me `jq: error (at &lt;stdin&gt;:0): Cannot index string with string &quot;null&quot;`.\r\n\r\nCan someone help me with the correct jq? Thanks in advance",
        "link": "https://stackoverflow.com/questions/54546761/jq-cannot-extract-values-from-ubibot-json",
        "title": "JQ - Cannot extract values from Ubibot json"
    },
    {
        "tags": [
            "json",
            "bash",
            "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": 1549469051,
                "post_id": 54551554,
                "comment_id": 95915278,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1549449658,
                "creation_date": 1549449658,
                "answer_id": 54551634,
                "question_id": 54551554,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "What you want is merge JSONs. If you are using 1.4+ you can use: `jq -s &#39;.[0] * .[1]&#39; file1 file2`\r\n\r\nYou can find more answers here: https://stackoverflow.com/questions/19529688/how-to-merge-2-json-file-using-jq",
                "title": "Bash jq; build array using primary key"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1549465817,
                "last_edit_date": 1549465817,
                "creation_date": 1549465262,
                "answer_id": 54556560,
                "question_id": 54551554,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The problem as stated can be broken down into two parts:\r\n\r\n1) parsing the text of `key : value` pairs into valid JSON;\r\n\r\n2) constructing the output\r\n\r\nSince the format of the key:value text is not clearly specified, I&#39;m going to assume that each key:value pair occurs on a separate line, and that the key/value pair can be recovered using the def:\r\n\r\n\r\n    def parse: \r\n      capture(&quot;\\&quot;(?&lt;k&gt;[^\\&quot;]*)\\&quot; *: *(?&lt;v&gt;.*)&quot;) | [.k, (.v | fromjson)];\r\n    \r\nThe second part of the problem is readily solved using the following generic def:\r\n\r\n    def add_by(s; f; g):\r\n      reduce s as $x (null; .[$x|f] += ($x|g));\r\n\r\nPutting the pieces together, we can write:\r\n\r\n    add_by(inputs | parse; .[0]; .[1])\r\n\r\n## Invocation\r\n\r\nWith the above snippets in merge.jq, we can write:\r\n\r\n    jq -nR -f merge.jq part1.txt part2.txt part3.txt ...\r\n\r\n## Variant\r\n\r\nIf your jq library already contains:\r\n\r\n    def aggregate_by(s; f; g):\r\n      reduce s as $x  (null; .[$x|f] += [$x|g]);\r\n\r\nthen you could use the above def of `parse` as follows:\r\n\r\n    aggregate_by(inputs | parse; .[0]; .[1])\r\n    | map_values(add)\r\n",
                "title": "Bash jq; build array using primary key"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1549465817,
        "creation_date": 1549449433,
        "question_id": 54551554,
        "body_markdown": "I have a bash while do done loop in a loop that outputs using this  \r\n`echo &quot;${KEY}: {\\&quot;${ATTRIBUTE}\\&quot;: ${VALUE} }&quot;`\r\n\r\nInput part 1\r\n\r\n    &quot;PKEY1&quot;: {&quot;rank&quot;: 1 }\r\n    &quot;PKEY2&quot;: {&quot;rank&quot;: 2 }\r\n    &quot;PKEY3&quot;: {&quot;rank&quot;: 4 }\r\n    &quot;PKEY4&quot;: {&quot;rank&quot;: 3 }\r\n\r\nInput part 2\r\n\r\n    &quot;PKEY1&quot;: {&quot;attr&quot;: &quot;xyz&quot; }\r\n    &quot;PKEY2&quot;: {&quot;attr&quot;: &quot;foo&quot; }\r\n    &quot;PKEY3&quot;: {&quot;attr&quot;: &quot;bar&quot; }\r\n    &quot;PKEY4&quot;: {&quot;attr&quot;: &quot;abc&quot; }\r\n\r\nInput part 3,4,5,etc...\r\n\r\nHow can I get an output file or echo to look like this in short\r\n\r\n    {\r\n    &quot;PKEY1&quot;: {&quot;rank&quot;: 1, &quot;attr&quot;: &quot;xyz&quot; },\r\n    &quot;PKEY2&quot;: {&quot;rank&quot;: 2, &quot;attr&quot;: &quot;foo&quot; },\r\n    &quot;PKEY3&quot;: {&quot;rank&quot;: 4, &quot;attr&quot;: &quot;bar&quot; },\r\n    &quot;PKEY4&quot;: {&quot;rank&quot;: 3, &quot;attr&quot;: &quot;abc&quot; }\r\n    }",
        "link": "https://stackoverflow.com/questions/54551554/bash-jq-build-array-using-primary-key",
        "title": "Bash jq; build array using primary key"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1549459663,
                "creation_date": 1549459663,
                "answer_id": 54554772,
                "question_id": 54554227,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I&#39;m not a jq expert, but can&#39;t you use something like the below ? You can store into a variable what you parse with jq, and proceed as needed.\r\n\r\n    code=$(app | jq &#39;.code&#39;)\r\n    if [ $code -eq 0 ]  \r\n      then ...\r\n      else ...\r\n    fi\r\n\r\n",
                "title": "How can manage jq return boolean value to bash for future proceed"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1697615710,
                "last_edit_date": 1697615710,
                "creation_date": 1697560113,
                "answer_id": 77310724,
                "question_id": 54554227,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "you can leverage the `-e` option, that sets the exit status of `jq` based on the query:\r\n```bash\r\necho &#39;{&quot;code&quot;: 1}&#39; | jq -e &#39;.code == 0&#39;\r\necho $?      # prints 1\r\n```\r\n\r\nYou can use it to exit by checking the status explicitly\r\n```bash\r\napp | jq -e &#39;.code == 0&#39; || exit 1\r\n\r\n# or\r\n\r\napp | jq -e &#39;.code == 0&#39;\r\nif [ $? -eq 1 ] ; then\r\n  exit 1\r\nfi\r\n```",
                "title": "How can manage jq return boolean value to bash for future proceed"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1697615710,
        "creation_date": 1549457926,
        "last_edit_date": 1549462405,
        "question_id": 54554227,
        "body_markdown": "I have to proceed output from app which produce JSON output.\r\nMust check &quot;code&quot; filed if it&#39;s different from 0 to make some actions.\r\nDecide to done it in Bash script but now I can&#39;t find a way (jq totally noob) to return boolean false or exit 0 to next switch case.\r\n\r\n\r\nThat&#39;s what I&#39;ve tried:\r\n\r\n    app | jq -r &#39;if (.code != 0 ) then (@sh &#39;exit 1&#39;) else empty end&#39;\r\n    app | jq -r &#39;if (.code != 0 ) then (boolean (false)) else empty end&#39;\r\n\r\nbut all time errors like:\r\n\r\n    jq: error: syntax error, unexpected INVALID_CHARACTER (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n    if (.code != 0 ) then (@sh &#39;exit 1&#39;) else empty end                           \r\n    jq: 1 compile error\r\n    exit status 3\r\n\r\nThat&#39;s the input JSON\r\n\r\nAnd the output is extensive (that&#39;s not complete output)\r\n\r\n    {\r\n      &quot;code&quot; : 0,\r\n      &quot;description&quot; : &quot;Success&quot;,\r\n      &quot;response&quot; : {\r\n        &quot;properties&quot; : [\r\n            {\r\n                &quot;name&quot; : &quot;name&quot;,\r\n                &quot;value&quot; : &quot;\\&quot;cam_src_pipe\\&quot;&quot;,\r\n                &quot;param&quot; : {\r\n                    &quot;description&quot; : &quot;The name of the current Gstd session&quot;,\r\n                    &quot;type&quot; : &quot;gchararray&quot;,\r\n                    &quot;access&quot; : &quot;((GstdParamFlags) READ | 234)&quot;\r\n                }\r\n            },\r\n            {\r\n                &quot;name&quot; : &quot;description&quot;,\r\n                &quot;value&quot; : &quot;\\&quot;imxv4l2videosrc imx-capture-mode=0 ! imxipuvideotransform deinterlace=true ! interpipesink name=cam_src caps=video/x-raw,width=640,height=480,framerate=30/1 sync=true async=false forw\r\n    ard-eos=true\\&quot;&quot;,\r\n                &quot;param&quot; : {\r\n                    &quot;description&quot; : &quot;The gst-launch like pipeline description&quot;,\r\n                    &quot;type&quot; : &quot;gchararray&quot;,\r\n                    &quot;access&quot; : &quot;((GstdParamFlags) READ | 234)&quot;\r\n                }\r\n            },\r\n            {\r\n                &quot;name&quot; : &quot;elements&quot;,\r\n                &quot;value&quot; : &quot;((GstdList*) 0x560c63a0)&quot;,\r\n                &quot;param&quot; : {\r\n                    &quot;description&quot; : &quot;The elements in the pipeline&quot;,\r\n                    &quot;type&quot; : &quot;GstdList&quot;,\r\n                    &quot;access&quot; : &quot;((GstdParamFlags) READ | 224)&quot;\r\n                }\r\n            },\r\n\r\nI have to get boolean false or exit 1 to proceed with Bash \r\n\r\n",
        "link": "https://stackoverflow.com/questions/54554227/how-can-manage-jq-return-boolean-value-to-bash-for-future-proceed",
        "title": "How can manage jq return boolean value to bash for future proceed"
    },
    {
        "tags": [
            "arrays",
            "select",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1549482882,
                "last_edit_date": 1549482882,
                "creation_date": 1549471117,
                "answer_id": 54558457,
                "question_id": 54558107,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Depending on your precise requirements, you could use `map(select(...))` or `.[] | select(...)`, along the lines of, for example:\r\n\r\n    .tag[] | select(.k == &quot;name&quot;) | .v\r\n\r\nYou might want to make this more robust, for example by taking into account the possibility that there might not be exactly one &quot;name&quot;:\r\n\r\n    first(.tag[] | select(.k == &quot;name&quot;) | .v // null)",
                "title": "How to extract specific field from JSON array with jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1549472386,
                "last_edit_date": 1549472386,
                "creation_date": 1549471823,
                "answer_id": 54558661,
                "question_id": 54558107,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Ok, I got it:\r\n\r\n    {lat: .lat, lon: .lon, tag: .tag[]}\r\n    | select(.tag.k==&quot;name&quot;) \r\n    | {lat: .lat, lon: .lon, name: .tag.v}\r\n\r\nThe trick was to use `.tag[]` which multiplies each entry with the number of array elements in `.tag`, then to select the relevant entries and then to construct the output JSON. Thanks for the hint, @peak!",
                "title": "How to extract specific field from JSON array with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1549482882,
        "creation_date": 1549470034,
        "question_id": 54558107,
        "body_markdown": "I want to process JSON data using jq. Here is an excerpt from the data:\r\n\r\n    {\r\n      &quot;lat&quot;: &quot;49.3877286&quot;,\r\n      &quot;lon&quot;: &quot;6.704062&quot;,\r\n      &quot;tag&quot;: [\r\n        {\r\n          &quot;k&quot;: &quot;name&quot;,\r\n          &quot;v&quot;: &quot;Beckingen&quot;\r\n        },\r\n        {\r\n          &quot;k&quot;: &quot;is_in&quot;,\r\n          &quot;v&quot;: &quot;Merzig-Wadern,Saarland,Bundesrepublik Deutschland,Europe&quot;\r\n        },\r\n        {\r\n          &quot;k&quot;: &quot;place&quot;,\r\n          &quot;v&quot;: &quot;town&quot;\r\n        },\r\n      ]\r\n    }\r\n    {\r\n      &quot;lat&quot;: &quot;49.287307&quot;,\r\n      &quot;lon&quot;: &quot;6.8827786&quot;,\r\n      &quot;tag&quot;: [\r\n        {\r\n          &quot;k&quot;: &quot;name&quot;,\r\n          &quot;v&quot;: &quot;P&#252;ttlingen&quot;\r\n        },\r\n        {\r\n          &quot;k&quot;: &quot;place&quot;,\r\n          &quot;v&quot;: &quot;town&quot;\r\n        },\r\n        {\r\n          &quot;k&quot;: &quot;population&quot;,\r\n          &quot;v&quot;: &quot;18748&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\n\r\nI need to extract the `lat`, `lon`, and `name` fields, like this:\r\n\r\n    {\r\n      &quot;lat&quot;: &quot;49.3877286&quot;,\r\n      &quot;lon&quot;: &quot;6.704062&quot;,\r\n      &quot;name&quot;: &quot;Beckingen&quot;\r\n    },\r\n    {\r\n      &quot;lat&quot;: &quot;49.287307&quot;,\r\n      &quot;lon&quot;: &quot;6.8827786&quot;,\r\n      &quot;name&quot;: &quot;P&#252;ttlingen&quot;\r\n    }\r\n\r\nI&#39;m almost there, but I can&#39;t figure out how to select a field from an array using `select()`. Can anyone point me in the right direction?\r\n\r\nMany thanks,\r\n\r\nEnno\r\n",
        "link": "https://stackoverflow.com/questions/54558107/how-to-extract-specific-field-from-json-array-with-jq",
        "title": "How to extract specific field from JSON array with jq"
    },
    {
        "tags": [
            "javascript",
            "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": 1549490645,
                "post_id": 54562183,
                "comment_id": 95925417,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 40542,
                    "reputation": 71057,
                    "user_id": 117471,
                    "user_type": "registered",
                    "accept_rate": 31,
                    "profile_image": "https://www.gravatar.com/avatar/959ccd33301cb3c15953c1a632a36763?s=256&d=identicon&r=PG",
                    "display_name": "Bruno Bronosky",
                    "link": "https://stackoverflow.com/users/117471/bruno-bronosky"
                },
                "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": 1549500871,
                "post_id": 54562183,
                "comment_id": 95928374,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1549510481,
                "post_id": 54562183,
                "comment_id": 95930177,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 40542,
                    "reputation": 71057,
                    "user_id": 117471,
                    "user_type": "registered",
                    "accept_rate": 31,
                    "profile_image": "https://www.gravatar.com/avatar/959ccd33301cb3c15953c1a632a36763?s=256&d=identicon&r=PG",
                    "display_name": "Bruno Bronosky",
                    "link": "https://stackoverflow.com/users/117471/bruno-bronosky"
                },
                "reply_to_user": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1549512287,
                "post_id": 54562183,
                "comment_id": 95930594,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1549485436,
                "creation_date": 1549485436,
                "answer_id": 54562184,
                "question_id": 54562183,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Assuming all embedded JSON is a minified dictionary (as is the case with my Terraform output, AWS cli output, and AWS logs) this one `jq` script works wonders.\r\n\r\n```\r\njq &#39;walk(if type == &quot;string&quot; and .[0:2] == &quot;{\\&quot;&quot; then .=(.|fromjson) else . end)&#39;\r\n```\r\n\r\nIt works by walking the json object looking for strings that begin with `{&quot;` and uses a subprocess to pipe them through `fromjson` (never leaving `jq`).\r\n\r\nI put it in a bash function (`jqp`) because it&#39;s easier than escaping the quotes for an alias and MUCH more flexible. Then I can use it to process a file or clipboard contents.\r\n\r\n```\r\n# This is in my .bash_profile\r\njqp(){\r\n  jq &#39;walk(if type == &quot;string&quot; and .[0:2] == &quot;{\\&quot;&quot; then .=(.|fromjson) else . end)&#39; &quot;$@&quot;\r\n}\r\n```\r\n```\r\n# Here is an event trigger from SNS to Lambda\r\n$ cat event.json\r\n{\r\n    &quot;Records&quot;: [\r\n        {\r\n            &quot;EventVersion&quot;: &quot;1.0&quot;,\r\n            &quot;EventSubscriptionArn&quot;: &quot;arn:aws:sns:us-east-1:123456789012:sns-to-slack-shared-services:a70df027-2c7f-492a-840a-633d44fd71a6&quot;,\r\n            &quot;EventSource&quot;: &quot;aws:sns&quot;,\r\n            &quot;Sns&quot;: {\r\n                &quot;SignatureVersion&quot;: &quot;1&quot;,\r\n                &quot;Timestamp&quot;: &quot;2019-02-06T15:50:30.028Z&quot;,\r\n                &quot;Signature&quot;: &quot;GN3712/aWjVLftSzdOcW5Zm32/uvfZKrCcvTmz6Obv/AXbz1xc22sTMYt2vFja7coHGhhO5bG6dz/IbJSx/Zm0U/dVVefWKukFl1umP3av+1JoUbbi+4uHai3k3AwQa3wR4HWjrKKmMt+Tkt/gm7jvhcuojtx+n5oc4S6bMsVq5OmSfAWd2Xd1urTm2zeGCL59nbfhZv+xB4db3dk62FtxVKtFXtvO2pH27+E3vXUvgu2k1c2Kd/Vt/vbYCAA==&quot;,\r\n                &quot;SigningCertUrl&quot;: &quot;https://sns.us-east-1.amazonaws.com/SimpleNotificationService-a70df027-2c7f-492a-840a-633d44fd71a6.pem&quot;,\r\n                &quot;MessageId&quot;: &quot;a8df3067-c347-55ce-b869-64b2c7c1d0a3&quot;,\r\n                &quot;Message&quot;: &quot;{\\&quot;AlarmName\\&quot;:\\&quot;unauthorized_api_calls_Count-alarm\\&quot;,\\&quot;AlarmDescription\\&quot;:\\&quot;This metric monitors unauthorized API calls\\&quot;,\\&quot;AWSAccountId\\&quot;:\\&quot;123456789012\\&quot;,\\&quot;NewStateValue\\&quot;:\\&quot;ALARM\\&quot;,\\&quot;NewStateReason\\&quot;:\\&quot;Threshold Crossed: 1 datapoint [5.0 (06/02/19 15:45:00)] was greater than or equal to the threshold (1.0).\\&quot;,\\&quot;StateChangeTime\\&quot;:\\&quot;2019-02-06T15:50:30.023+0000\\&quot;,\\&quot;Region\\&quot;:\\&quot;US East (N. Virginia)\\&quot;,\\&quot;OldStateValue\\&quot;:\\&quot;INSUFFICIENT_DATA\\&quot;,\\&quot;Trigger\\&quot;:{\\&quot;MetricName\\&quot;:\\&quot;unauthorized_api_calls\\&quot;,\\&quot;Namespace\\&quot;:\\&quot;security_rules\\&quot;,\\&quot;StatisticType\\&quot;:\\&quot;Statistic\\&quot;,\\&quot;Statistic\\&quot;:\\&quot;SUM\\&quot;,\\&quot;Unit\\&quot;:null,\\&quot;Dimensions\\&quot;:[],\\&quot;Period\\&quot;:300,\\&quot;EvaluationPeriods\\&quot;:1,\\&quot;ComparisonOperator\\&quot;:\\&quot;GreaterThanOrEqualToThreshold\\&quot;,\\&quot;Threshold\\&quot;:1.0,\\&quot;TreatMissingData\\&quot;:\\&quot;\\&quot;,\\&quot;EvaluateLowSampleCountPercentile\\&quot;:\\&quot;\\&quot;}}&quot;,\r\n                &quot;MessageAttributes&quot;: {},\r\n                &quot;Type&quot;: &quot;Notification&quot;,\r\n                &quot;UnsubscribeUrl&quot;: &quot;https://sns.us-east-1.amazonaws.com/?Action=Unsubscribe&amp;SubscriptionArn=arn:aws:sns:us-east-1:123456789012:sns-to-slack-shared-services:a70df027-2c7f-492a-840a-633d44fd71a6&quot;,\r\n                &quot;TopicArn&quot;: &quot;arn:aws:sns:us-east-1:123456789012:sns-to-slack-shared-services&quot;,\r\n                &quot;Subject&quot;: &quot;ALARM: \\&quot;unauthorized_api_calls_Count-alarm\\&quot; in US East (N. Virginia)&quot;\r\n            }\r\n        }\r\n    ]\r\n}\r\n\r\n# Demonstrate that &quot;$@&quot; in the function allows the use of extra options\r\n$ jqp --indent 4 event.json\r\n{\r\n    &quot;Records&quot;: [\r\n        {\r\n            &quot;EventVersion&quot;: &quot;1.0&quot;,\r\n            &quot;EventSubscriptionArn&quot;: &quot;arn:aws:sns:us-east-1:123456789012:sns-to-slack-shared-services:a70df027-2c7f-492a-840a-633d44fd71a6&quot;,\r\n            &quot;EventSource&quot;: &quot;aws:sns&quot;,\r\n            &quot;Sns&quot;: {\r\n                &quot;SignatureVersion&quot;: &quot;1&quot;,\r\n                &quot;Timestamp&quot;: &quot;2019-02-06T15:50:30.028Z&quot;,\r\n                &quot;Signature&quot;: &quot;GN3712/aWjVLftSzdOcW5Zm32/uvfZKrCcvTmz6Obv/AXbz1xc22sTMYt2vFja7coHGhhO5bG6dz/IbJSx/Zm0U/dVVefWKukFl1umP3av+1JoUbbi+4uHai3k3AwQa3wR4HWjrKKmMt+Tkt/gm7jvhcuojtx+n5oc4S6bMsVq5OmSfAWd2Xd1urTm2zeGCL59nbfhZv+xB4db3dk62FtxVKtFXtvO2pH27+E3vXUvgu2k1c2Kd/Vt/vbYCAA==&quot;,\r\n                &quot;SigningCertUrl&quot;: &quot;https://sns.us-east-1.amazonaws.com/SimpleNotificationService-a70df027-2c7f-492a-840a-633d44fd71a6.pem&quot;,\r\n                &quot;MessageId&quot;: &quot;a8df3067-c347-55ce-b869-64b2c7c1d0a3&quot;,\r\n                &quot;Message&quot;: {\r\n                    &quot;AlarmName&quot;: &quot;unauthorized_api_calls_Count-alarm&quot;,\r\n                    &quot;AlarmDescription&quot;: &quot;This metric monitors unauthorized API calls&quot;,\r\n                    &quot;AWSAccountId&quot;: &quot;123456789012&quot;,\r\n                    &quot;NewStateValue&quot;: &quot;ALARM&quot;,\r\n                    &quot;NewStateReason&quot;: &quot;Threshold Crossed: 1 datapoint [5.0 (06/02/19 15:45:00)] was greater than or equal to the threshold (1.0).&quot;,\r\n                    &quot;StateChangeTime&quot;: &quot;2019-02-06T15:50:30.023+0000&quot;,\r\n                    &quot;Region&quot;: &quot;US East (N. Virginia)&quot;,\r\n                    &quot;OldStateValue&quot;: &quot;INSUFFICIENT_DATA&quot;,\r\n                    &quot;Trigger&quot;: {\r\n                        &quot;MetricName&quot;: &quot;unauthorized_api_calls&quot;,\r\n                        &quot;Namespace&quot;: &quot;security_rules&quot;,\r\n                        &quot;StatisticType&quot;: &quot;Statistic&quot;,\r\n                        &quot;Statistic&quot;: &quot;SUM&quot;,\r\n                        &quot;Unit&quot;: null,\r\n                        &quot;Dimensions&quot;: [],\r\n                        &quot;Period&quot;: 300,\r\n                        &quot;EvaluationPeriods&quot;: 1,\r\n                        &quot;ComparisonOperator&quot;: &quot;GreaterThanOrEqualToThreshold&quot;,\r\n                        &quot;Threshold&quot;: 1,\r\n                        &quot;TreatMissingData&quot;: &quot;&quot;,\r\n                        &quot;EvaluateLowSampleCountPercentile&quot;: &quot;&quot;\r\n                    }\r\n                },\r\n                &quot;MessageAttributes&quot;: {},\r\n                &quot;Type&quot;: &quot;Notification&quot;,\r\n                &quot;UnsubscribeUrl&quot;: &quot;https://sns.us-east-1.amazonaws.com/?Action=Unsubscribe&amp;SubscriptionArn=arn:aws:sns:us-east-1:123456789012:sns-to-slack-shared-services:a70df027-2c7f-492a-840a-633d44fd71a6&quot;,\r\n                &quot;TopicArn&quot;: &quot;arn:aws:sns:us-east-1:123456789012:sns-to-slack-shared-services&quot;,\r\n                &quot;Subject&quot;: &quot;ALARM: \\&quot;unauthorized_api_calls_Count-alarm\\&quot; in US East (N. Virginia)&quot;\r\n            }\r\n        }\r\n    ]\r\n}\r\n```",
                "title": "How to use jq to format JSON with embedded, escaped/stringified JSON (for any/all structures)?"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1549516538,
                "last_edit_date": 1549516538,
                "creation_date": 1549491034,
                "answer_id": 54563345,
                "question_id": 54562183,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Running `fromjson` on all strings could be done, e.g. using `walk` and `?`:\r\n\r\n    walk(if type == &quot;string&quot; then fromjson? // . else . end)\r\n\r\n## Leaving numeric strings alone\r\n\r\n    walk(if type == &quot;string&quot;\r\n         then if tonumber? // false then . \r\n              else fromjson? // . end\r\n         else . end)",
                "title": "How to use jq to format JSON with embedded, escaped/stringified JSON (for any/all structures)?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1549516538,
        "creation_date": 1549485436,
        "question_id": 54562183,
        "body_markdown": "There are many questions that say &quot;I have this exact JSON structure, please do my homework for me and make it have this other exact structure.&quot; This is NOT one of those questions.\r\n\r\nI want to see `jq` scripts for cleaning up generic data. I will post an answer below that works pretty well for most of the data I get out of my logs. But, seeing as there are many smart people out here, I want to see what others come up with.\r\n\r\n**Note:** This is not a duplicate of other questions, because the nature of every question I have seen on SO results in answers that are pretty much only useful to the OP. The answers to this question should be helpful to everyone Googling for something similar. Some lucky answerer will get a reputation bomb [like I did with my answer here][1].\r\n\r\n\r\n  [1]: https://stackoverflow.com/questions/192249/how-do-i-parse-command-line-arguments-in-bash/14203146#14203146",
        "link": "https://stackoverflow.com/questions/54562183/how-to-use-jq-to-format-json-with-embedded-escaped-stringified-json-for-any-al",
        "title": "How to use jq to format JSON with embedded, escaped/stringified JSON (for any/all structures)?"
    },
    {
        "tags": [
            "json",
            "parsing",
            "text",
            "jq",
            "converters"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 15284249,
                    "reputation": 3,
                    "user_id": 11027721,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b47082acfa67a6ddefb4ddb8fbac4226?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "madum",
                    "link": "https://stackoverflow.com/users/11027721/madum"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1549539595,
                "post_id": 54572477,
                "comment_id": 95942679,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1549544999,
                "post_id": 54572477,
                "comment_id": 95945937,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 15284249,
                    "reputation": 3,
                    "user_id": 11027721,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b47082acfa67a6ddefb4ddb8fbac4226?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "madum",
                    "link": "https://stackoverflow.com/users/11027721/madum"
                },
                "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": 1549548847,
                "post_id": 54572477,
                "comment_id": 95948170,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1549575171,
                "last_edit_date": 1549575171,
                "creation_date": 1549565616,
                "answer_id": 54580338,
                "question_id": 54572477,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Your def for `parse_line` produces a stream of JSON entities, whereas you evidently want a JSON array.  Using your regex, you could write:\r\n\r\n    def parse:\r\n      def parse_line:\r\n        match(&quot;(\\\\d+-\\\\d+-\\\\d+) (\\\\d+:\\\\d+:\\\\d+) (D|.).* +(\\\\d+) +(\\\\d+) +(.*\\\\\\\\)([^\\\\\\\\]*)\\\\.(.*)&quot;)\r\n        | .captures\r\n        | map(.string)\r\n        | { &quot;date&quot; :.[0],\r\n            &quot;time&quot; :.[1],\r\n            &quot;attr&quot; :.[2],\r\n            &quot;size&quot; :.[3],\r\n            &quot;path&quot; :.[5],\r\n            &quot;name&quot; :.[6],\r\n            &quot;extn&quot; :.[7] } ;\r\n      \r\n      [inputs | parse_line];\r\n    \r\n    parse\r\n\r\n \r\n## Invocation\r\n    jq -nR -f 7z.jq 7z.txt\r\n\r\n## Alternative regex\r\nThe regex fragment `(D|.).*` does not make much sense. \r\n You should consider replacing it by `(.)[^ ]*` or some such.\r\n\r\n## A simpler solution\r\n\r\n    def parse_line:\r\n      capture(&quot;(?&lt;date&gt;\\\\d+-\\\\d+-\\\\d+) &quot; \r\n      + &quot;(?&lt;time&gt;\\\\d+:\\\\d+:\\\\d+) &quot; \r\n      + &quot;(?&lt;attr&gt;.)[^ ]* +&quot; \r\n      + &quot;(?&lt;size&gt;\\\\d+) +\\\\d+ +&quot;\r\n      + &quot;(?&lt;path&gt;.*\\\\\\\\)&quot;\r\n      + &quot;(?&lt;name&gt;[^\\\\\\\\]*)\\\\.&quot;\r\n      + &quot;(?&lt;extn&gt;.*)&quot;);\r\n\r\n    [inputs | parse_line]\r\n\r\n## An alternative approach\r\n\r\nFrom the comment about JSONEdit, it seems likely to me that your overall approach might be suboptimal.  Have you considered using jq rather than jq with JSONEdit?\r\n\r\n",
                "title": "How to fix missing json block separator"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1549575171,
        "creation_date": 1549539343,
        "question_id": 54572477,
        "body_markdown": "I&#39;m trying to convert 7z file content list to json and can&#39;t fix missing separator between output converted blocks.\r\n\r\nI&#39;m little bit newbie in json conversion, but found that jq could do the job.\r\nI read the [jq documentation](https://stedolan.github.io/jq/manual) and found examples [inside here](https://stackoverflow.com/questions/52291785/convert-data-in-a-text-file-into-json) and [there](https://stackoverflow.com/questions/38860529/create-json-using-jq-from-pipe-separated-keys-and-values-in-bash) also elsewhere without solution.\r\n\r\n\r\n##Please find the use case:##\r\n\r\n###The command line:###\r\n&lt;pre&gt;    jq -f pf_7z.jq -R &lt; demo.lst&lt;/pre&gt;\r\n\r\n##The input file demo.lst:##\r\n       Date      Time    Attr         Size   Compressed  Name\r\n    ------------------- ----- ------------ ------------  ------------------------\r\n    2018-06-23 14:02:16 D....            0            0  Installer\r\n    2018-06-23 14:02:16 .....         3381         1157  Installer\\Readme\r\n    2018-06-23 14:02:16 .....         4646         1157  Installer\\License.txt\r\n    2018-06-23 14:02:16 .....       138892       136152  Installer\\Setup.exe\r\n\r\n\r\n###The filter file pf7z.jq:###\r\n\r\n    def parse:\r\n\r\n    def parse_line:\r\n    . | map(match(&quot;(\\\\d+-\\\\d+-\\\\d+) (\\\\d+:\\\\d+:\\\\d+) (D|.).* +(\\\\d+) +(\\\\d+) +(.*\\\\\\\\)([^\\\\\\\\]*)\\\\.(.*)&quot;)) | .[] |\r\n    ({ \r\n      &quot;date&quot; :(.captures[0].string),\r\n      &quot;time&quot; :(.captures[1].string),\r\n      &quot;attr&quot; :(.captures[2].string),\r\n      &quot;size&quot; :(.captures[3].string),\r\n      &quot;path&quot; :(.captures[5].string),\r\n      &quot;name&quot; :(.captures[6].string),\r\n      &quot;extn&quot; :(.captures[7].string)\r\n    });\r\n\r\n    split(&quot;\\n&quot;) | ( {} + (parse_line));\r\n    \r\n    parse\r\n\r\n\r\n\r\n###The expected result should be:###\r\n{\r\n  &quot;date&quot;: &quot;2018-06-23&quot;,\r\n  &quot;time&quot;: &quot;14:02:16&quot;,\r\n  &quot;attr&quot;: &quot;.&quot;,\r\n  &quot;size&quot;: &quot;4646&quot;,\r\n  &quot;path&quot;: &quot;Installer\\\\&quot;,\r\n  &quot;name&quot;: &quot;License&quot;,\r\n  &quot;extn&quot;: &quot;txt&quot;\r\n},\r\n{\r\n  &quot;date&quot;: &quot;2018-06-23&quot;,\r\n  &quot;time&quot;: &quot;14:02:16&quot;,\r\n  &quot;attr&quot;: &quot;.&quot;,\r\n  &quot;size&quot;: &quot;138892&quot;,\r\n  &quot;path&quot;: &quot;Installer\\\\&quot;,\r\n  &quot;name&quot;: &quot;Setup&quot;,\r\n  &quot;extn&quot;: &quot;exe&quot;\r\n}\r\n\r\n\r\n###And I only got :###\r\n{\r\n  &quot;date&quot;: &quot;2018-06-23&quot;,\r\n  &quot;time&quot;: &quot;14:02:16&quot;,\r\n  &quot;attr&quot;: &quot;.&quot;,\r\n  &quot;size&quot;: &quot;4646&quot;,\r\n  &quot;path&quot;: &quot;Installer\\\\&quot;,\r\n  &quot;name&quot;: &quot;License&quot;,\r\n  &quot;extn&quot;: &quot;txt&quot;\r\n}\r\n{\r\n  &quot;date&quot;: &quot;2018-06-23&quot;,\r\n  &quot;time&quot;: &quot;14:02:16&quot;,\r\n  &quot;attr&quot;: &quot;.&quot;,\r\n  &quot;size&quot;: &quot;138892&quot;,\r\n  &quot;path&quot;: &quot;Installer\\\\&quot;,\r\n  &quot;name&quot;: &quot;Setup&quot;,\r\n  &quot;extn&quot;: &quot;exe&quot;\r\n}\r\n\r\nwithout the comma separator between blocks.\r\n\r\nThanks ;-)\r\n\r\n",
        "link": "https://stackoverflow.com/questions/54572477/how-to-fix-missing-json-block-separator",
        "title": "How to fix missing json block separator"
    },
    {
        "tags": [
            "arrays",
            "json",
            "bash",
            "variables",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1549610727,
                "last_edit_date": 1549610727,
                "creation_date": 1549608749,
                "answer_id": 54587347,
                "question_id": 54586848,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The following tweaks are sufficient to get your script to run to completion normally:\r\n\r\n1. Fix inconsistent naming\r\n\r\n    median0x =&gt; medianHex\r\n    time0x =&gt; timeHex\r\n\r\n2. Change invocation (drop quotation marks)\r\n\r\n    jq -n ${_jqArgs[@]} ...\r\n\r\n## Handling the bash arrays\r\n\r\nRegarding the bash arrays, I would suggest in your case reading them in separately, e.g. using the technique illustrated by the following:\r\n\r\n    jq -nc --argjson vs &quot;$(printf &#39;%s\\n&#39; &quot;${validSources[@]}&quot; | jq -nR &#39;[inputs]&#39;)&quot; &#39;$vs&#39;\r\n\r\nWith your data, this produces:\r\n\r\n    [&quot;Bitfinex&quot;,&quot;Poloniex&quot;,&quot;Coinbase&quot;]\r\n\r\n## Constructing `.sources`\r\nYou can then use $vs and the analogously obtained $vp to construct the object you want as `.sources`, e.g. along the lines of:\r\n\r\n    [$vs, $vp] | transpose | map({(.[0]): .[1]}) | add\r\n\r\n    ",
                "title": "How can I pass in bash variables and generate dynamic JSON with jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1549612753,
        "creation_date": 1549606030,
        "last_edit_date": 1549612753,
        "question_id": 54586848,
        "body_markdown": "I have a bunch of bash vars that I want to turn into JSON with a very specific format. I&#39;m having trouble passing them in as arguments to jq and scratching my head how to then loop through the 2 arrays within jq itself. Maybe I should manually transpose the two arrays as JSON first and then pass in that JSON to jq through `--argjson`?\r\n\r\nHere&#39;s what I&#39;ve written so far.\r\n\r\n```\r\n#!/usr/bin/env bash                                                                                                                                                                                                                       \r\n\r\n#example data                                                                                                                                                                                                                             \r\n_assetPair=BTCUSD\r\n_version=0.9.1\r\n_median=103.96\r\n_medianHex=&quot;000000000000000000000000000000000000000000000005a2bc1d32419c0000&quot;\r\n_time=1549524531\r\n_timeHex=&quot;000000000000000000000000000000000000000000000000000000005c5bde33&quot;\r\n_hash=&quot;db035aa02562167d23f657bb6f1030ba962d476f18a51c5c651b6b4b0&quot;\r\n_signature=&quot;51cd021f3c3edf1600aafaa81e366cd14543125dd7ec4c1da91765b0e632cfd313a3b8a291153262531e7027163ffe1239ddc9cc42815ddfcf70404a6cb5f2d71b&quot;\r\n\r\n#the size of the two below arrays is always equal but not known ahead of time                                                                                                                                                             \r\n#unsure how to pass/use these in jq                                                                                                                                                                                                       \r\n#if I pass in the elements I won&#39;t know which handle to call them with in jq                                                                                                                                                              \r\n#maybe need some transpose magic here                                                                                                                                                                                                     \r\nvalidSources=()\r\nvalidPrices=()\r\nvalidSources+=( &quot;Bitfinex&quot; &quot;Poloniex&quot; &quot;Coinbase&quot; )\r\nvalidPrices+=( &quot;104.61&quot; &quot;102.88&quot; &quot;103.96&quot;)\r\n\r\n#Create jq input argument list                                                                                                                                                                                                            \r\n_jqArgs=()\r\n_jqArgs=( &quot;--arg assetPair $_assetPair&quot; &quot;--arg version $_version&quot; &quot;--arg median $_median&quot; &quot;--arg median0x $_medianHex&quot; &quot;--arg time $_time&quot; &quot;--arg time0x $_timeHex&quot; &quot;--arg hash ${_hash:2}&quot; &quot;--arg signature ${_signature:2}&quot; )\r\nfor index in ${!validSources[*]}; do\r\n    _jqArgs+=( --arg &quot;${validSources[index]}&quot; &quot;${validPrices[index]}&quot; )\r\ndone\r\n\r\n#sanity check                                                                                                                                                                                                                             \r\necho &quot;${_jqArgs[@]}&quot;\r\n\r\n#generate json                                                                                                                                                                                                                            \r\njq -n &quot;${_jqArgs[@]}&quot; &#39;{assetPair: $assetPair, version: $version, median: $median | tonumber, medianHex: $medianHex, time: $time | tonumber, timeHex: $timeHex, hash: $hash, signature: $signature}&#39;\r\n```\r\n\r\nWhen I run the above script here&#39;s the error output I&#39;m getting.\r\n```\r\nbash-5.0$ ./test.sh\r\n--arg assetPair BTCUSD --arg version 0.9.1 --arg median 103.96 --arg median0x 000000000000000000000000000000000000000000000005a2bc1d32419c0000 --arg time 1549524531 --arg time0x 000000000000000000000000000000000000000000000000000000005c5bde33 --arg hash 035aa02562167d23f657bb6f1030ba962d476f18a51c5c651b6b4b0 --arg signature cd021f3c3edf1600aafaa81e366cd14543125dd7ec4c1da91765b0e632cfd313a3b8a291153262531e7027163ffe1239ddc9cc42815ddfcf70404a6cb5f2d71b --arg Bitfinex 104.61 --arg Poloniex 102.88 --arg Coinbase 103.96\r\njq: Unknown option --arg assetPair BTCUSD\r\n```\r\n\r\nIve tried adding escaped double quotes around BTCUSD when assigning it to assetPair in jqArgs but that returned the same error.\r\n\r\n\r\nI&#39;m expecting output like this:\r\n```\r\n{\r\n   &quot;assetPair&quot;: &quot;BTCUSD&quot;,\r\n   &quot;version&quot;: &quot;0.9.1&quot;,\r\n   &quot;median&quot;: 103.96,\r\n   &quot;medianHex: &quot;000000000000000000000000000000000000000000000005a2bc1d32419c0000&quot;,\r\n   &quot;time&quot;: 1549524531,\r\n   &quot;timeHex&quot;: &quot;000000000000000000000000000000000000000000000000000000005c5bde33&quot;,\r\n   &quot;hash&quot;: &quot;db035aa02562167d23f657bb6f1030ba962d476f18a51c5c651b6b4b0&quot;,\r\n   &quot;signature&quot;: &quot;51cd021f3c3edf1600aafaa81e366cd14543125dd7ec4c1da91765b0e632cfd313a3b8a291153262531e7027163ffe1239ddc9cc42815ddfcf70404a6cb5f2d71b&quot;,\r\n   &quot;sources&quot;: {\r\n      &quot;Bitfinex&quot;: &quot;104.61&quot;,\r\n      &quot;Coinbase: &quot;103.96&quot;,\r\n      &quot;Poloniex&quot;: &quot;102.88&quot;\r\n   }\r\n}\r\n```\r\n\r\n",
        "link": "https://stackoverflow.com/questions/54586848/how-can-i-pass-in-bash-variables-and-generate-dynamic-json-with-jq",
        "title": "How can I pass in bash variables and generate dynamic JSON with jq?"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1549667037,
                "post_id": 54601240,
                "comment_id": 95999119,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 13890823,
                    "reputation": 45,
                    "user_id": 10028865,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/-zJCg6FAOFN8/AAAAAAAAAAI/AAAAAAAAAAA/AB6qoq3qo7W6s6fkuf3IaMyhPfU_DBY1fg/mo/s256-rj/photo.jpg",
                    "display_name": "Anna",
                    "link": "https://stackoverflow.com/users/10028865/anna"
                },
                "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": 1549668087,
                "post_id": 54601240,
                "comment_id": 95999335,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1549668482,
                "last_edit_date": 1549668482,
                "creation_date": 1549667198,
                "answer_id": 54601439,
                "question_id": 54601240,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "### Using `jq` as a template engine\r\n\r\nIf you don&#39;t *really* need `input.json` to be a separate file, the easy thing to do is to define your entire template as a jq expression:\r\n\r\n```\r\nvar1=&quot;red&quot;\r\nvar2=&quot;european.flowers&quot;\r\nvar3=&quot;european_vegetables&quot;\r\nvar4=&quot;20&quot;\r\njq -n --arg var1 &quot;$var1&quot; --arg var2 &quot;$var2&quot; --arg var3 &quot;$var3&quot; --arg var4 &quot;$var4&quot; &#39;\r\n{\r\n &quot;plants&quot;: {\r\n  &quot;\\($var2)&quot;: {\r\n    &quot;colour&quot;: $var1,\r\n    &quot;age&quot;: &quot;&quot;,\r\n    &quot;\\($var3)&quot;: {\r\n     &quot;root&quot;: &quot;&quot;,\r\n     &quot;height&quot;: $var4\r\n    }\r\n  }\r\n }\r\n}&#39;\r\n```\r\n\r\nemits as output:\r\n\r\n```\r\n{\r\n  &quot;plants&quot;: {\r\n    &quot;european.flowers&quot;: {\r\n      &quot;colour&quot;: &quot;red&quot;,\r\n      &quot;age&quot;: &quot;&quot;,\r\n      &quot;european_vegetables&quot;: {\r\n        &quot;root&quot;: &quot;&quot;,\r\n        &quot;height&quot;: &quot;20&quot;\r\n      }\r\n    }\r\n  }\r\n}\r\n```\r\n\r\n---\r\n\r\n### Alternately: Renaming subtrees\r\n\r\nIf you *really do* want to rename an existing key, consider an approach like the below. Using jq variables for the template fields isn&#39;t mandatory, but it does make it easier to change your code later:\r\n\r\n```\r\nvar1=&quot;red&quot;; var2=&quot;european.flowers&quot;; var3=&quot;european_vegetables&quot;; var4=&quot;20&quot;\r\n\r\njq --arg var1 &quot;$var1&quot; --arg var2 &quot;$var2&quot; --arg var3 &quot;$var3&quot; --arg var4 &quot;$var4&quot; &#39;\r\n\r\n  # set variables for the fields we expect to see in our input\r\n  &quot;flowers.small&quot; as $plant_tmpl |\r\n  &quot;vegetables&quot; as $cat_tmpl |\r\n\r\n  # change things inside fields we will later rename *before* we rename those fields\r\n  .plants[$plant_tmpl].colour = $var1 |\r\n  .plants[$plant_tmpl][$cat_tmpl].height = $var4 |\r\n\r\n  if $var3 == $cat_tmpl then . else\r\n    # var3 is not &quot;vegetables&quot; (templated value), so we need to rename it\r\n    .plants[$plant_tmpl][$var3] = .plants[$plant_tmpl][$cat_tmpl] |\r\n    del(.plants[$plant_tmpl][$cat_tmpl])\r\n  end |\r\n\r\n  if $var2 == $plant_tmpl then . else\r\n    .plants[$var2] = .plants[$plant_tmpl] |\r\n    del(.plants[$plant_tmpl])\r\n  end\r\n&#39; &lt;&lt;&#39;EOF&#39;\r\n{\r\n &quot;plants&quot;: {\r\n  &quot;flowers.small&quot;: {\r\n    &quot;colour&quot;: &quot;&quot;,\r\n    &quot;age&quot;: &quot;&quot;,\r\n    &quot;vegetables&quot;: {\r\n     &quot;root&quot;: &quot;&quot;,\r\n     &quot;height&quot;: &quot;&quot;\r\n    }\r\n  }\r\n }\r\n}\r\nEOF\r\n```",
                "title": "Using jq to change json object and field value from variable"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1549668746,
                "last_edit_date": 1549668746,
                "creation_date": 1549668210,
                "answer_id": 54601578,
                "question_id": 54601240,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I suspect this is very close to what you want:\r\n\r\n    #!/bin/bash\r\n    \r\n    var1=&quot;red&quot;\r\n    var2=&quot;european.flowers&quot;\r\n    var3=&quot;european_vegetables&quot;\r\n    var4=&quot;20&quot;\r\n    \r\n    jq --arg var1 &quot;$var1&quot; \\\r\n       --arg var2 &quot;$var2&quot; \\\r\n       --arg var3 &quot;$var3&quot; \\\r\n       --arg var4 &quot;$var4&quot; &#39;\r\n       {&quot;${var1}&quot;: $var1, &quot;${var2}&quot;: $var2, &quot;${var3}&quot;: $var3, &quot;${var4}&quot;: $var4} as $dict\r\n       | walk( if type == &quot;string&quot; and $dict[.] then  $dict[.] \r\n               elif type==&quot;object&quot; then with_entries(if $dict[.key] then .key |= $dict[.] else . end)\r\n               else . end)&#39; template.json\r\n       \r\n\r\nThis general approach is OK, but you might want to check the jq Cookbook for suggestions about using jq as a template engine: https://github.com/stedolan/jq/wiki/Cookbook#using-jq-as-a-template-engine\r\n\r\n## Streamlined version\r\nIf your jq supports `$ARGS`, then you could use this streamlined version of the above:\r\n\r\n    jq --arg &#39;${var1}&#39; &quot;$var1&quot; \\\r\n       --arg &#39;${var2}&#39; &quot;$var2&quot; \\\r\n       --arg &#39;${var3}&#39; &quot;$var3&quot; \\\r\n       --arg &#39;${var4}&#39; &quot;$var4&quot; &#39;\r\n        $ARGS.named as $dict\r\n        | walk( if type == &quot;string&quot; and $dict[.] then  $dict[.] \r\n                elif type==&quot;object&quot; then with_entries(if $dict[.key] then .key |= $dict[.] else . end)\r\n                else . end)&#39; template.json\r\n\r\n",
                "title": "Using jq to change json object and field value from variable"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1549668746,
        "creation_date": 1549665773,
        "question_id": 54601240,
        "body_markdown": "I want to modify the following json using variables specified in a Linux bash shell using jq. \r\n\r\n    var1=&quot;red&quot;\r\n    var2=&quot;european.flowers&quot;\r\n    var3=&quot;european_vegetables&quot;\r\n    var4=&quot;20&quot;\r\n\r\nMy json:\r\n\r\n    {\r\n     &quot;plants&quot;: {\r\n      &quot;flowers.small&quot;: {\r\n        &quot;colour&quot;: &quot;&quot;,\r\n    \t&quot;age&quot;: &quot;&quot;,\r\n    \t&quot;vegetables&quot;: {\r\n    \t &quot;root&quot;: &quot;&quot;,\r\n    \t &quot;height&quot;: &quot;&quot;\r\n    \t}\r\n      }\r\n     }\r\n    }\r\n\r\nI want to modify the json using variables in jq:\r\n\r\n    {\r\n     &quot;plants&quot;: {\r\n      &quot;${var2}&quot;: {\r\n        &quot;colour&quot;: &quot;${var1}&quot;,\r\n    \t&quot;age&quot;: &quot;&quot;,\r\n    \t&quot;${var3}&quot;: {\r\n    \t &quot;root&quot;: &quot;&quot;,\r\n    \t &quot;height&quot;: &quot;${var4}&quot;\r\n    \t}\r\n      }\r\n     }\r\n    }\r\n\r\nI am attempting to just set a field value from a variables: \r\n\r\n**Command:**\r\n\r\n    cat myjson.json|jq &#39;.plants[&quot;flowers.small&quot;].colour = &quot;${var1}&quot;&#39; -c\r\n\r\nThe result is: \r\n\r\n    {&quot;plants&quot;:{&quot;flowers.small&quot;:{&quot;colour&quot;:&quot;${var1}&quot;,&quot;age&quot;:&quot;&quot;,&quot;vegetables&quot;:{&quot;root&quot;:&quot;&quot;,&quot;height&quot;:&quot;&quot;}}}}\r\n\r\n**Command**:\r\n\r\n    cat myjson.json|jq --arg v &quot;$var1&quot; &#39;.plants.[&quot;flowers.small&quot;].colour = [$v]&#39; -c\r\n\r\nThe result is: \r\n\r\n    jq: error: syntax error, unexpected &#39;[&#39;, expecting FORMAT or QQSTRING_START (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n    .plants.[&quot;flowers.small&quot;].colour = $v\r\n    jq: 1 compile error\r\n\r\n\r\nMy jq version is: jq-1.5-1-a5b5cbe\r\n\r\nHow can I rename a field and set a value for the key from the variables?\r\nIs this even doable using the jq version?",
        "link": "https://stackoverflow.com/questions/54601240/using-jq-to-change-json-object-and-field-value-from-variable",
        "title": "Using jq to change json object and field value from variable"
    },
    {
        "tags": [
            "json",
            "elasticsearch",
            "path",
            "jq",
            "flatten"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 15204726,
                    "reputation": 18070,
                    "user_id": 10971581,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/XPQr1.png?s=256",
                    "display_name": "jhnc",
                    "link": "https://stackoverflow.com/users/10971581/jhnc"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1549731952,
                "post_id": 54608267,
                "comment_id": 96011959,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2454782,
                    "reputation": 33,
                    "user_id": 11038410,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/-2Af1jak6dmI/AAAAAAAAAAI/AAAAAAAAC9M/FQjTYPpBQKI/s256-rj/photo.jpg",
                    "display_name": "Douglas Hobson",
                    "link": "https://stackoverflow.com/users/11038410/douglas-hobson"
                },
                "reply_to_user": {
                    "account_id": 15204726,
                    "reputation": 18070,
                    "user_id": 10971581,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/XPQr1.png?s=256",
                    "display_name": "jhnc",
                    "link": "https://stackoverflow.com/users/10971581/jhnc"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1549742519,
                "post_id": 54608267,
                "comment_id": 96015026,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1549777038,
                "last_edit_date": 1549777038,
                "creation_date": 1549769287,
                "answer_id": 54613088,
                "question_id": 54608267,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You evidently already know the solution to the second part of the problem, so here is a solution to the first part:\r\n\r\n    # linearize all paths of the input object or array\r\n    def dotkeys:\r\n      def stringify: map(tostring) | join(&quot;.&quot;);\r\n      . as $in\r\n      | reduce paths(scalars) as $p (null;\r\n         ($in|getpath($p)) as $v\r\n         | setpath([$p|stringify]; $v));\r\n    \r\n    def chain(key):\r\n     .[key] |= dotkeys ;\r\n    \r\n    chain(&quot;level1b&quot;)\r\n\r\n## Output\r\n\r\nWith your input, this produces:\r\n\r\n    {\r\n      &quot;level1a&quot;: &quot;value&quot;,\r\n      &quot;level1b&quot;: {\r\n        &quot;level2a.level3a&quot;: &quot;nestedvalue&quot;,\r\n        &quot;level2b&quot;: &quot;value&quot;\r\n      }\r\n    }",
                "title": "How can I convert a nested part of a JSON object to dot-chained flat JSON?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1549777038,
        "creation_date": 1549730259,
        "last_edit_date": 1549770640,
        "question_id": 54608267,
        "body_markdown": "I want this:\r\n\r\n    {\r\n    \t&quot;level1a&quot;: &quot;value&quot;,\r\n    \t&quot;level1b&quot;: {\r\n    \t\t&quot;level2a&quot;: {\r\n    \t\t\t&quot;level3a&quot;: &quot;nestedvalue&quot;\r\n    \t\t},\r\n    \t\t&quot;level2b&quot;: &quot;value&quot;\r\n    \t}\r\n    }\r\n\r\nTo end up looking like this:\r\n\r\n    {\r\n    \t&quot;level1a&quot;: &quot;value&quot;,\r\n    \t&quot;level1b&quot;: {\r\n    \t\t&quot;level2a.level3a&quot;: &quot;nestedvalue&quot;,\r\n    \t\t&quot;level2b&quot;: &quot;value&quot;\r\n    \t}\r\n    }\r\nAnd then to this:\r\n\r\n    {\r\n    \t&quot;level1a&quot;: &quot;value&quot;,\r\n    \t&quot;level1b&quot;: [{\r\n    \t\t\t&quot;key&quot;: &quot;level2a.level3a&quot;,\r\n    \t\t\t&quot;val&quot;: &quot;nestedvalue&quot;\r\n    \t\t},\r\n    \t\t{\r\n    \t\t\t&quot;key&quot;: &quot;level2b&quot;,\r\n    \t\t\t&quot;val&quot;: &quot;value&quot;\r\n    \t\t}\r\n    \t]\r\n    }\r\n\r\nI only want some nested fields to be dotted and I want to be able to choose which fields. I have a set of JSON documents that has thousands of fields, most of them nested under one or two first or second level fields. \r\n\r\nUltimately I then want to use something like jq&#39;s to_entries on the dot-chained fields to make then ready for ingestion into Elasticsearch as nested fields so as to keep the total number of fields low while still retaining all the information.\r\n\r\nAny thoughts?",
        "link": "https://stackoverflow.com/questions/54608267/how-can-i-convert-a-nested-part-of-a-json-object-to-dot-chained-flat-json",
        "title": "How can I convert a nested part of a JSON object to dot-chained flat JSON?"
    },
    {
        "tags": [
            "python",
            "bash",
            "subprocess",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 35417,
                    "reputation": 1133042,
                    "user_id": 100297,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/24780fb6df85a943c7aea0402c843737?s=256&d=identicon&r=PG",
                    "display_name": "Martijn Pieters",
                    "link": "https://stackoverflow.com/users/100297/martijn-pieters"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1549804528,
                "post_id": 54616696,
                "comment_id": 96026391,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5467878,
                    "reputation": 407,
                    "user_id": 4348131,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/a36fde190b1cc0a05cf43643d20625f5?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Chris",
                    "link": "https://stackoverflow.com/users/4348131/chris"
                },
                "reply_to_user": {
                    "account_id": 35417,
                    "reputation": 1133042,
                    "user_id": 100297,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/24780fb6df85a943c7aea0402c843737?s=256&d=identicon&r=PG",
                    "display_name": "Martijn Pieters",
                    "link": "https://stackoverflow.com/users/100297/martijn-pieters"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1549804977,
                "post_id": 54616696,
                "comment_id": 96026498,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 35417,
                    "reputation": 1133042,
                    "user_id": 100297,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/24780fb6df85a943c7aea0402c843737?s=256&d=identicon&r=PG",
                    "display_name": "Martijn Pieters",
                    "link": "https://stackoverflow.com/users/100297/martijn-pieters"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1549805222,
                "post_id": 54616696,
                "comment_id": 96026564,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1549874503,
                "last_edit_date": 1549874503,
                "creation_date": 1549804923,
                "answer_id": 54616823,
                "question_id": 54616696,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Without a shell, you need two subprocesses.\r\n\r\n    os.makedirs(os.path.dirname(filePath))\r\n    dst = open(filePath, &#39;a&#39;)\r\n\r\n    p0 = Popen([&quot;bw&quot;, &quot;list&quot;, &quot;--session&quot;, session_key, &quot;collections&quot;], \r\n        stdout=PIPE, check=True)\r\n    p1 = Popen([&quot;jq&quot;, &quot;.&quot;], stdout=dst, stdin=p0.stdout, check=True)\r\n    p1.communicate()\r\n    dst.close()\r\n\r\nThis is almost literally lifted from the [documentation.](https://docs.python.org/3.7/library/subprocess.html#replacing-shell-pipeline) There is a [`pipes`](https://docs.python.org/3.7/library/pipes.html) module in the standard library which somewhat simplifies this, though it is arguably clunky; thus, there are also several third-party replacements.\r\n\r\nOn the other hand, perhaps this is one of those situations where you can defend `shell=True`.\r\n\r\n    os.makedirs(os.path.dirname(filePath))\r\n    dst = open(filePath, &#39;a&#39;)\r\n    subprocess.run(&quot;&quot;&quot;\r\n        bw list --session &#39;{}&#39; collections |\r\n        jq .&quot;&quot;&quot;.format(session_key),\r\n        stdout=dst, shell=True, check=True)\r\n    dst.close()\r\n\r\nOn the third hand, if you really want a shell script, why are you writing Python?",
                "title": "Send &#39;jq&#39; output to a file using subprocess"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1549874503,
        "creation_date": 1549803916,
        "question_id": 54616696,
        "body_markdown": "I am not entirely sure how jq works here with subprocess so there is a misunderstanding but I am trying to get the extact format from using jq on the command line ( `jq &gt; file.json`) with subprocess. This is what I have but the following produces an empty file. \r\n\r\n```\r\nos.makedirs(os.path.dirname(filePath))\r\nopen(filePath, &#39;a&#39;).close()\r\n\r\ncall([&quot;bw&quot;, &quot;list&quot;, &quot;--session&quot;, session_key, \\\r\n    &quot;collections&quot;, &quot;|&quot;, &quot;jq&quot;, &quot;.&quot;, &quot;&gt;&quot;, filePath])\r\n\r\n```\r\n\r\nI have also tried \r\n```\r\nwith open(filePath, &quot;w+&quot;) as output:\r\n        call([&quot;bw&quot;, &quot;list&quot;, &quot;--session&quot;, session_key, \\\r\n         &quot;collections&quot;, &quot;|&quot;, &quot;jq&quot;, &quot;.&quot;], stdout=output)\r\n\r\n```\r\nBut this produces a string instead of the actual formatting of jq. Is there a way for me to obtain the stdout jq on the commandline into a file using python?",
        "link": "https://stackoverflow.com/questions/54616696/send-jq-output-to-a-file-using-subprocess",
        "title": "Send &#39;jq&#39; output to a file using subprocess"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq",
            "package.json"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1549857115,
                "last_edit_date": 1549857115,
                "creation_date": 1549820921,
                "answer_id": 54619228,
                "question_id": 54619020,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s one straightforward (if rather pedestrian) solution:\r\n\r\n    .devDependencies[$name] as $v\r\n    | if $v then &quot;devDependencies, \\&quot;\\($name)\\&quot;: \\&quot;\\($v)\\&quot;&quot;\r\n      else .dependencies[$name] as $v\r\n      | if $v then &quot;dependencies, \\&quot;\\($name)\\&quot;: \\&quot;\\($v)\\&quot;&quot; else empty end\r\n      end\r\n\r\n## Invocation\r\n\r\n    jq --arg name split -r -f program.jq input.json\r\n\r\n## More economically\r\n\r\n    {devDependencies,dependencies}\r\n    | map_values(.[$name])\r\n    | to_entries[]\r\n    | select(.value)\r\n    | &quot;\\(.key), \\&quot;\\($name)\\&quot;: \\&quot;\\(.value)&quot;\r\n\r\n## More generically\r\n\r\n    (paths | select( .[-1] == $name )) as $p\r\n    | &quot;\\($p[-2]), \\&quot;\\($name)\\&quot;: \\&quot;\\(getpath($p))\\&quot;&quot;\r\n\r\n",
                "title": "jq print if its a dependency or devdependency with version number"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1549857115,
        "creation_date": 1549819624,
        "last_edit_date": 1549832199,
        "question_id": 54619020,
        "body_markdown": "Recently came across jq library, https://stedolan.github.io/jq/ which promises to solve a problem I&#39;m facing. Given a package name, I want to be able to print if its devdependency or dependency and also print the line so that I get the version number.\r\n\r\n**If I input &quot;split&quot;:** \r\n\r\n**Expected output:**\r\n&gt; dependencies, &quot;split&quot;: &quot;0.3.0&quot;.\r\n\r\nsample package.json\r\n--\r\n    {\r\n        &quot;name&quot;: &quot;universe&quot;,\r\n        &quot;devDependencies&quot;:\r\n        {\r\n            &quot;escape-html&quot;: &quot;^1.0.3&quot;,\r\n            &quot;lucene-query-parser&quot;: &quot;^1.0.1&quot;\r\n        },\r\n        &quot;dependencies&quot;:\r\n        {\r\n            &quot;async&quot;: &quot;^0.2.10&quot;,\r\n            &quot;npm2es&quot;: &quot;~0.4.2&quot;,\r\n            &quot;optimist&quot;: &quot;~0.6.0&quot;,\r\n            &quot;request&quot;: &quot;~2.30.0&quot;,\r\n            &quot;skateboard&quot;: &quot;^1.5.1&quot;,\r\n            &quot;split&quot;: &quot;0.3.0&quot;,\r\n            &quot;weld&quot;: &quot;^0.2.2&quot;\r\n        }\r\n       \r\n    }\r\n\r\n\r\nWith my limited experience with the jq library, I am able to get a true or false value for dependency/devDependency but I need to get the above expected output. Anything that gets me closer to the above expected output is fine too.\r\n\r\nThis is my query:\r\n\r\n&gt; jq -c &#39;{dependencies: .dependencies, devDependencies: .devDependencies}&#39; package.json |  jq .[] | jq &#39;contains({ &quot;split&quot;})&#39;",
        "link": "https://stackoverflow.com/questions/54619020/jq-print-if-its-a-dependency-or-devdependency-with-version-number",
        "title": "jq print if its a dependency or devdependency with version number"
    },
    {
        "tags": [
            "json",
            "linux",
            "bash",
            "debian",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 13789219,
                    "reputation": 53538,
                    "user_id": 9952196,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/cd1a3f93172eb89e221c98e35e6e22b3?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Shawn",
                    "link": "https://stackoverflow.com/users/9952196/shawn"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1549865691,
                "post_id": 54624827,
                "comment_id": 96041931,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 13789219,
                    "reputation": 53538,
                    "user_id": 9952196,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/cd1a3f93172eb89e221c98e35e6e22b3?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Shawn",
                    "link": "https://stackoverflow.com/users/9952196/shawn"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1549865796,
                "post_id": 54624827,
                "comment_id": 96041972,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 16,
                "is_accepted": true,
                "score": 15,
                "last_activity_date": 1549914507,
                "last_edit_date": 1549914507,
                "creation_date": 1549866309,
                "answer_id": 54624970,
                "question_id": 54624827,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use the `length()` function at the end of the filter, after putting the objects list into an array\r\n\r\n\r\n    jq &#39;[.[] | select(.status == &quot;skipped&quot;) | select(.ref | test(&quot;1\\\\.4\\\\.15&quot;))] | length&#39;\r\n\r\nbut for just returning the objects leave out the logic to get the length\r\n\r\n    jq &#39;[.[] | select(.status == &quot;skipped&quot;) | select(.ref | test(&quot;1\\\\.4\\\\.15&quot;))]&#39;\r\n\r\n\r\nThe [`test()`](https://stedolan.github.io/jq/manual/#example80) is a more powerful way to match your regex with JSON strings. The `startswith()` or `endswith()` can&#39;t match strings if they are in the middle.\r\n\r\nUsing variables,\r\n\r\n    ref=&quot;1\\.4\\.15&quot;\r\n    jq --arg status &quot;$status&quot; --arg ref &quot;$ref&quot; \\\r\n        &#39;[.[] | select(.status == $status) | select(.ref | test($ref))]|length&#39; json",
                "title": "JQ, how to count depending on conditions?"
            },
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1549867127,
                "last_edit_date": 1549867127,
                "creation_date": 1549866820,
                "answer_id": 54625061,
                "question_id": 54624827,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "By using map(select(...) or equivalent, you could use `length`, but it is generally more efficient to use a generic counting function, such as:\r\n\r\n    def sigma(s): reduce s as $s (null; .+$s);\r\n    \r\n    sigma(.[] | select(.status==&quot;skipped&quot; and (.ref | startswith(&quot;v1.4.15&quot;) )) | 1)\r\n\r\n## Using shell and environment variables\r\n\r\nUsing shell and environment variables is covered in the jq manual, but in brief, one way to pass in string values is using the command-line option `--arg`, e.g. along the lines of:\r\n\r\n    jq --arg status &quot;$status&quot; --arg ref &quot;$ref&quot; -f program.jq test.json",
                "title": "JQ, how to count depending on conditions?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1550780380,
                "creation_date": 1550780380,
                "answer_id": 54815588,
                "question_id": 54624827,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "For the sake of completeness, this would be an equivalent JSONiq query:\r\n\r\n\r\n    let $a := [\r\n       (: copy-paste the entire array here in plain JSON syntax --\r\n          omitted for the sake of brevity :)\r\n    ]\r\n    return count(\r\n       for $obj in $a[]\r\n       where $obj.status eq &quot;skipped&quot;\r\n             and\r\n             matches($obj.ref, &quot;ˆv&quot;)\r\n       return $obj\r\n    )\r\n",
                "title": "JQ, how to count depending on conditions?"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 8,
        "last_activity_date": 1550780380,
        "creation_date": 1549865411,
        "last_edit_date": 1549867108,
        "question_id": 54624827,
        "body_markdown": "Using jq, I need to **get the count** within an array depending on two criterias: it MUST have `status === &#39;skipped&#39; &amp;&amp; ref.includes(version)`\r\n\r\n\r\n```json\r\n[\r\n  {\r\n    &quot;id&quot;: 15484,\r\n    &quot;sha&quot;: &quot;52606c8da57984d1243f436e5d12e275db29a6e0&quot;,\r\n    &quot;ref&quot;: &quot;v1.4.15&quot;,\r\n    &quot;status&quot;: &quot;canceled&quot;\r\n  },\r\n  {\r\n    &quot;id&quot;: 15483,\r\n    &quot;sha&quot;: &quot;52606c8da57984d1243f436e5d12e275db29a6e0&quot;,\r\n    &quot;ref&quot;: &quot;v1.4.15&quot;,\r\n    &quot;status&quot;: &quot;canceled&quot;\r\n  },\r\n  {\r\n    &quot;id&quot;: 15482,\r\n    &quot;sha&quot;: &quot;1b4ccc1dc17e9b8ddb24550c5566d2be6b03465e&quot;,\r\n    &quot;ref&quot;: &quot;dev&quot;,\r\n    &quot;status&quot;: &quot;success&quot;\r\n  },\r\n  {\r\n    &quot;id&quot;: 15481,\r\n    &quot;sha&quot;: &quot;5b6ec939739c5a1513634f3b58bf96522917571d&quot;,\r\n    &quot;ref&quot;: &quot;dev&quot;,\r\n    &quot;status&quot;: &quot;failed&quot;\r\n  },\r\n  {\r\n    &quot;id&quot;: 15480,\r\n    &quot;sha&quot;: &quot;ec18d46f491a4645c68388df91fc41455b421e71&quot;,\r\n    &quot;ref&quot;: &quot;dev&quot;,\r\n    &quot;status&quot;: &quot;failed&quot;\r\n  },\r\n  {\r\n    &quot;id&quot;: 15479,\r\n    &quot;sha&quot;: &quot;dd83a6d6e58cc5114aed8016341ab3c5b3ebb702&quot;,\r\n    &quot;ref&quot;: &quot;dev&quot;,\r\n    &quot;status&quot;: &quot;failed&quot;\r\n  },\r\n  {\r\n    &quot;id&quot;: 15478,\r\n    &quot;sha&quot;: &quot;18ccaf4bc37bf65470b2c6ddaa69e5b4018354a7&quot;,\r\n    &quot;ref&quot;: &quot;dev&quot;,\r\n    &quot;status&quot;: &quot;success&quot;\r\n  },\r\n  {\r\n    &quot;id&quot;: 15477,\r\n    &quot;sha&quot;: &quot;f90900d733bce2be3d9ba9db25f8b51296bc6f3f&quot;,\r\n    &quot;ref&quot;: &quot;dev&quot;,\r\n    &quot;status&quot;: &quot;failed&quot;\r\n  },\r\n  {\r\n    &quot;id&quot;: 15476,\r\n    &quot;sha&quot;: &quot;3cf0431a161e6c9ca90e8248af7b4ec39c54bfb1&quot;,\r\n    &quot;ref&quot;: &quot;dev&quot;,\r\n    &quot;status&quot;: &quot;failed&quot;\r\n  },\r\n  {\r\n    &quot;id&quot;: 15285,\r\n    &quot;sha&quot;: &quot;d24b46edc75d8f7308dbef37d7b27625ef70c845&quot;,\r\n    &quot;ref&quot;: &quot;dev&quot;,\r\n    &quot;status&quot;: &quot;success&quot;\r\n  },\r\n  {\r\n    &quot;id&quot;: 15265,\r\n    &quot;sha&quot;: &quot;52606c8da57984d1243f436e5d12e275db29a6e0&quot;,\r\n    &quot;ref&quot;: &quot;v1.4.15&quot;,\r\n    &quot;status&quot;: &quot;success&quot;\r\n  },\r\n  {\r\n    &quot;id&quot;: 15264,\r\n    &quot;sha&quot;: &quot;9a15f8d4c950047f88c642abda506110b9b0bbd7&quot;,\r\n    &quot;ref&quot;: &quot;v1.4.15-static&quot;,\r\n    &quot;status&quot;: &quot;skipped&quot;\r\n  },\r\n  {\r\n    &quot;id&quot;: 15263,\r\n    &quot;sha&quot;: &quot;9a15f8d4c950047f88c642abda506110b9b0bbd7&quot;,\r\n    &quot;ref&quot;: &quot;v1.4.15-static&quot;,\r\n    &quot;status&quot;: &quot;skipped&quot;\r\n  },\r\n  {\r\n    &quot;id&quot;: 15262,\r\n    &quot;sha&quot;: &quot;76451d2401001c4c51b9800d3cdf62e4cdcc86ba&quot;,\r\n    &quot;ref&quot;: &quot;v1.4.15-no-js&quot;,\r\n    &quot;status&quot;: &quot;skipped&quot;\r\n  },\r\n  {\r\n    &quot;id&quot;: 15261,\r\n    &quot;sha&quot;: &quot;76451d2401001c4c51b9800d3cdf62e4cdcc86ba&quot;,\r\n    &quot;ref&quot;: &quot;v1.4.15-no-js&quot;,\r\n    &quot;status&quot;: &quot;skipped&quot;\r\n  },\r\n  {\r\n    &quot;id&quot;: 15260,\r\n    &quot;sha&quot;: &quot;515cd1b00062e9cbce05420036f5ecc7a898a4bd&quot;,\r\n    &quot;ref&quot;: &quot;v1.4.15-cli&quot;,\r\n    &quot;status&quot;: &quot;skipped&quot;\r\n  },\r\n  {\r\n    &quot;id&quot;: 15259,\r\n    &quot;sha&quot;: &quot;515cd1b00062e9cbce05420036f5ecc7a898a4bd&quot;,\r\n    &quot;ref&quot;: &quot;v1.4.15-cli&quot;,\r\n    &quot;status&quot;: &quot;skipped&quot;\r\n  },\r\n  {\r\n    &quot;id&quot;: 15258,\r\n    &quot;sha&quot;: &quot;b67acd3082da795f022fafc304d267d3afd6b736&quot;,\r\n    &quot;ref&quot;: &quot;v1.4.15-node&quot;,\r\n    &quot;status&quot;: &quot;skipped&quot;\r\n  },\r\n  {\r\n    &quot;id&quot;: 15257,\r\n    &quot;sha&quot;: &quot;b67acd3082da795f022fafc304d267d3afd6b736&quot;,\r\n    &quot;ref&quot;: &quot;v1.4.15-node&quot;,\r\n    &quot;status&quot;: &quot;skipped&quot;\r\n  },\r\n  {\r\n    &quot;id&quot;: 15256,\r\n    &quot;sha&quot;: &quot;4da4a788a85d82527ea568fed4f03da193842a80&quot;,\r\n    &quot;ref&quot;: &quot;v1.4.15-bs-redux-saga-router-dom-intl&quot;,\r\n    &quot;status&quot;: &quot;skipped&quot;\r\n  }\r\n]\r\n```\r\n\r\n\r\nWe also like to use environment variable for the query : \r\n\r\n - `status=skipped`\r\n - `ref=v1.4.15`\r\n\r\nThis work but without environment variable options:\r\n\r\n    cat test.json | jq &#39;[.[] | select(.status==&quot;skipped&quot;) | select(.ref | startswith(&quot;v1.4.15&quot;))] | length&#39;\r\n\r\nHow is this possible?\r\n\r\n## Answer:\r\n\r\n    status=skipped; ref=v1.4.15; cat test.json | jq --arg REF &quot;$ref&quot; --arg STATUS &quot;$status&quot; -r &#39;[.[] | select(.status==$STATUS) | select(.ref | startswith($REF))] | length&#39;\r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/54624827/jq-how-to-count-depending-on-conditions",
        "title": "JQ, how to count depending on conditions?"
    },
    {
        "tags": [
            "json",
            "jq",
            "any",
            "set-intersection",
            "negation"
        ],
        "answers": [
            {
                "up_vote_count": 6,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1549885859,
                "creation_date": 1549885859,
                "answer_id": 54630000,
                "question_id": 54628953,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use a combination of `jq` and shell tricks using arrays to produce the filter. Firstly to produce the shell array, use an array notation from the shell as below. Note that the below notation of `bash` arrays will _not_ take `,` as a separator in its definition. Now we need to produce a regex filter to match the string, so we produce an alternation operator\r\n\r\n    filter=(&quot;first&quot; &quot;second&quot;)\r\n    echo &quot;$(IFS=&quot;|&quot;; echo &quot;${filter[*]}&quot;\r\n    first|second\r\n\r\nYou haven&#39;t mentioned if the string only matches in the first or last or could be anywhere in the `.title` section. The below regex matches for the string anywhere in the string.\r\n\r\nNow we want to use this filter in the `jq` to match against the `.title` string as below. Notice the use of `not` to negate the result. To provide the actual match, remove the part `|not`.\r\n\r\n    jq --arg re &quot;$(IFS=&quot;|&quot;; echo &quot;${filter[*]}&quot;)&quot; &#39;[.[] | select(.title|test($re)|not)]&#39; &lt; json",
                "title": "jq: select when any value is in array"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1549926103,
                "last_edit_date": 1549926103,
                "creation_date": 1549925744,
                "answer_id": 54640382,
                "question_id": 54628953,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "One way to solve a problem that involves the word &quot;any&quot; is often to use jq&#39;s `any`, e.g. using your shell variable:\r\n  \r\n    jq --argjson filter &quot;$filter&quot; &#39;\r\n      map((.title | split(&quot; &quot;)) as $title\r\n          | select(any( $title[] as $t\r\n                        | $filter[] as $kw\r\n                        | $kw == $t )))&#39; input.json\r\n\r\n## Negation\r\n\r\nAs in formal logic, you can use `all` or `any` (in conjunction with negation) to solve the negated problem.  But don&#39;t forget that if you use `not`,\r\njq&#39;s `not` is a zero-arity filter.\r\n\r\n\r\n\r\n    jq --argjson filter &quot;$filter&quot; &#39;\r\n      map((.title | split(&quot; &quot;)) as $title\r\n          | select(all( $title[] as $t\r\n                        | $filter[] as $kw\r\n                        | $kw != $t )))&#39; input.json\r\n\t\t\t\r\n## Other approaches\r\n\r\nThe above uses &quot;keyword matching&quot; as that is what the question specifies, but of course the above jq expressions can easily be modified to use regexes or some other type of matching. \r\n\r\nIf the list of keywords is very long, then a better algorithm for array-intersection would no doubt be desirable. ",
                "title": "jq: select when any value is in array"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 7,
        "last_activity_date": 1549926223,
        "creation_date": 1549882473,
        "last_edit_date": 1549912483,
        "question_id": 54628953,
        "body_markdown": "Given the input json\r\n```\r\n[\r\n  {&quot;title&quot;: &quot;first line&quot;},\r\n  {&quot;title&quot;: &quot;second line&quot;},\r\n  {&quot;title&quot;: &quot;third line&quot;}\r\n]\r\n```\r\n\r\nHow can we extract only the titles that contain keywords that are listed in a second &quot;filter&quot; array. Using a shell variable here for instance:\r\n\r\n```\r\nfilter=&#39;[&quot;second&quot;, &quot;third&quot;]&#39;\r\n```\r\n\r\nThe output in this case would be\r\n```\r\n[\r\n  {&quot;title&quot;: &quot;second line&quot;},\r\n  {&quot;title&quot;: &quot;third line&quot;}\r\n]\r\n```\r\n\r\nAlso, how to use the array filter to negate instead.\r\nEg: return only the &quot;first line&quot; entry in the previous example.\r\n\r\nThere is a [similar reply](https://stackoverflow.com/questions/29142185/jq-select-when-attribute-value-exists-in-a-bash-array) but using an old version of jq.\r\nI hope that there&#39;s a more intuitive/readable way to do this with the current version of jq.\r\n",
        "link": "https://stackoverflow.com/questions/54628953/jq-select-when-any-value-is-in-array",
        "title": "jq: select when any value is in array"
    },
    {
        "tags": [
            "json",
            "iteration",
            "transform",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 51201,
                    "reputation": 243376,
                    "user_id": 152948,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/194ef8f807c34a9d7aab0e11a8674768?s=256&d=identicon&r=PG",
                    "display_name": "hobbs",
                    "link": "https://stackoverflow.com/users/152948/hobbs"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1549940856,
                "post_id": 54642244,
                "comment_id": 96076052,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1549941596,
                "creation_date": 1549941596,
                "answer_id": 54642351,
                "question_id": 54642244,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "As already pointed out in a comment, the &quot;expected response&quot; is not JSON and probably not what you want anyway.  The following would make sense and in any case illustrates how to iterate appropriately:\r\n\r\n    .amazon\r\n    | { userType: .userType,\r\n        userName: .user,\r\n        itemCatalog: (.items | map({ itemId: .id, name} ))\r\n      }\r\n\r\n## Output\r\n\r\n    {\r\n      &quot;userType&quot;: &quot;new&quot;,\r\n      &quot;userName&quot;: &quot;net&quot;,\r\n      &quot;itemCatalog&quot;: [\r\n        {\r\n          &quot;itemId&quot;: 1,\r\n          &quot;name&quot;: &quot;harry potter&quot;\r\n        },\r\n        {\r\n          &quot;itemId&quot;: 2,\r\n          &quot;name&quot;: &quot;adidas shoes&quot;\r\n        },\r\n        {\r\n          &quot;itemId&quot;: 3,\r\n          &quot;name&quot;: &quot;watch&quot;\r\n        },\r\n        {\r\n          &quot;itemId&quot;: 4,\r\n          &quot;name&quot;: &quot;adidas shoes&quot;\r\n        }\r\n      ]\r\n    }",
                "title": "JSON Transformation using JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1549945715,
        "creation_date": 1549940606,
        "last_edit_date": 1549945715,
        "question_id": 54642244,
        "body_markdown": "I am trying to transform my JSON to different structure using JQ. I am able to partially achieve my new structure, however i get a additional blocks of data.\r\n\r\nAs i iterate i am able to get the structure in new format. But additional structures are coming.\r\n\r\nCode Snippet- https://jqplay.org/s/3gulSlZiWz\r\n\r\nJSON\r\n\r\n        {\r\n          &quot;amazon&quot;: {\r\n            &quot;activeitem&quot;: 2,\r\n            &quot;createdDate&quot;: &quot;2019-01-15T17:36:31.588Z&quot;,\r\n            &quot;lastModifiedDate&quot;: &quot;2019-01-15T17:36:31.588Z&quot;,\r\n            &quot;user&quot;: &quot;net&quot;,\r\n            &quot;userType&quot;: &quot;new&quot;,\r\n            &quot;items&quot;: [\r\n              {\r\n                &quot;id&quot;: 1,\r\n                &quot;name&quot;: &quot;harry potter&quot;,\r\n                &quot;state&quot;: &quot;sold&quot;,\r\n                &quot;type&quot;: {\r\n                  &quot;branded&quot;: false,\r\n                  &quot;description&quot;: &quot;artwork&quot;,\r\n                  &quot;contentLevel&quot;: &quot;season&quot;\r\n                }\r\n              },\r\n              {\r\n                &quot;id&quot;: 2,\r\n                &quot;name&quot;: &quot;adidas shoes&quot;,\r\n                &quot;state&quot;: &quot;in inventory&quot;,\r\n                &quot;type&quot;: {\r\n                  &quot;branded&quot;: false,\r\n                  &quot;description&quot;: &quot;Spprts&quot;,\r\n                  &quot;contentLevel&quot;: &quot;season&quot;\r\n                }\r\n              },\r\n              {\r\n                &quot;id&quot;: 3,\r\n                &quot;name&quot;: &quot;watch&quot;,\r\n                &quot;state&quot;: &quot;returned&quot;,\r\n                &quot;type&quot;: {\r\n                  &quot;branded&quot;: false,\r\n                  &quot;description&quot;: &quot;walking&quot;,\r\n                  &quot;contentLevel&quot;: &quot;special&quot;\r\n                }\r\n              },\r\n              {\r\n                &quot;id&quot;: 4,\r\n                &quot;name&quot;: &quot;adidas shoes&quot;,\r\n                &quot;state&quot;: &quot;in inventory&quot;,\r\n                &quot;type&quot;: {\r\n                  &quot;branded&quot;: false,\r\n                  &quot;description&quot;: &quot;running&quot;,\r\n                  &quot;contentLevel&quot;: &quot;winter&quot;\r\n                }\r\n              }\r\n            ],\r\n            &quot;product&quot;: {\r\n              &quot;id&quot;: 4,\r\n              &quot;name&quot;: &quot;adidas shoes&quot;,\r\n              &quot;source&quot;: &quot;dealer&quot;,\r\n              &quot;destination&quot;: &quot;resident&quot;\r\n            }\r\n          }\r\n        }\r\n\r\n\r\n\r\nJQ Query:\r\n\r\n\r\n\r\n          .amazon| \r\n          {  \r\n              userType: .userType,\r\n              userName: .user,\r\n              itemCatalog: {   \r\n                 itemId: .items[].id, \r\n                 name: .items[].name  \r\n              }\r\n          }\r\n\r\n\r\nExpected Response:\r\n\r\n\r\n     {\r\n        &quot;userType&quot;: &quot;new&quot;,\r\n        &quot;userName&quot;: &quot;net&quot;,\r\n        &quot;itemCatalog&quot;: {\r\n          &quot;itemId&quot;: 1,\r\n          &quot;name&quot;: &quot;harry potter&quot;\r\n        },{\r\n          &quot;itemId&quot;: 2,\r\n          &quot;name&quot;: &quot;adidas shoes&quot;\r\n        }, {\r\n          &quot;itemId&quot;: 3,\r\n          &quot;name&quot;: &quot;watch&quot;\r\n        },{\r\n          &quot;itemId&quot;: 4,\r\n          &quot;name&quot;: &quot;adidas shoes&quot;\r\n        }\r\n      }\r\n\r\n\r\n\r\nBut getting something weird long duplicated response.\r\n\r\n",
        "link": "https://stackoverflow.com/questions/54642244/json-transformation-using-jq",
        "title": "JSON Transformation using JQ"
    },
    {
        "tags": [
            "json",
            "google-bigquery",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1550007090,
                "creation_date": 1550007090,
                "answer_id": 54658959,
                "question_id": 54657231,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "For the given example:\r\n\r\n     jq -c  .items[] lala.json  &gt; lala.jq.json\r\n\r\nThen you can load into BigQuery:\r\n\r\n     bq load --source_format NEWLINE_DELIMITED_JSON --autodetect fh-bigquery:deleting.testjson lala.jq.json\r\n\r\nAnd then it&#39;s ready to be queried:\r\n\r\n[![enter image description here][1]][1]\r\n\r\nNote that the answer from user &quot;peak&quot; is missing `-c` and `[]` to control the output and splitting into different items from the array.\r\n\r\n  [1]: https://i.sstatic.net/DybeM.png",
                "title": "Turning JSON blob into BQ friendly format with JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1550007090,
        "creation_date": 1549999109,
        "last_edit_date": 1550001075,
        "question_id": 54657231,
        "body_markdown": "To be upfront, I have next to no experience with JSON, JQ, or much of anything on the Java side. I&#39;ve been spending a lot of time trying to use the `jq` command line function to properly format a test blob of data in a way that I can easily feed into Google BigQuery.\r\n\r\n    {\r\n        &quot;total_items&quot;: 848,\r\n        &quot;page_count&quot;: 34,\r\n        &quot;items&quot;: [\r\n            {\r\n                &quot;landing_id&quot;: &quot;708d9e3eb106820f98162d879198774b&quot;,\r\n                &quot;token&quot;: &quot;708d9e3eb106820f98162d879198774b&quot;,\r\n                &quot;response_id&quot;: &quot;708d9e3eb106820f98162d879198774b&quot;,\r\n                &quot;landed_at&quot;: &quot;2019-02-12T01:58:02Z&quot;,\r\n                &quot;submitted_at&quot;: &quot;2019-02-12T01:58:31Z&quot;,\r\n                &quot;metadata&quot;: {\r\n                    &quot;user_agent&quot;: &quot;Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/72.0.3560.98 Safari/537.36&quot;,\r\n                    &quot;platform&quot;: &quot;other&quot;,\r\n                    &quot;referer&quot;: &quot;https://test.typeform.com/to/LTYE9W?prefilled_answer=8&amp;email=test.x20a@gmail.com&quot;,\r\n                    &quot;network_id&quot;: &quot;35b9eae170&quot;,\r\n                    &quot;browser&quot;: &quot;default&quot;\r\n                },\r\n                &quot;answers&quot;: [\r\n                    {\r\n                        &quot;field&quot;: {\r\n                            &quot;id&quot;: &quot;fX64BkjuxYy1&quot;,\r\n                            &quot;type&quot;: &quot;opinion_scale&quot;,\r\n                            &quot;ref&quot;: &quot;97f8e18ad06a02e6&quot;\r\n                        },\r\n                        &quot;type&quot;: &quot;number&quot;,\r\n                        &quot;number&quot;: 8\r\n                    },\r\n                    {\r\n                        &quot;field&quot;: {\r\n                            &quot;id&quot;: &quot;lYeFxbL67g8B&quot;,\r\n                            &quot;type&quot;: &quot;multiple_choice&quot;,\r\n                            &quot;ref&quot;: &quot;78d09e15-7d42-49ec-9f9d-004bf7d3058a&quot;\r\n                        },\r\n                        &quot;type&quot;: &quot;choices&quot;,\r\n                        &quot;choices&quot;: {\r\n                            &quot;labels&quot;: [\r\n                                &quot;Experience&quot;\r\n                            ]\r\n                        }\r\n                    },\r\n                    {\r\n                        &quot;field&quot;: {\r\n                            &quot;id&quot;: &quot;D3ubKSVfNnlY&quot;,\r\n                            &quot;type&quot;: &quot;multiple_choice&quot;,\r\n                            &quot;ref&quot;: &quot;684cb3bd-09cb-4f27-8e7d-baef6a09f787&quot;\r\n                        },\r\n                        &quot;type&quot;: &quot;choices&quot;,\r\n                        &quot;choices&quot;: {\r\n                            &quot;labels&quot;: [\r\n                                &quot;Condition&quot;\r\n                            ]\r\n                        }\r\n                    },\r\n                    {\r\n                        &quot;field&quot;: {\r\n                            &quot;id&quot;: &quot;UccviSuUQPio&quot;,\r\n                            &quot;type&quot;: &quot;yes_no&quot;,\r\n                            &quot;ref&quot;: &quot;ed7e0d9c-5b62-4b0f-9395-54a53d125711&quot;\r\n                        },\r\n                        &quot;type&quot;: &quot;boolean&quot;,\r\n                        &quot;boolean&quot;: false\r\n                    }\r\n                ],\r\n                &quot;hidden&quot;: {\r\n                    &quot;email&quot;: &quot;test.x20a@gmail.com&quot;\r\n                }\r\n            }\r\n            ]\r\n    }\r\n\r\n[I&#39;ve been using this tutorial, but with no success, and it&#39;s getting incredibly frustrating][1]\r\n\r\nLet&#39;s assume I want all fields, but I want to get rid of that top part that includes `total_items` and `page_count`. So essentially, everything beginning with `landing_id`. I apologize for not going further into my previous attempts to give you all a baseline, but I just haven&#39;t gotten anywhere.\r\n\r\n  [1]: https://stedolan.github.io/jq/tutorial/",
        "link": "https://stackoverflow.com/questions/54657231/turning-json-blob-into-bq-friendly-format-with-jq",
        "title": "Turning JSON blob into BQ friendly format with JQ"
    },
    {
        "tags": [
            "json",
            "parent-child",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1550020524,
                "last_edit_date": 1550020524,
                "creation_date": 1550018157,
                "answer_id": 54660782,
                "question_id": 54660692,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here are two ways that work:\r\n\r\n1.\r\n\r\n    jq &#39;.services\r\n        | . as $services\r\n        | keys_unsorted\r\n        | map( select($services[.] | has(&quot;build&quot;)) )&#39;\r\n\r\n(Drill down to `.services`, remember it as `$services` for later use, get the list of keys, and select the ones such that the corresponding value in `$services` has a `build` key).\r\n\r\n2.\r\n\r\n    jq &#39;.services\r\n        | to_entries\r\n        | map( select(.value | has(&quot;build&quot;)) | .key)&#39;\r\n\r\n(Drill down to `.services`, convert to a list of `{&quot;key&quot;: ..., &quot;value&quot;: ...}` objects, select the ones where the `.value` has a `build` key, and return the `.key` for each).\r\n\r\nThe second is probably more idiomatic jq, but the first provides an interesting way to think about the problem as well.",
                "title": "Using jq: Only select parents with a certain child key"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1550037986,
                "last_edit_date": 1550037986,
                "creation_date": 1550019064,
                "answer_id": 54660903,
                "question_id": 54660692,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a third approach, notable for being oblivious to the upper reaches:\r\n\r\n    [(paths(scalars) \r\n      | select(.[-1] == &quot;build&quot;)) as $p\r\n     | getpath($p)]\r\n\r\n",
                "title": "Using jq: Only select parents with a certain child key"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1550037986,
        "creation_date": 1550017375,
        "last_edit_date": 1550019091,
        "question_id": 54660692,
        "body_markdown": "Example json:\r\n```\r\n{\r\n  &quot;version&quot;: &quot;3&quot;,\r\n  &quot;services&quot;: {\r\n    &quot;web&quot;: {\r\n      &quot;build&quot;: &quot;web&quot;\r\n    },\r\n    &quot;redis&quot;: {\r\n      &quot;image&quot;: &quot;redis&quot;\r\n    },\r\n    &quot;datadog&quot;: {\r\n      &quot;build&quot;: &quot;datadog&quot;\r\n    },\r\n    &quot;another&quot;: {\r\n      &quot;image&quot;: &quot;mysql&quot;\r\n    }\r\n  }\r\n}\r\n```\r\n\r\nI&#39;d like to return a list of services that have the &quot;build&quot; key, and not the &quot;image&quot; key. Note that the value for the build key isn&#39;t something I can key off of.\r\n\r\nOutput should be: [&quot;web&quot;, &quot;datadog&quot;]\r\n\r\n\r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/54660692/using-jq-only-select-parents-with-a-certain-child-key",
        "title": "Using jq: Only select parents with a certain child key"
    },
    {
        "tags": [
            "arrays",
            "json",
            "select",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1550059292,
                "creation_date": 1550059292,
                "answer_id": 54669725,
                "question_id": 54669497,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use the update assignment operator `|=` in combination with `map`\r\n\r\n    jq &#39;.cities|=map(if . == &quot;Brisbane&quot; or . == &quot;Perth&quot; then empty else . end)&#39;",
                "title": "Filter out entries in child array"
            },
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1550116831,
                "last_edit_date": 1550116831,
                "creation_date": 1550061659,
                "answer_id": 54670458,
                "question_id": 54669497,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could use subtraction:\r\n\r\n    jq &#39;.cities -= [&quot;Perth&quot;, &quot;Brisbane&quot;]&#39;\r\n\r\nOutput:\r\n\r\n&lt;!-- language: lang-json --&gt;\r\n\r\n    {\r\n      &quot;country&quot;: &quot;Australia&quot;,\r\n      &quot;cities&quot;: [\r\n        &quot;Melbourne&quot;,\r\n        &quot;Sydney&quot;\r\n      ]\r\n    }",
                "title": "Filter out entries in child array"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 3,
        "last_activity_date": 1550483220,
        "creation_date": 1550058566,
        "last_edit_date": 1550483220,
        "question_id": 54669497,
        "body_markdown": "How can I filter items in a json sub array?\r\n\r\nFor instance, with this:\r\n\r\n```\r\n{\r\n  &quot;country&quot;: &quot;Australia&quot;,\r\n  &quot;cities&quot;: [\r\n    &quot;Melbourne&quot;,\r\n    &quot;Sydney&quot;,\r\n    &quot;Brisbane&quot;,\r\n    &quot;Perth&quot;\r\n  ]\r\n}\r\n```\r\nI would need to filter out &quot;Brisbane&quot; and &quot;Perth&quot; to obtain.\r\n```\r\n{\r\n  &quot;country&quot;: &quot;Australia&quot;,\r\n  &quot;cities&quot;: [\r\n    &quot;Melbourne&quot;,\r\n    &quot;Sydney&quot;\r\n  ]\r\n}\r\n\r\n```\r\n\r\nI&#39;ve tried different combinations of `select(something|test(&quot;Brisbane|Perth&quot;)|not)` without success.\r\n",
        "link": "https://stackoverflow.com/questions/54669497/filter-out-entries-in-child-array",
        "title": "Filter out entries in child array"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 21,
                "is_accepted": true,
                "score": 21,
                "last_activity_date": 1550136158,
                "last_edit_date": 1550136158,
                "creation_date": 1550074732,
                "answer_id": 54674832,
                "question_id": 54674527,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To have double-quotes in a `jq` command you&#39;ve enclosed in double-quotes, you&#39;d escape them with a backslash :\r\n\r\n    jq &quot;.[\\&quot;key-key\\&quot;]&quot;\r\n\r\nAnother problem with your final command is that `${var[i+1]}` expands to the empty string, because this syntax is used to index elements of an array, and you previously defined `var` as a simple string. \r\n\r\nA better way to work with variables in `jq` commands is to define them through the `--arg name value` option, after which you can refer to them with `$foo` *in a single-quotes enclosed command* :\r\n\r\n    jq --arg keyName key-key &#39;.[$keyName]&#39;\r\n\r\nTo fix the code included in the update, I would use the following :\r\n\r\n    declare -a var=(\r\n        &quot;key-key&quot;\r\n        &quot;key2-key2&quot;\r\n        &quot;key3-key3&quot;\r\n    )\r\n    \r\n    json=$(curl -s &quot;url&quot;)\r\n\r\n    for searchedKey in &quot;${var[@]}&quot;; do\r\n        echo $json | jq --arg keyName $searchedKey &#39;.[$keyName].something&#39;\r\n    done",
                "title": "jq doesn&#39;t work with keys which contains dash in it from a variable"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 15,
        "last_activity_date": 1550136158,
        "creation_date": 1550073892,
        "last_edit_date": 1550075965,
        "question_id": 54674527,
        "body_markdown": "If you&#39;d like jq to escape dashes, you need to put your key between square brackets like this;\r\n\r\n`jq &#39;.[&quot;key-key&quot;]&#39;`\r\n\r\nand apart from that, if you&#39;d like to include a variable in jq, you need to use double quotes instead of single quotes;\r\n\r\n`jq &quot;.&quot;${var[i+1]}&quot;&quot;`\r\n\r\nbut my variable contains dash in it and in this case, I&#39;ve tried to merge the 2 examples above but it didn&#39;t work;\r\n\r\n```\r\nvar=key-key\r\njq &quot;.[&quot;${var[i+1]}&quot;].&quot;key&quot;&quot;\r\n```\r\n\r\nhow can I get this work?\r\n\r\nUpdate:\r\n\r\nThis is the final script, which I&#39;ve forgot to mention;\r\n\r\n```bash\r\ndeclare -a var=(\r\n    &quot;key-key&quot;\r\n    &quot;key2-key2&quot;\r\n    &quot;key3-key3&quot;\r\n)\r\n\r\nfor ((i=0; i&lt;${#var[@]})); do\r\n    curl -s &quot;url&quot; | jq &quot;.[&quot;${var}&quot;].&quot;something&quot;&quot;\r\ndone\r\n```",
        "link": "https://stackoverflow.com/questions/54674527/jq-doesnt-work-with-keys-which-contains-dash-in-it-from-a-variable",
        "title": "jq doesn&#39;t work with keys which contains dash in it from a variable"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1550076803,
                "last_edit_date": 1550076803,
                "creation_date": 1550075606,
                "answer_id": 54675146,
                "question_id": 54674724,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The easy part of this question is handling empty arrays and missing &quot;export_type&quot; values, e.g.\r\n\r\n\r\n    .[]\r\n    | [.id,\r\n       .graphic,\r\n       (.export_params.uses?[] // &quot;&quot;),\r\n       (.export_params.export_type? // &quot;&quot;) ]\r\n    | @csv\r\n\r\nBut what if `.uses` is an array with more than one item in it?  That would potentially mean a variable number of values\r\nin the rows, which might cause problems.\r\n\r\nTo restrict consideration to the first item in `.uses`, you could use `first`:\r\n\r\n    .[]\r\n    | [.id,\r\n       .graphic,\r\n       first(.export_params.uses?[] // &quot;&quot;), \r\n       (.export_params.export_type? // &quot;&quot;) ]\r\n    | @csv\r\n\r\n## An alternative approach\r\n\r\nTo avoid clutter, it might be preferable to tweak the objects before querying them, e.g. along these lines:\r\n\r\n    .[]\r\n    | .export_params |= (if . == [] then {uses: [&quot;&quot;]} else . end)\r\n    | [.id, \r\n       .graphic,\r\n       .export_params.uses[0], \r\n       .export_params.export_type ]\r\n    | @csv",
                "title": "Running jq query on alternating object type"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1550076803,
        "creation_date": 1550074430,
        "question_id": 54674724,
        "body_markdown": "I have json file with lots of data about image files. It has this structure:\r\n\r\n    [\r\n      {\r\n        &quot;id&quot;: 1,\r\n        &quot;graphic&quot;: &quot;filename&quot;,\r\n        &quot;export_params&quot;: {\r\n          &quot;uses&quot;: [\r\n            &quot;string&quot;\r\n          ]\r\n        }\r\n      },\r\n      {\r\n        &quot;id&quot;: 2,\r\n        &quot;graphic&quot;: &quot;filename2&quot;,\r\n        &quot;export_params&quot;: []\r\n      },\r\n      ...\r\n    ]\r\n\r\nMost objects in this array has full `export_params` info, but sometimes it is just empty array. I&#39;ve tried using this jq query\r\n\r\n    .[] | [.id, .graphic, .export_params.uses[], .export_params.export_type ] | @csv\r\n\r\nto turn it into csv, but it broke on a line, where it found first &quot;empty `export_params`&quot; key. How can I bypass problem with different object type (most cases it&#39;s object, when empty, it&#39;s array - I think this is what causes my query to fail)?",
        "link": "https://stackoverflow.com/questions/54674724/running-jq-query-on-alternating-object-type",
        "title": "Running jq query on alternating object type"
    },
    {
        "tags": [
            "json",
            "sorting",
            "key",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1550093532,
                "last_edit_date": 1550093532,
                "creation_date": 1550093215,
                "answer_id": 54679704,
                "question_id": 54678845,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you are willing to rely on the --sort-keys command-line option to sort the keys, then you can ensure all arrays are sorted by writing:\r\n\r\n    walk(if type==&quot;array&quot; then sort else . end)\r\n\r\nIf you want the object keys to be sorted internally (i.e. before the final output is generated), then you could augment the above by using the following filter:\r\n\r\n    walk(if type==&quot;array&quot; then sort\r\n         elif type == &quot;object&quot; then to_entries | sort | from_entries\r\n         else . end)\r\n\r\n## Alternatives\r\nIf for some reason you wish not to use `walk`, then you can roll your own solution using some combination of `sort` (for JSON arrays) and `to_entries|sort|from_entries` (for JSON objects).",
                "title": "Using jq to sort keys then values in json"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1550265698,
        "creation_date": 1550089521,
        "last_edit_date": 1550094876,
        "question_id": 54678845,
        "body_markdown": "Anyone knows how to use jq to sort keys and their array values in json?\r\n\r\nFor example:\r\n\r\nBefore sort:\r\n\r\n    { \r\n       z:[&quot;c&quot;,&quot;b&quot;,&quot;a&quot;],\r\n       y:[&quot;e&quot;, &quot;d&quot;, &quot;f&quot;],\r\n       x:[&quot;g&quot;, &quot;i&quot;, &quot;h&quot;]\r\n    }\r\n\r\nAfter sort:\r\n\r\n    {\r\n       x:[&quot;h&quot;, &quot;i&quot;, &quot;j&quot;]\r\n       y:[&quot;d&quot;, &quot;e&quot;, &quot;f&quot;],\r\n       z:[&quot;a&quot;,&quot;b&quot;,&quot;c&quot;]\r\n    }\r\n\r\nI am trying to use \r\n\r\n    jq --sort-keys \r\n\r\nbut it only sorts the keys, but not including their values.\r\n\r\nThanks!\r\n",
        "link": "https://stackoverflow.com/questions/54678845/using-jq-to-sort-keys-then-values-in-json",
        "title": "Using jq to sort keys then values in json"
    },
    {
        "tags": [
            "windows",
            "powershell",
            "cmd",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 10,
                "is_accepted": true,
                "score": 10,
                "last_activity_date": 1550129138,
                "last_edit_date": 1550129138,
                "creation_date": 1550118333,
                "answer_id": 54683205,
                "question_id": 54683103,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You have three main options:\r\n\r\n1. (Easy) Put the JSON and jq program into separate files (or maybe, with care, into one file), and invoke jq accordingly.\r\n\r\n2. (Error-prone) Follow the quoting rules for the shell you&#39;re using.\r\n\r\n3. Some combination of the above.\r\n\r\nThe basic rule as I understand it is as follows: at a Windows `cmd` command-line prompt, in order to quote strings, you use double-quotes, and escape double-quotes within the string using backslashes.  \r\n\r\nFor example:\r\n\r\n    C&gt;ver\r\n    Microsoft Windows [Version 10.0.17134.590]\r\n\r\n    C&gt;echo &quot;hello \\&quot;world\\&quot;&quot; | jq .\r\n    &quot;hello \\&quot;world\\&quot;&quot;\r\n    \r\n    C&gt;jq -n &quot;\\&quot;hello world\\&quot;&quot;\r\n    &quot;hello world&quot;\r\n\r\n\r\n## Your example\r\n\r\n    C&gt;echo [&quot;a&quot;,&quot;b&quot;,&quot;c&quot;] | jq -c &quot;{\\&quot;data\\&quot;:map({\\&quot;{#SNAME}\\&quot;:.})}&quot;\r\n    {&quot;data&quot;:[{&quot;{#SNAME}&quot;:&quot;a&quot;},{&quot;{#SNAME}&quot;:&quot;b&quot;},{&quot;{#SNAME}&quot;:&quot;c&quot;}]}\r\n\r\n## Postscript\r\n\r\nExcept for the hash (`#`) and braces (`{}`) in the string, one can achieve the goal by avoiding spaces:\r\n\r\n    C&gt;echo [&quot;a&quot;,&quot;b&quot;,&quot;c&quot;] | jq -c {&quot;data&quot;:map({&quot;SNAME&quot;:.})}\r\n    {&quot;data&quot;:[{&quot;SNAME&quot;:&quot;a&quot;},{&quot;SNAME&quot;:&quot;b&quot;},{&quot;SNAME&quot;:&quot;c&quot;}]}\r\n\r\n## Powershell\r\n\r\nAgain, except for the hash and braces, simple solutions are possible:\r\n\r\nUsing single-quoted strings:\r\n\r\n     echo &#39;[&quot;a&quot;, &quot;b&quot;, &quot;c&quot;]&#39; | jq -c &#39;{&quot;data&quot;: map( {&quot;SNAME&quot;: . })}&#39;\r\n     {&quot;data&quot;:[{&quot;SNAME&quot;:&quot;a&quot;},{&quot;SNAME&quot;:&quot;b&quot;},{&quot;SNAME&quot;:&quot;c&quot;}]}\r\n\r\nUsing `&quot;&quot;` inside double-quoted strings:\r\n\r\n    echo &#39;[&quot;a&quot;, &quot;b&quot;, &quot;c&quot;]&#39; | jq -c &quot;{&quot;&quot;data&quot;&quot;: map( {&quot;&quot;SNAME&quot;&quot;: . })}&quot;\r\n    {&quot;data&quot;:[{&quot;SNAME&quot;:&quot;a&quot;},{&quot;SNAME&quot;:&quot;b&quot;},{&quot;SNAME&quot;:&quot;c&quot;}]}\r\n\r\nThe PowerShell documentation that I&#39;ve seen suggests backticks can be used to escape special characters within double-quoted strings, but YMMV.\r\n\r\nBonne chance!",
                "title": "Simple jq filters not working in Windows shell, various quoting issues"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 6,
        "last_activity_date": 1562343230,
        "creation_date": 1550117458,
        "last_edit_date": 1562343230,
        "question_id": 54683103,
        "body_markdown": "I am trying really hard to get the Windows shell working with jq and failing miserably. \r\n\r\nI want this type of thing to work \r\n\r\n    echo &#39;[&quot;a&quot;,&quot;b&quot;,&quot;c&quot;]&#39; | .\\Downloads\\jq.exe -r &#39;{ &quot;data&quot;: map({ &quot;{#SNAME}&quot;: . })}&#39;\r\n\r\nBut I get an error:\r\n\r\n&gt; jq: error: syntax error, unexpected &#39;.&#39; (Windows cmd shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n\r\nIf i just do `echo &#39;[&quot;a&quot;,&quot;b&quot;,&quot;c&quot;]&#39; | .\\Downloads\\jq.exe -r &#39;.&#39;` then it&#39;s happy but as soon i i add in other characters such as `echo &#39;[&quot;a&quot;,&quot;b&quot;,&quot;c&quot;]&#39; | .\\Downloads\\jq.exe -r &#39;{.}&#39;` then it fails again with:\r\n\r\n&gt; jq: error: syntax error, unexpected &#39;.&#39; (Windows cmd shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n\r\nDoes anyone know how to make Windows shell happy with jq for the above examples to work as expected ?\r\n\r\nUsing latest 1.6 build from jq website for these tests and confirmed the jq commands work using Linux and jqplay.org.\r\n\r\nThank you.",
        "link": "https://stackoverflow.com/questions/54683103/simple-jq-filters-not-working-in-windows-shell-various-quoting-issues",
        "title": "Simple jq filters not working in Windows shell, various quoting issues"
    },
    {
        "tags": [
            "shell",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1550239146,
                "creation_date": 1550239146,
                "answer_id": 54710912,
                "question_id": 54710853,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "found it:\r\n\r\n    cat jobs.json | jq &#39;.jobs[].name&#39;",
                "title": "Parsing JSON with jq"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1550239146,
        "creation_date": 1550238954,
        "question_id": 54710853,
        "body_markdown": "&lt;br/&gt;\r\nI have to parse a JSON which includes an array of of class/name:\r\n\r\n    {\r\n    \r\n        &quot;_class&quot;: &quot;model.ListView&quot;,\r\n        &quot;jobs&quot;: [\r\n            {\r\n                &quot;_class&quot;: &quot;hudson.matrix.MatrixProject&quot;,\r\n                &quot;name&quot;: &quot;tests-different-node-full&quot;\r\n            },\r\n            {\r\n                &quot;_class&quot;: &quot;hudson.matrix.MatrixProject&quot;,\r\n                &quot;name&quot;: &quot;tests-jms-activemq-full&quot;\r\n            },\r\n            {\r\n                &quot;_class&quot;: &quot;hudson.matrix.MatrixProject&quot;,\r\n                &quot;name&quot;: &quot;tests-txpropag-jpa-full&quot;\r\n            }\r\n        ]\r\n    \r\n    }\r\nI need to retrieve the list of &quot;name&quot;.\r\nLooking at the examples I&#39;ve found of jq, I have tried with:\r\n\r\n    cat jobs.json | jq &#39;.[].name&#39;\r\n\r\nIt fails with:\r\n\r\n    jq: error (at &lt;stdin&gt;:0): Cannot index string with string &quot;name&quot;\r\n\r\nHow should I reference the name element of the array?\r\nThanks",
        "link": "https://stackoverflow.com/questions/54710853/parsing-json-with-jq",
        "title": "Parsing JSON with jq"
    },
    {
        "tags": [
            "arrays",
            "json",
            "indexing",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3959308,
                    "reputation": 53394,
                    "user_id": 3266847,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/U0oyt.png?s=256",
                    "display_name": "Benjamin W.",
                    "link": "https://stackoverflow.com/users/3266847/benjamin-w"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1550263434,
                "post_id": 54716748,
                "comment_id": 96219364,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "user_type": "does_not_exist",
                    "display_name": "anon"
                },
                "reply_to_user": {
                    "account_id": 3959308,
                    "reputation": 53394,
                    "user_id": 3266847,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/U0oyt.png?s=256",
                    "display_name": "Benjamin W.",
                    "link": "https://stackoverflow.com/users/3266847/benjamin-w"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1550263571,
                "post_id": 54716748,
                "comment_id": 96219412,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1550266486,
                "last_edit_date": 1550266486,
                "creation_date": 1550266177,
                "answer_id": 54717324,
                "question_id": 54716748,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Admittedly this is not obvious, but a very short solution is:\r\n\r\n    with_entries(.key |= tostring)\r\n\r\nA more pedestrian but still perfectly respectable solution would be:\r\n\r\n    . as $in\r\n    | reduce range(0;length) as $i ({}; . + {($i|tostring): $in[$i]})\r\n",
                "title": "Convert simple array to numeric key and value"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1550268225,
        "creation_date": 1550263291,
        "last_edit_date": 1550268225,
        "question_id": 54716748,
        "body_markdown": "I&#39;m really struggling with this simple task. I&#39;m trying to convert this:\r\n\r\n    [\r\n        &quot;arn:aws:iam::123456789012:role/masters.a.eu.somewhere.com&quot;,\r\n        &quot;arn:aws:iam::123456789012:role/masters.b.eu.somewhere.com&quot;,\r\n        &quot;arn:aws:iam::123456789012:role/masters.c.eu.somewhere.com&quot;\r\n    ]\r\n\r\nTo something like this:\r\n\r\n    {\r\n        &quot;0&quot;: &quot;arn:aws:iam::123456789012:role/masters.a.eu.somewhere.com&quot;,\r\n        &quot;1&quot;: &quot;arn:aws:iam::123456789012:role/masters.b.eu.somewhere.com&quot;,\r\n        &quot;2&quot;: &quot;arn:aws:iam::123456789012:role/masters.c.eu.somewhere.com&quot;\r\n    }\r\n\r\nUsing just JQ. I&#39;ve tried using &#39;to_entries&#39; but I&#39;m not getting the desired output. Any suggestions appreciated.",
        "link": "https://stackoverflow.com/questions/54716748/convert-simple-array-to-numeric-key-and-value",
        "title": "Convert simple array to numeric key and value"
    },
    {
        "tags": [
            "json",
            "bash",
            "stream",
            "jq",
            "partitioning"
        ],
        "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": 1550347279,
                "post_id": 54725080,
                "comment_id": 96238090,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1550347373,
                "post_id": 54725080,
                "comment_id": 96238113,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1550347633,
                "post_id": 54725080,
                "comment_id": 96238162,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1550348230,
                "post_id": 54725080,
                "comment_id": 96238294,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 15318589,
                    "reputation": 63,
                    "user_id": 11051796,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/aea6dcd088760516ca8f4f70f05f7e58?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "scrim",
                    "link": "https://stackoverflow.com/users/11051796/scrim"
                },
                "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": 1550369951,
                "post_id": 54725080,
                "comment_id": 96242554,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1550348085,
                "last_edit_date": 1550348085,
                "creation_date": 1550347068,
                "answer_id": 54727100,
                "question_id": 54725080,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Assuming the JSON objects in the file are relatively small (none more than a few MB), you won&#39;t need to use the (rather complex) &quot;--stream&quot; command-line option, which is mainly needed when the input is (or includes) a single humungous JSON entity. \r\n\r\nThere are however several choices still to be made. The main ones are described at https://stackoverflow.com/questions/28744361/split-a-json-file-into-separate-files, these being a multi-pass approach (N or (N+1) calls to jq, where N is the number of output files), and an approach that involves just one call to jq, followed by a call to a program such as `awk` to perform the actual partitioning into files.  Each approach has its pros and cons, but if reading the input file N times is acceptable, then the first approach might be better.\r\n\r\nTo estimate the total computational resources that will be required, it would probably be a good idea to measure the resources used by running `jq empty input.json`\r\n\r\n(From your brief writeup, it sounds like the memory issue you&#39;ve run into results primarily from the unzipping of the file.)",
                "title": "Using jq, how can I split a JSON stream of objects into separate files based on the values of an object property?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1550348814,
                "last_edit_date": 1550348814,
                "creation_date": 1550347878,
                "answer_id": 54727208,
                "question_id": 54725080,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using `jq` to split into a NUL-delimited stream of (type, document) pairs, and using native bash (4.1 or later) to write to those documents using a persistent set of file descriptors:\r\n\r\n```\r\n#!/usr/bin/env bash\r\ncase $BASH_VERSION in &#39;&#39;|[1-3].*|4.0*) echo &quot;ERROR: Bash 4.1 needed&quot; &gt;&amp;2; exit 1;; esac\r\n\r\ndeclare -A output_fds=( )\r\n\r\nwhile IFS= read -r -d &#39;&#39; type &amp;&amp; IFS= read -r -d &#39;&#39; content; do\r\n  if [[ ${output_fds[$type]} ]]; then  # already have a file handle for this output file?\r\n    curr_fd=${output_fds[$type]}       # reuse it, then.\r\n  else\r\n    exec {curr_fd}&gt;&quot;$type.json&quot;        # open a new output file...\r\n    output_fds[$type]=$curr_fd         # and store its file descriptor for use.\r\n  fi\r\n  printf &#39;%s\\n&#39; &quot;$content&quot; &gt;&amp;&quot;$curr_fd&quot;\r\ndone &lt; &lt;(jq -j &#39;(.type) + &quot;\\u0000&quot; + (. | tojson) + &quot;\\u0000&quot;&#39;)\r\n```\r\n\r\nThis never reads more than a few records (admittedly, potentially multiple copies of each) into memory at a time, so it&#39;ll work with an arbitrarily large file so long as the records are of reasonable size.",
                "title": "Using jq, how can I split a JSON stream of objects into separate files based on the values of an object property?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 6,
        "last_activity_date": 1550384441,
        "creation_date": 1550333793,
        "last_edit_date": 1550384441,
        "question_id": 54725080,
        "body_markdown": "I have a very large file (20GB+ compressed) called `input.json` containing a stream of JSON objects as follows:\r\n\r\n```\r\n{\r\n    &quot;timestamp&quot;: &quot;12345&quot;,\r\n    &quot;name&quot;: &quot;Some name&quot;,\r\n    &quot;type&quot;: &quot;typea&quot;\r\n}\r\n{\r\n    &quot;timestamp&quot;: &quot;12345&quot;,\r\n    &quot;name&quot;: &quot;Some name&quot;,\r\n    &quot;type&quot;: &quot;typea&quot;\r\n}\r\n{\r\n    &quot;timestamp&quot;: &quot;12345&quot;,\r\n    &quot;name&quot;: &quot;Some name&quot;,\r\n    &quot;type&quot;: &quot;typeb&quot;\r\n}\r\n```\r\n\r\nI want to split this file into files dependent on their `type` property: `typea.json`, `typeb.json` etc., each containing their own stream of json objects that only have the matching type property.\r\n\r\nI&#39;ve managed to solve this problem for smaller files, however with such a large file I run out of memory on my AWS instance. As I wish to keep memory usage down, I understand I need to use `--stream` but I&#39;m struggling to see how I can achieve this.\r\n\r\n`cat input.json | jq -c --stream &#39;select(.[0][0]==&quot;type&quot;) | .[1]&#39;` will return me the values of each of the type properties, but how do I use this to then filter the objects?\r\n \r\n\r\nAny help would be greatly appreciated!\r\n\r\n",
        "link": "https://stackoverflow.com/questions/54725080/using-jq-how-can-i-split-a-json-stream-of-objects-into-separate-files-based-on",
        "title": "Using jq, how can I split a JSON stream of objects into separate files based on the values of an object property?"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 10015983,
                    "reputation": 144648,
                    "user_id": 9072753,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/EPmGy.jpg?s=256",
                    "display_name": "KamilCuk",
                    "link": "https://stackoverflow.com/users/9072753/kamilcuk"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1550572764,
                "post_id": 54764031,
                "comment_id": 96308768,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1550574560,
                "last_edit_date": 1550574560,
                "creation_date": 1550574201,
                "answer_id": 54764742,
                "question_id": 54764031,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It should be:\r\n\r\n&lt;!-- language: lang-none --&gt;\r\n\r\n    ▶ cat jsonfile | jq -r &#39;.comment.&quot;site-ops-updates&quot;[].&quot;hw-name&quot;&#39; \r\n    Machine has got missing disks. \r\n\r\nOr better still:\r\n\r\n&lt;!-- language: lang-none --&gt;\r\n\r\n    ▶ jq -r &#39;.comment.&quot;site-ops-updates&quot;[].&quot;hw-name&quot;&#39; jsonfile    \r\n    Machine has got missing disks. \r\n\r\nFrom the [docs][1]:\r\n\r\n&gt; If the key contains special characters, you need to surround it with double quotes like this: `.&quot;foo$&quot;`, or else `.[&quot;foo$&quot;]`.\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/",
                "title": "JQ query on JSON file"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1550574820,
        "creation_date": 1550572099,
        "last_edit_date": 1550574820,
        "question_id": 54764031,
        "body_markdown": "I am having below code in JSON file. \r\n\r\n```json\r\n{\r\n  &quot;comment&quot;: {\r\n    &quot;vm-updates&quot;: [],\r\n    &quot;site-ops-updates&quot;: [\r\n      {\r\n        &quot;comment&quot;: {\r\n          &quot;message&quot;: &quot;You can start maintenance on this resource&quot;\r\n        },\r\n        &quot;hw-name&quot;: &quot;Machine has got missing disks. &quot;\r\n      }\r\n    ]\r\n  },\r\n  &quot;object_name&quot;: &quot;4QXH862&quot;,\r\n  &quot;has_problems&quot;: &quot;yes&quot;,\r\n  &quot;tags&quot;: &quot;&quot;\r\n}\r\n```\r\n\r\nI want to separate &quot;hw-name&quot; from this JSON file using jq. I&#39;ve tried below combinations, but nothing worked.\r\n\r\n```\r\ncat jsonfile | jq -r &#39;.comment[].hw-name&#39;\r\ncat json_file.json | jq -r &#39;.comment[].site-ops-updates[].hw-name&#39;\r\n```\r\n\r\nAppreciated help from StackOverflow!!!\r\n",
        "link": "https://stackoverflow.com/questions/54764031/jq-query-on-json-file",
        "title": "JQ query on JSON file"
    },
    {
        "tags": [
            "json",
            "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": 1550622800,
                "post_id": 54777015,
                "comment_id": 96333679,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1550623004,
                "post_id": 54777015,
                "comment_id": 96333721,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1550623242,
                "post_id": 54777015,
                "comment_id": 96333787,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1550623261,
                "post_id": 54777015,
                "comment_id": 96333792,
                "content_license": "CC BY-SA 4.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": 1550624769,
                "post_id": 54777015,
                "comment_id": 96334108,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 85384,
                    "reputation": 2912,
                    "user_id": 238074,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/3fed50cc653f3ea8c50eb4c227237840?s=256&d=identicon&r=PG",
                    "display_name": "Kevin Buchs",
                    "link": "https://stackoverflow.com/users/238074/kevin-buchs"
                },
                "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": 1550682376,
                "post_id": 54777015,
                "comment_id": 96361625,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 85384,
                    "reputation": 2912,
                    "user_id": 238074,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/3fed50cc653f3ea8c50eb4c227237840?s=256&d=identicon&r=PG",
                    "display_name": "Kevin Buchs",
                    "link": "https://stackoverflow.com/users/238074/kevin-buchs"
                },
                "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": 1550682406,
                "post_id": 54777015,
                "comment_id": 96361643,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1550682415,
                "post_id": 54777015,
                "comment_id": 96361651,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 51201,
                    "reputation": 243376,
                    "user_id": 152948,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/194ef8f807c34a9d7aab0e11a8674768?s=256&d=identicon&r=PG",
                    "display_name": "hobbs",
                    "link": "https://stackoverflow.com/users/152948/hobbs"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1550686063,
                "post_id": 54777015,
                "comment_id": 96363417,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1550685037,
                "last_edit_date": 1550685037,
                "creation_date": 1550684426,
                "answer_id": 54792321,
                "question_id": 54777015,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The jq function `to_entries` will transform `{ &quot;KEY&quot;: &quot;VALUE&quot; }` to `{ &quot;key&quot;: &quot;KEY&quot;, &quot;value&quot;: &quot;VALUE&quot; }`.\r\n\r\nGiven that, you can refer directly to the keys, or to the values they&#39;re mapped to, as so:\r\n\r\n```jq\r\n.rows[] | to_entries[] |  [.key, .value[&quot;ec2.placement_availability_zone&quot;]] | @csv\r\n```\r\n\r\n...given your input, outputs (when run in raw mode):\r\n\r\n```\r\n&quot;i-0cf0&quot;,&quot;us-east-1d&quot;\r\n&quot;i-f9aa&quot;,&quot;us-east-1b&quot;\r\n```\r\n",
                "title": "jq program to manipulate objects with unknown keys"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1550685037,
        "creation_date": 1550622666,
        "last_edit_date": 1550682244,
        "question_id": 54777015,
        "body_markdown": "I need to manipulate objects in an array where the single key of those objects is not a fixed, common string. Here is a real quick example:\r\n\r\n    echo &#39;{ &quot;a&quot;: { &quot;b&quot; : 1 } }&#39;|jq &#39;. as $save|keys&#39;\r\n\r\nSo, the problem is &quot;a&quot; could be anything. So, I cannot use jq &#39;.a&#39;. The only way I have found to get the key name is via the *keys* built-in function. However, it seems that keys does not want to play along with a comma (throws syntax error, like:)\r\n\r\n    echo &#39;{ &quot;a&quot;: { &quot;b&quot; : 1 } }&#39;|jq &#39;keys, . as $save|$save[.]&#39;\r\n\r\nand if you reverse them as the only pipe stage, you get another error:\r\n\r\n    echo &#39;{ &quot;a&quot;: { &quot;b&quot; : 1 } }&#39;|jq &#39;. as $save, keys&#39;\r\n    jq: error: syntax error, unexpected &#39;,&#39;, expecting \r\n    &#39;|&#39; (Unix shell quoting issues?) at &lt;top-level&gt;, \r\n    line 1:  . as $save, keys\r\n    jq: 1 compile error\r\n\r\nIt seems that keys expects to be the only operator on the input and only source of output.\r\n\r\nIs there any other way to *find* &quot;a&quot;? \r\n\r\nIn the event that I have over-simplified the example I gave and you don&#39;t understand the problem, then please consider a subset of the data I actually need to manipulate:\r\n\r\n    {\r\n      &quot;rows&quot;: [\r\n        {\r\n          &quot;i-0cf0&quot;: {\r\n            &quot;chef_environment&quot;: &quot;alpha-prod&quot;,\r\n            &quot;ec2.placement_availability_zone&quot;: &quot;us-east-1d&quot;\r\n          }\r\n        },\r\n        {\r\n          &quot;i-f9aa&quot;: {\r\n            &quot;chef_environment&quot;: &quot;alpha-qa&quot;,\r\n            &quot;ec2.placement_availability_zone&quot;: &quot;us-east-1b&quot;\r\n          }\r\n        }\r\n      ]\r\n    }\r\n\r\nComments have led me to add this additional content. An example of additional manipulations I want to do for the above input, is: select based on particular values of chef_environment and for those, output the key and availability zone, e.g. \r\n\r\n    i-f9aa,us-east-1b\r\n",
        "link": "https://stackoverflow.com/questions/54777015/jq-program-to-manipulate-objects-with-unknown-keys",
        "title": "jq program to manipulate objects with unknown keys"
    },
    {
        "tags": [
            "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": 1550701995,
                "post_id": 54794749,
                "comment_id": 96370520,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1112935,
                    "reputation": 105,
                    "user_id": 10279266,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/c4a1b609df75533eb43079b045268738?s=256&d=identicon&r=PG",
                    "display_name": "suresh kumar",
                    "link": "https://stackoverflow.com/users/10279266/suresh-kumar"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1627003829,
                "post_id": 54794749,
                "comment_id": 121048121,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 81,
                "is_accepted": false,
                "score": 81,
                "last_activity_date": 1605671668,
                "last_edit_date": 1605671668,
                "creation_date": 1551649860,
                "answer_id": 54974102,
                "question_id": 54794749,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To protect against the possibility that `.items` is not an array, you could write:\r\n\r\n    .items | .[]?\r\n\r\nor even more robustly:\r\n\r\n    try .items[]\r\n\r\nwhich is equivalent to `(.items[])?`.\r\n\r\nIn summary:\r\n* `try E` is equivalent to `try E catch empty`\r\n* `try E` is equivalent to `(E)?`\r\n\r\n(Note that the expressions `.items[]?` and `(.items[])?` are not identical.)\r\n\r\nHowever none of these will provide protection against input that is invalid JSON.\r\n\r\n----\r\n\r\np.s. In future, please follow the mcve guidelines (http://stackoverflow.com/help/mcve); in the present case, it would have helped if you had provided an illustrative JSON snippet based on the output produced by the `curl` command.",
                "title": "jq: error (at &lt;stdin&gt;:0): Cannot iterate over null (null)"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1574474163,
                "creation_date": 1574474163,
                "answer_id": 59003870,
                "question_id": 54794749,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It is necessary to let JSON know that it can continue after an unexpected value while parsing that array. *try* or *?* are perfect options for that.\r\n\r\nBear in mind that it is either necessary to guarantee the data or let the interpreter to know that it is ok to continue. It may sounds redundant, but it is something like a fail-safe approach to prevent unexpected results that are harder to track/notice. \r\nAlso, it is necessary to be aware about the differences for &quot;testing&quot; between ***? vs try***.\r\n\r\nAssuming that *$sample* meets JSON standards the code bellow will work always:\r\n\r\n    sample=&#39;{&quot;myvar&quot;:1,&quot;var2&quot;:&quot;foo&quot;}&#39;\r\n    jq &#39;{newVar: ((.op[]? | .item) // 0)}&#39; &lt;&lt;&lt; $sample\r\n\r\nso, the **op** array is **null** for *$sample* as above, but it is clear to jq that it can continue without asking for your intervention/fix. \r\n\r\n----------\r\n\r\n**But if you do assume *?* as the same as *try*, you may get an error** (took me a loot to learn this, and it is not clear in the documentation). As an example of improper use of *?* we have:\r\n\r\n    sample=&#39;{&quot;myvar&quot;:1,&quot;var2&quot;:&quot;foo&quot;}&#39;\r\n    jq &#39;{newVar: (.op[].item? // 0)}&#39; &lt;&lt;&lt; $sample\r\n\r\nSo, as **op** is **null** it will lead to an error, because you are telling to jq to ignore an error while retrieving *.item*, while there is mention about the possibility of an error during the attempt to iterate over **null** (in this case **.op[]**), and that attempt happened before that point checking for *.item*.\r\nOn the other hand, **try would work in this case**:\r\n\r\n    sample=&#39;{&quot;myvar&quot;:1,&quot;var2&quot;:&quot;foo&quot;}&#39;\r\n    jq &#39;{newVar: (try .op[].item catch 0)}&#39; &lt;&lt;&lt; $sample\r\n\r\nThis is a small use difference that can lead to a large difference in the result",
                "title": "jq: error (at &lt;stdin&gt;:0): Cannot iterate over null (null)"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 47,
        "last_activity_date": 1605671668,
        "creation_date": 1550694602,
        "question_id": 54794749,
        "body_markdown": "I&#39;ve been working with an API call to structure it in JSON format so I might later push it into a database. Then code looks like this:\r\n    \r\n    getPage() {\r\n    curl --fail -X GET &#39;https://api.app.com/v1/test?page=1&amp;pageSize=1000&amp;sort=desc&#39; \\\r\n      -H &#39;Authorization: Bearer 123abc456pickupsticks789&#39; \\\r\n      -H &#39;cache-control: no-cache&#39;  \r\n    }\r\n    \r\n    getPage \\\r\n    | jq -c &#39;.items | .[] | {landing_id: .landing_id, submitted_at: .submitted_at, answers: .answers, email: .hidden.email}&#39; \\\r\n      &gt; testpush.json\r\n\r\nWhen I run it though, it produces this error: `jq: error (at &lt;stdin&gt;:0): Cannot iterate over null (null)`\r\n\r\nI&#39;ve looked at solutions such as [this one][1], [or this one from this site][2], and [this response.][3] \r\n\r\nThe common solution seemed to be using a `?` in front of `[]` and I tried it in the `jq` line towards the bottom, but it still does not work. It just produces an empty json file.\r\n\r\nAm I misreading the takeaway from those other answers and not putting my `?` in the right place?&gt;\r\n\r\n  [1]: https://www.google.com/url?sa=t&amp;rct=j&amp;q=&amp;esrc=s&amp;source=web&amp;cd=1&amp;cad=rja&amp;uact=8&amp;ved=2ahUKEwjTkOaaksvgAhWGT98KHeJjCSgQFjAAegQICRAB&amp;url=https%3A%2F%2Fmarkhneedham.com%2Fblog%2F2015%2F10%2F09%2Fjq-error-cannot-iterate-over-null-null%2F&amp;usg=AOvVaw3MlzRddK0KFA3kn14E8u78\r\n  [2]: https://stackoverflow.com/questions/28213232/docker-error-jq-error-cannot-iterate-over-null\r\n  [3]: https://www.google.com/url?sa=t&amp;rct=j&amp;q=&amp;esrc=s&amp;source=web&amp;cd=3&amp;cad=rja&amp;uact=8&amp;ved=2ahUKEwiVstTNksvgAhUIWN8KHUukBucQFjACegQIBxAB&amp;url=https%3A%2F%2Fstackoverflow.com%2Fquestions%2F54176763%2Fgithub-actions-filter-returns-jq-error-cannot-iterate-over-null-null&amp;usg=AOvVaw2YRkgqsn5G_w4SbTSP_ZQJ",
        "link": "https://stackoverflow.com/questions/54794749/jq-error-at-stdin0-cannot-iterate-over-null-null",
        "title": "jq: error (at &lt;stdin&gt;:0): Cannot iterate over null (null)"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 10,
                "is_accepted": true,
                "score": 8,
                "last_activity_date": 1550798257,
                "creation_date": 1550798257,
                "answer_id": 54818662,
                "question_id": 54814037,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use `test` filter to do the check and return true/false. And I think you can just use the filters directly, no need to create a json and convert again.\r\n\r\n    happystring=&quot;Bob Ross&quot;\r\n    unhappynumber1=&quot;1942&quot;\r\n    unhappyboolean=true\r\n    \r\n    JSON=$(jq -n \\\r\n            --arg happystring &quot;$happystring&quot; --arg unhappynumber1 &quot;$unhappynumber1&quot; \\\r\n            --arg unhappyboolean $unhappyboolean \\\r\n            &#39;\r\n            {\r\n                happystring: $happystring,\r\n                unhappynumber1: $unhappynumber1 | tonumber,\r\n                unhappyboolean: $unhappyboolean | test(&quot;true&quot;)\r\n            }\r\n            &#39;)\r\n    \r\n    echo &quot;$JSON&quot; | jq\r\n\r\nwill give output as:\r\n\r\n    {\r\n      &quot;happystring&quot;: &quot;Bob Ross&quot;,\r\n      &quot;unhappynumber1&quot;: 1942,\r\n      &quot;unhappyboolean&quot;: true\r\n    }",
                "title": "JQ convert to number, convert to boolean when generating new json from shell variables"
            },
            {
                "up_vote_count": 18,
                "is_accepted": false,
                "score": 18,
                "last_activity_date": 1550866751,
                "last_edit_date": 1550866751,
                "creation_date": 1550851001,
                "answer_id": 54830801,
                "question_id": 54814037,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "There&#39;s no need to convert variables to strings like `--arg` does only to convert them back, you can use `--argjson` and still input them separately but with types determined by the normal JSON rules:\r\n\r\n\r\n    happystring=&#39;&quot;Bob Ross&quot;&#39;\r\n    unhappynumber1=1942\r\n    unhappyboolean=true\r\n\r\n    JSON=$(jq -n \\\r\n          --argjson happystring &quot;$happystring&quot; \\\r\n          --argjson unhappynumber1 &quot;$unhappynumber1&quot; \\\r\n          --argjson unhappyboolean &quot;$unhappyboolean&quot; \\\r\n          &#39;\r\n          {\r\n              happystring: $happystring,\r\n              unhappynumber1: $unhappynumber1,\r\n              unhappyboolean: $unhappyboolean\r\n          }\r\n          &#39;)\r\n\r\n          echo &quot;$JSON&quot;\r\n\r\nYou could also mix `--arg` for strings and `--argjson` for everything else if you prefer not needing literal `&quot;` quotes for the string arguments, as the [note in the manual][1] on shell quoting and the program text really applies to any arguments with characters you need to escape in your shell:\r\n\r\n&gt; Note: it is important to mind the shell’s quoting rules. As a general rule it’s best to always quote (with single-quote characters) the jq program, as too many characters with special meaning to jq are also shell meta-characters. For example, jq &quot;foo&quot; will fail on most Unix shells because that will be the same as jq foo, which will generally fail because foo is not defined. When using the Windows command shell (cmd.exe) it’s best to use double quotes around your jq program when given on the command-line (instead of the -f program-file option), but then double-quotes in the jq program need backslash escaping.\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/#Invokingjq",
                "title": "JQ convert to number, convert to boolean when generating new json from shell variables"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 11,
        "last_activity_date": 1550866751,
        "creation_date": 1550774246,
        "last_edit_date": 1550854404,
        "question_id": 54814037,
        "body_markdown": "I&#39;m attempting to generate json output where the input is coming from shell variables.\r\n\r\n    happystring=&quot;Bob Ross&quot;\r\n    unhappynumber1=&quot;1942&quot;\r\n    unhappyboolean=true\r\n    \r\n    JSON=$(jq -n \\\r\n            --arg happystring &quot;$happystring&quot; --arg unhappynumber1 &quot;$unhappynumber1&quot; \\\r\n            --arg unhappyboolean $unhappyboolean \\\r\n            &#39;\r\n            {\r\n                happystring: $happystring,\r\n                unhappynumber1: $unhappynumber1,\r\n                unhappyboolean: $unhappyboolean\r\n            }\r\n            &#39;)\r\n    \r\n    echo &quot;$JSON&quot; | jq\r\n\r\nProduces this output:\r\n\r\n    {\r\n      &quot;happystring&quot;: &quot;Bob Ross&quot;,\r\n      &quot;unhappynumber1&quot;: &quot;1942&quot;,\r\n      &quot;unhappyboolean&quot;: &quot;true&quot;\r\n    }\r\n\r\nI know I can use `tonumber` to convert a string to a number in a simple filter.  However, I cannot figure out how to convert a string to a boolean.  And I&#39;m having trouble reasoning how to do either when sourcing from shell vars and creating new json as output.\r\n\r\nDesired output:\r\n\r\n    {\r\n      &quot;happystring&quot;: &quot;Bob Ross&quot;,\r\n      &quot;unhappynumber1&quot;: 1942,\r\n      &quot;unhappyboolean&quot;: true\r\n    }\r\n\r\nWould it be easier or more clear if I produced the json and stored it in a shell var in one step, and then performed the additional conversion in a second step?",
        "link": "https://stackoverflow.com/questions/54814037/jq-convert-to-number-convert-to-boolean-when-generating-new-json-from-shell-var",
        "title": "JQ convert to number, convert to boolean when generating new json from shell variables"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6929975,
                    "reputation": 2562,
                    "user_id": 5319738,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/33be75bf8acd83e41411d134106c8811?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Kamal",
                    "link": "https://stackoverflow.com/users/5319738/kamal"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1550800469,
                "post_id": 54814990,
                "comment_id": 96413507,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": -1,
                "last_activity_date": 1627618667,
                "last_edit_date": 1627618667,
                "creation_date": 1627439482,
                "answer_id": 68553683,
                "question_id": 54814990,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "**Horrible** solution, delete them after the query. There must be a neater way? (I started using jq today)\r\n\r\n    .amazon | { userType: .userType, userName: .user, itemCatalog: (.items | map({ itemId: .id, name, state} )) }| del(.itemCatalog[].state |select(. == null))\r\n\r\nhttps://jqplay.org/s/jlNYmJNi25\r\n",
                "title": "Conditionally add a field in JSON transformation using JQ"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1627618667,
        "creation_date": 1550778054,
        "last_edit_date": 1550779119,
        "question_id": 54814990,
        "body_markdown": "I am trying to transform my JSON to different structure using JQ. I am able to achieve my new structure, however i am getting feilds with Null objects if they are not present in Source, my client wants to remove the fields if they are having null values..\r\n\r\nAs i iterate i am able to get the structure in new format. But additional structures are coming.\r\n\r\nCode Snippet- https://jqplay.org/s/w2N_Ozg9Ag\r\n\r\nJSON\r\n\r\n        {\r\n\t\t\t\t  &quot;amazon&quot;: {\r\n\t\t\t\t    &quot;activeitem&quot;: 2,\r\n\t\t\t\t    &quot;createdDate&quot;: &quot;2019-01-15T17:36:31.588Z&quot;,\r\n\t\t\t\t    &quot;lastModifiedDate&quot;: &quot;2019-01-15T17:36:31.588Z&quot;,\r\n\t\t\t\t    &quot;user&quot;: &quot;net&quot;,\r\n\t\t\t\t    &quot;userType&quot;: &quot;new&quot;,\r\n\t\t\t\t    &quot;items&quot;: [\r\n\t\t\t\t      {\r\n\t\t\t\t        &quot;id&quot;: 1,\r\n\t\t\t\t        &quot;name&quot;: &quot;harry potter&quot;,\r\n\t\t\t\t        &quot;state&quot;: &quot;sold&quot;,\r\n\t\t\t\t        &quot;type&quot;: {\r\n\t\t\t\t          &quot;branded&quot;: false,\r\n\t\t\t\t          &quot;description&quot;: &quot;artwork&quot;,\r\n\t\t\t\t          &quot;contentLevel&quot;: &quot;season&quot;\r\n\t\t\t\t        }\r\n\t\t\t\t      },\r\n\t\t\t\t      {\r\n\t\t\t\t        &quot;id&quot;: 2,\r\n\t\t\t\t        &quot;name&quot;: &quot;adidas shoes&quot;,\r\n\t\t\t\t        &quot;state&quot;: null ,\r\n\t\t\t\t        &quot;type&quot;: {\r\n\t\t\t\t          &quot;branded&quot;: false,\r\n\t\t\t\t          &quot;description&quot;: &quot;Spprts&quot;,\r\n\t\t\t\t          &quot;contentLevel&quot;: &quot;season&quot;\r\n\t\t\t\t        }\r\n\t\t\t\t      },\r\n\t\t\t\t      {\r\n\t\t\t\t        &quot;id&quot;: 3,\r\n\t\t\t\t        &quot;name&quot;: &quot;watch&quot;,\r\n\t\t\t\t        &quot;type&quot;: {\r\n\t\t\t\t          &quot;branded&quot;: false,\r\n\t\t\t\t          &quot;description&quot;: &quot;walking&quot;,\r\n\t\t\t\t          &quot;contentLevel&quot;: &quot;special&quot;\r\n\t\t\t\t        }\r\n\t\t\t\t      },\r\n\t\t\t\t      {\r\n\t\t\t\t        &quot;id&quot;: 4,\r\n\t\t\t\t        &quot;name&quot;: &quot;adidas shoes&quot;,\r\n\t\t\t\t        &quot;state&quot;: &quot;in inventory&quot;,\r\n\t\t\t\t        &quot;type&quot;: {\r\n\t\t\t\t          &quot;branded&quot;: false,\r\n\t\t\t\t          &quot;description&quot;: &quot;running&quot;,\r\n\t\t\t\t          &quot;contentLevel&quot;: &quot;winter&quot;\r\n\t\t\t\t        }\r\n\t\t\t\t      }\r\n\t\t\t\t    ],\r\n\t\t\t\t    &quot;product&quot;: {\r\n\t\t\t\t      &quot;id&quot;: 4,\r\n\t\t\t\t      &quot;name&quot;: &quot;adidas shoes&quot;,\r\n\t\t\t\t      &quot;source&quot;: &quot;dealer&quot;,\r\n\t\t\t\t      &quot;destination&quot;: &quot;resident&quot;\r\n\t\t\t\t    }\r\n\t\t\t\t  }\r\n\t\t\t\t}\r\n\r\n\r\n\r\nJQ Query:\r\n\r\n\r\n\r\n           .amazon | { userType: .userType,     userName: .user,     itemCatalog: (.items | map({ itemId: .id, name, state} ))   }\r\n\r\n\r\nExpected Response:\r\n\r\n\r\n            {\r\n\t\t\t\t  &quot;userType&quot;: &quot;new&quot;,\r\n\t\t\t\t  &quot;userName&quot;: &quot;net&quot;,\r\n\t\t\t\t  &quot;itemCatalog&quot;: [\r\n\t\t\t\t    {\r\n\t\t\t\t      &quot;itemId&quot;: 1,\r\n\t\t\t\t      &quot;name&quot;: &quot;harry potter&quot;,\r\n\t\t\t\t      &quot;state&quot;: &quot;sold&quot;\r\n\t\t\t\t    },\r\n\t\t\t\t    {\r\n\t\t\t\t      &quot;itemId&quot;: 2,\r\n\t\t\t\t      &quot;name&quot;: &quot;adidas shoes&quot;\r\n\t\t\t\t    },\r\n\t\t\t\t    {\r\n\t\t\t\t      &quot;itemId&quot;: 3,\r\n\t\t\t\t      &quot;name&quot;: &quot;watch&quot;\r\n\t\t\t\t    },\r\n\t\t\t\t    {\r\n\t\t\t\t      &quot;itemId&quot;: 4,\r\n\t\t\t\t      &quot;name&quot;: &quot;adidas shoes&quot;,\r\n\t\t\t\t      &quot;state&quot;: &quot;in inventory&quot;\r\n\t\t\t\t    }\r\n\t\t\t\t  ]\r\n\t\t\t\t}\r\n\r\n\r\nWith the query i have, i am getting **state : null** for the entries which has  empty or null values. I want to hide the field itself in these cases.",
        "link": "https://stackoverflow.com/questions/54814990/conditionally-add-a-field-in-json-transformation-using-jq",
        "title": "Conditionally add a field in JSON transformation using JQ"
    },
    {
        "tags": [
            "json",
            "key",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1550785469,
                "creation_date": 1550785469,
                "answer_id": 54816696,
                "question_id": 54816639,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": " In brief, since {wanted: .wanted} can be abbreviated to {wanted}:\r\n\r\n    .large | {wanted}",
                "title": "JQ keep key in result"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1550813512,
        "creation_date": 1550785144,
        "last_edit_date": 1550813512,
        "question_id": 54816639,
        "body_markdown": "I have a json\r\n\r\n    {\r\n        &quot;large&quot;: {\r\n            &quot;key1&quot;: &quot;one&quot;,\r\n            &quot;key2&quot;: &quot;two&quot;,\r\n            &quot;key3&quot;: &quot;three&quot;,\r\n            &quot;wanted&quot;: {\r\n                &quot;here&quot;: &quot;result&quot;\r\n             }\r\n        }\r\n    }\r\n\r\nAnd I want \r\n\r\n    {\r\n        &quot;wanted&quot;: {\r\n                   &quot;here&quot;: &quot;result&quot;\r\n                  }             \r\n    }\r\n\r\n`jq &#39;.large.wanted&#39;` removes the key `wanted`, but im trying to keep it. How can I do this?\r\n\r\n",
        "link": "https://stackoverflow.com/questions/54816639/jq-keep-key-in-result",
        "title": "JQ keep key in result"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1551472020,
                "last_edit_date": 1551472020,
                "creation_date": 1550963246,
                "answer_id": 54847159,
                "question_id": 54842908,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I think using `last` is a good indication that you don&#39;t care about intermediate values and since foreach[1] is described as:\r\n\r\n&gt; The foreach syntax is similar to reduce, but intended to allow the construction of limit and reducers that produce intermediate results\r\n\r\nThere is an equivalent reduce:\r\n\r\n`reduce .names[] as $name (.; .del[$name]=false)`\r\n\r\nWhen both are possible, reduce is more efficient in terms of code as communication with other programmers and potential performance. (If the `reduce` implementation were found to be slower than a pattern with `foreach`, then jq could reimplement `reduce` with that pattern.)\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/#foreach",
                "title": "jq update objects based on array of object names"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1551472020,
        "creation_date": 1550934093,
        "last_edit_date": 1550963970,
        "question_id": 54842908,
        "body_markdown": "I&#39;m trying to update some objects based on a list of objects. For example I want to turn this:\r\n\r\n    {\r\n      &quot;names&quot;: [&quot;a&quot;,&quot;c&quot;],\r\n      &quot;del&quot;: {\r\n          &quot;a&quot;: true,\r\n          &quot;b&quot;: true,\r\n          &quot;c&quot;: true\r\n      }\r\n    }\r\n\r\ninto this:\r\n\r\n    {\r\n      &quot;names&quot;: [&quot;a&quot;,&quot;c&quot;],\r\n      &quot;del&quot;: {\r\n          &quot;a&quot;: false,\r\n          &quot;b&quot;: true,\r\n          &quot;c&quot;: false\r\n      }\r\n    }\r\n\r\nSo for each object name in `.names` update its corresponding object in `.del` \r\nThe solution I can up with seems inefficient and I was wondering if there was a better way.\r\n\r\n`[foreach .names[] as $name (.;.del[$name] = false ; .) ] | last`\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/54842908/jq-update-objects-based-on-array-of-object-names",
        "title": "jq update objects based on array of object names"
    },
    {
        "tags": [
            "python",
            "json",
            "python-2.7",
            "shell",
            "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": 1551109325,
                "post_id": 54867655,
                "comment_id": 96510039,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1551104394,
                "creation_date": 1551104394,
                "answer_id": 54868240,
                "question_id": 54867655,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Just do it in your SELECT instead of pulling another program into a pipeline. MySQL has [JSON functions](https://dev.mysql.com/doc/refman/8.0/en/json-function-reference.html). Ones of interest here are `JSON_ARRAYAGG()` and `JSON_OBJECT()`. Something like:\r\n\r\n\r\n    SELECT json_arrayagg(json_object(&#39;user&#39;, user, &#39;host&#39;, host)) FROM mysql.user;\r\n\r\nshould do it, plus whatever&#39;s needed to not print out that fancy table ascii art.",
                "title": "how to use jq tools or python as a output encoder to make result to translate to json formot is a difficult question"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1551639575,
                "creation_date": 1551639575,
                "answer_id": 54972537,
                "question_id": 54867655,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s an all-jq solution that assumes an invocation like this:\r\n\r\n    jq -Rcn -f program.jq sql.txt\r\n\r\nNote in particular the -R (&quot;raw input&quot;) and -n options.\r\n\r\n    def trim: sub(&quot; *$&quot;;&quot;&quot;) | sub(&quot;^ *&quot;;&quot;&quot;);\r\n    \r\n    # input: an array of values\r\n    def objectify($headers):\r\n      . as $in\r\n      | reduce range(0; $headers|length) as $i ({}; .[$headers[$i]] = ($in[$i]) ) ;\r\n    \r\n    def preprocess:\r\n      select( startswith(&quot;|&quot;) )\r\n      | split(&quot;|&quot;)\r\n      | .[1:-1]\r\n      | map(trim) ;\r\n    \r\n    reduce (inputs|preprocess) as $in (null;\r\n        if . == null then {header: $in}\r\n        else .header as $h\r\n        | .table += [$in|objectify($h)]\r\n        end )\r\n      | .table\r\n      ",
                "title": "how to use jq tools or python as a output encoder to make result to translate to json formot is a difficult question"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": -1,
        "last_activity_date": 1551639575,
        "creation_date": 1551102399,
        "last_edit_date": 1551102720,
        "question_id": 54867655,
        "body_markdown": "**for a example**\r\n\r\n[root@test ~]# mysql -uroot -p&#39;123123&#39; -e&quot;select user,host from mysql.user;&quot;\r\n\r\n    +-------------------+-----------+\r\n    | user              | host      |\r\n    +-------------------+-----------+\r\n    | root              | %         |\r\n    | test              | %         |\r\n    | sqlaudit_test_mon | %         |\r\n    | sysbase_test      | %         |\r\n    | mysql.session     | localhost |\r\n    | mysql.sys         | localhost |\r\n    +-------------------+-----------+\r\n\r\nhow to make search the result quick to convert to json format can you jq tools or python\r\nsuch as that out put\r\n\r\n    [\r\n            {\r\n                     &quot;user&quot;:&quot;root&quot;,&quot;host&quot;:&quot;%&quot;},\r\n\t\t\t{\r\n                     &quot;user&quot;:&quot;test&quot;,&quot;host&quot;:&quot;%&quot;},\t\t\r\n\t\t\t{\r\n                     &quot;user&quot;:&quot;sqlaudit_test_mon&quot;,&quot;host&quot;:&quot;%&quot;},\r\n\t\t\t{\r\n                     &quot;user&quot;:&quot;sysbase_test&quot;,&quot;host&quot;:&quot;%&quot;},\r\n\t\t\t{\r\n                     &quot;user&quot;:&quot;mysql.session&quot;,&quot;host&quot;:&quot;localhost&quot;},\r\n\t\t\t{\r\n                     &quot;user&quot;:&quot;mysql.sys&quot;,&quot;host&quot;:&quot;localhost&quot;}\t\t\t\t\t \r\n    ]\r\n\r\ni just want to know how to quick make search result to json,thank you!\r\nit is better to user jq or python script it can make me search result to json format.\r\n",
        "link": "https://stackoverflow.com/questions/54867655/how-to-use-jq-tools-or-python-as-a-output-encoder-to-make-result-to-translate-to",
        "title": "how to use jq tools or python as a output encoder to make result to translate to json formot is a difficult question"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3388857,
                    "reputation": 1905,
                    "user_id": 2844215,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/X3158.jpg?s=256",
                    "display_name": "IMParasharG",
                    "link": "https://stackoverflow.com/users/2844215/imparasharg"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1551111537,
                "post_id": 54870363,
                "comment_id": 96511334,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1551112008,
                "creation_date": 1551112008,
                "answer_id": 54870634,
                "question_id": 54870363,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "First you&#39;ll want to read in all files as input, then combine all `Pack` items and aggregating them into groups by `id`, then take those groups and arrange them to the result you need.\r\n\r\n    $ jq -n &#39;\r\n    {Pack: ([inputs.Pack[]] | group_by(.id) | map({id: .[0].id, lang: (map(.lang) | add)}))}\r\n    &#39; file*.json\r\n\r\nThis results in:\r\n\r\n    {\r\n      &quot;Pack&quot;: [\r\n        {\r\n          &quot;id&quot;: &quot;item1&quot;,\r\n          &quot;lang&quot;: {\r\n            &quot;en&quot;: {},\r\n            &quot;sp&quot;: {}\r\n          }\r\n        },\r\n        {\r\n          &quot;id&quot;: &quot;item2&quot;,\r\n          &quot;lang&quot;: {\r\n            &quot;en&quot;: {}\r\n          }\r\n        }\r\n      ]\r\n    }\r\n\r\n",
                "title": "Merge array by using inner property"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1551231435,
        "creation_date": 1551111069,
        "question_id": 54870363,
        "body_markdown": "I have different language files like these:\r\n\r\n**file1**\r\n\r\n    {\r\n    \t&quot;Pack&quot;: [\r\n    \t\t{\r\n    \t\t\t&quot;id&quot;: &quot;item1&quot;,\r\n    \t\t\t&quot;lang&quot;: {\r\n    \t\t\t\t&quot;en&quot;: {\r\n    \t\t\t\t}\r\n    \t\t\t}\r\n    \t\t},\r\n    \t\t{\r\n    \t\t\t&quot;id&quot;: &quot;item2&quot;,\r\n    \t\t\t&quot;lang&quot;: {\r\n    \t\t\t\t&quot;en&quot;: {\r\n    \t\t\t\t}\r\n    \t\t\t}\r\n    \t\t}\r\n    \t]\r\n    }\r\n\r\n**file2**\r\n\r\n    {\r\n    \t&quot;Pack&quot;: [\r\n    \t\t{\r\n    \t\t\t&quot;id&quot;: &quot;item1&quot;,\r\n    \t\t\t&quot;lang&quot;: {\r\n    \t\t\t\t&quot;sp&quot;: {\r\n    \t\t\t\t}\r\n    \t\t\t}\r\n    \t\t}\r\n    \t]\r\n    }\r\n\r\nand I need to merge the same ids by **lang** field. Final file should looks like:\r\n\r\n    {\r\n    \t&quot;Pack&quot;: [\r\n    \t\t{\r\n    \t\t\t&quot;id&quot;: &quot;item1&quot;,\r\n    \t\t\t&quot;lang&quot;: {\r\n    \t\t\t\t&quot;en&quot;: {\r\n    \t\t\t\t},\r\n    \t\t\t\t&quot;sp&quot;: {\r\n    \t\t\t\t}\r\n    \t\t\t}\r\n    \t\t},\r\n    \t\t{\r\n    \t\t\t&quot;id&quot;: &quot;item2&quot;,\r\n    \t\t\t&quot;lang&quot;: {\r\n    \t\t\t\t&quot;en&quot;: {\r\n    \t\t\t\t}\r\n    \t\t\t}\r\n    \t\t}\r\n    \t]\r\n    }\r\n\r\nI think I should use something like more complex command but my starting point is:\r\n\r\n    jq -s &#39;{ attributes: map(.attributes[0]) }&#39; file*.json",
        "link": "https://stackoverflow.com/questions/54870363/merge-array-by-using-inner-property",
        "title": "Merge array by using inner property"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1551136182,
                "creation_date": 1551136182,
                "answer_id": 54876089,
                "question_id": 54874782,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The try-catch isn&#39;t really an expression, it yields no meaningful value, it merely executes some expression:\r\n\r\n[try-catch](https://stedolan.github.io/jq/manual/#try-catch)\r\n\r\n&gt; Errors can be caught by using try EXP catch EXP. **The first expression is executed, and if it fails then the second is executed with the error message.** The output of the handler, if any, is output as if it had been the output of the expression to try.\r\n\r\nemphasis mine.\r\n\r\nSo it would be wrong to use the value, you should perform the assignment within the try expression.\r\n\r\n    $ echo &#39;{&quot;array&quot;: [{&quot;foo&quot;:&quot;bar&quot;}]}&#39; | jq -c &#39;try (.array[] |= .) catch (.)&#39;",
                "title": "update array elements with try catch"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1551474415,
                "creation_date": 1551474415,
                "answer_id": 54952300,
                "question_id": 54874782,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You have stumbled upon a bug in jq 1.6. Using jq 1.5, one obtains the correct output:\r\n\r\n    {&quot;array&quot;:[{&quot;foo&quot;:&quot;bar&quot;}]}\r\n\r\nHowever, the expression `.array[] |= try . catch (.)` is not one would ever use in practice, because if .array is a JSON array or JSON object, it just says: do nothing.\r\n\r\nTo understand `try ... catch ...`, it might help to consider this example:\r\n\r\n    $ jq -n &#39;try error(&quot;abc&quot;) catch (&quot;The error message was &quot; + .)&#39;\r\n    &quot;The error message was abc&quot;\r\n\r\n",
                "title": "update array elements with try catch"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1551474415,
        "creation_date": 1551129290,
        "question_id": 54874782,
        "body_markdown": "I&#39;m trying to update large complexe json files and exit with detailled error message when detecting incoherent data (with jq 1.6).\r\n\r\nI started to use functions and try/catch to produce a kind of java stacktrace containing input data from each level =&gt; easy, thank you JQ\r\n\r\nBut when I started to update array elements (using |=), I didn&#39;t find the solution\r\n\r\nHere is a very simple example :\r\n\r\n    echo &#39;{&quot;array&quot;: [{&quot;foo&quot;:&quot;bar&quot;}]}&#39; | jq -c &#39;.array[] |= try . catch (.)&#39;\r\n    output : {&quot;array&quot;:[{&quot;__jq&quot;:0}]}\r\n\r\nDo I made a mistake ? Is it a normal behaviour ?\r\n\r\nThanks for your help",
        "link": "https://stackoverflow.com/questions/54874782/update-array-elements-with-try-catch",
        "title": "update array elements with try catch"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 51201,
                    "reputation": 243376,
                    "user_id": 152948,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/194ef8f807c34a9d7aab0e11a8674768?s=256&d=identicon&r=PG",
                    "display_name": "hobbs",
                    "link": "https://stackoverflow.com/users/152948/hobbs"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1551134961,
                "post_id": 54875776,
                "comment_id": 96521841,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 81175,
                    "reputation": 2702,
                    "user_id": 229058,
                    "user_type": "registered",
                    "accept_rate": 75,
                    "profile_image": "https://www.gravatar.com/avatar/1556e6ebdef89457b4a34b9a1b426a2a?s=256&d=identicon&r=PG",
                    "display_name": "Stephen Rasku",
                    "link": "https://stackoverflow.com/users/229058/stephen-rasku"
                },
                "reply_to_user": {
                    "account_id": 51201,
                    "reputation": 243376,
                    "user_id": 152948,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/194ef8f807c34a9d7aab0e11a8674768?s=256&d=identicon&r=PG",
                    "display_name": "hobbs",
                    "link": "https://stackoverflow.com/users/152948/hobbs"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1551135042,
                "post_id": 54875776,
                "comment_id": 96521875,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1551135292,
                "creation_date": 1551135292,
                "answer_id": 54875953,
                "question_id": 54875776,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This works:\r\n\r\n    map(. + {authorizedKey: {&quot;0&quot;: &quot;zero&quot;, &quot;1&quot;: &quot;one&quot;}[.authorizedKey]})\r\n\r\nIf there are other values besides 0 and 1, you can add them to the map. If you have a bunch more and you want to improve readability, you could do this:\r\n\r\n    {&quot;0&quot;: &quot;zero&quot;, &quot;1&quot;: &quot;one&quot;} as $mapping |\r\n      map(. + {authorizedKey: $mapping[.authorizedKey]})\r\n\r\nwhich avoids writing the value-mapping in the middle of the code.\r\n\r\nThis works because the `+` operator is defined on objects in jq, and if a key in the RHS already exists in the LHS, its value is replaced with the corresponding value from the RHS.",
                "title": "Transforming authorizedKey field in array using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1551135292,
        "creation_date": 1551134365,
        "question_id": 54875776,
        "body_markdown": "Given the following structure:\r\n\r\n    [\r\n      {\r\n        &quot;authorizedKey&quot;: &quot;0&quot;,\r\n        &quot;description&quot;: &quot;This key is for system testing.&quot;,\r\n        &quot;keyExpiration&quot;: &quot;2035-02-02T18:28:59Z&quot;,\r\n        &quot;keyId&quot;: &quot;aaa12345-1234-1234-1234-1234567890ab&quot;\r\n      },\r\n      {\r\n        &quot;authorizedKey&quot;: &quot;1&quot;,\r\n        &quot;description&quot;: &quot;This key is for system testing.&quot;,\r\n        &quot;keyExpiration&quot;: &quot;2035-02-02T18:28:59Z&quot;,\r\n        &quot;keyId&quot;: &quot;bbb12345-1234-1234-1234-1234567890ab&quot;\r\n      },\r\n      {\r\n        &quot;authorizedKey&quot;: &quot;1&quot;,\r\n        &quot;description&quot;: &quot;This key is for system testing.&quot;,\r\n        &quot;keyExpiration&quot;: &quot;2035-02-02T18:28:59Z&quot;,\r\n        &quot;keyId&quot;: &quot;ccc12345-1234-1234-1234-1234567890ab&quot;\r\n      }\r\n    ]\r\n\r\nUsing only `jq`, is there a way to transform it to the following structure? \r\n Or would I need to wrap it in some kind of external logic?\r\n\r\n    [\r\n      {\r\n        &quot;authorizedKey&quot;: &quot;zero&quot;,\r\n        &quot;description&quot;: &quot;This key is for system testing.&quot;,\r\n        &quot;keyExpiration&quot;: &quot;2035-02-02T18:28:59Z&quot;,\r\n        &quot;keyId&quot;: &quot;aaa12345-1234-1234-1234-1234567890ab&quot;\r\n      },\r\n      {\r\n        &quot;authorizedKey&quot;: &quot;one&quot;,\r\n        &quot;description&quot;: &quot;This key is for system testing.&quot;,\r\n        &quot;keyExpiration&quot;: &quot;2035-02-02T18:28:59Z&quot;,\r\n        &quot;keyId&quot;: &quot;bbb12345-1234-1234-1234-1234567890ab&quot;\r\n      },\r\n      {\r\n        &quot;authorizedKey&quot;: &quot;one&quot;,\r\n        &quot;description&quot;: &quot;This key is for system testing.&quot;,\r\n        &quot;keyExpiration&quot;: &quot;2035-02-02T18:28:59Z&quot;,\r\n        &quot;keyId&quot;: &quot;ccc12345-1234-1234-1234-1234567890ab&quot;\r\n      }\r\n    ]\r\n",
        "link": "https://stackoverflow.com/questions/54875776/transforming-authorizedkey-field-in-array-using-jq",
        "title": "Transforming authorizedKey field in array using jq"
    },
    {
        "tags": [
            "bash",
            "csv",
            "export-to-csv",
            "jq",
            "github-api"
        ],
        "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": 1551186948,
                "post_id": 54886306,
                "comment_id": 96541733,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1551187002,
                "post_id": 54886306,
                "comment_id": 96541751,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1551187106,
                "post_id": 54886306,
                "comment_id": 96541811,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1551187280,
                "post_id": 54886306,
                "comment_id": 96541922,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 15215309,
                    "reputation": 33,
                    "user_id": 10978843,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/-599YNl61IuU/AAAAAAAAAAI/AAAAAAAAAAA/ACevoQOyeibYUeeWUZ4oWh3UxDI6hE8ahw/mo/s256-rj/photo.jpg",
                    "display_name": "adonis",
                    "link": "https://stackoverflow.com/users/10978843/adonis"
                },
                "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": 1551193066,
                "post_id": 54886306,
                "comment_id": 96545745,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1663589230,
                "post_id": 54886306,
                "comment_id": 130267981,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 0,
        "last_activity_date": 1663589122,
        "creation_date": 1551186612,
        "last_edit_date": 1663589122,
        "question_id": 54886306,
        "body_markdown": "For a project I need to extract data from a lot of different blockchain GitHub profiles to a csv.\r\n\r\nAfter browsing through the GitHub API I was able to achieve some of the necessary data being shown as txt/csv files using bash commands and jq.\r\n\r\nNow doing all of this manually would probably take 7 days. I have a list of profiles i need to loop through saved as CSV.\r\n\r\nThe list looks like this --&gt; https://docs.google.com/spreadsheets/d/1lFsewAYI7F8zSw7WPhI9E9WwR8f4G1clw1yjxY3wz_4/edit#gid=0\r\n\r\n\r\nMy approach so far to get all the repo names looks like this:\r\n\r\n    sample=&#39;[{&quot;name&quot;:&quot;0chain&quot;},{&quot;name&quot;:&quot;0stateapp&quot;},{&quot;name&quot;:&quot;0xcert&quot;}]&#39;\r\n\r\nthe csv belongs in here, I didn&#39;t know how to redirect it to that variable yet, but for testing purposes this was enough. If somebody knows how to, feel free to give a hint.\r\n\r\n    for row in $(echo &quot;${sample}&quot; | jq -r &#39;.[] | @base64&#39;); do\r\n    _jq() \r\n    {\r\n     echo ${row} | base64 --decode | jq -r ${1}\r\n    }\r\n\r\n    for GHUSER in $( echo $(_jq &#39;.name&#39;)); do\r\n\r\n      curl -s https://api.github.com/users/$GHUSER/repos?per_page=100 | jq -r &#39;.[]|.full_name&#39;\r\n\r\n    done\r\n\r\n    done\r\n\r\n\r\nThe output looks like this:\r\n\r\n    0chain/0chain-token\r\n    0chain/client-sdk\r\n    0chain/docs\r\n    0chain/gorocksdb\r\n    0chain/hostadmin\r\n    0chain/rocksdb\r\n    0stateapp/ZSCoin\r\n    0xcert/0xcert\r\n    0xcert/conventions\r\n    0xcert/docs\r\n    0xcert/erc721-validator\r\n    0xcert/erc721-validator-api\r\n    0xcert/erc721-validator-ui\r\n    0xcert/erc721-website\r\n    0xcert/ethereum\r\n    0xcert/ethereum-crowdsale\r\n    0xcert/ethereum-dex\r\n    0xcert/ethereum-erc20\r\n    0xcert/ethereum-erc721\r\n    0xcert/ethereum-minter\r\n    0xcert/ethereum-utils\r\n    0xcert/ethereum-xcert\r\n    0xcert/ethereum-xcert-builder\r\n    0xcert/ethereum-zxc\r\n    0xcert/framework\r\n    0xcert/framework-cert-test\r\n    0xcert/nonfungiblealliance-www\r\n    0xcert/solidity-style-guide\r\n    0xcert/techpaper\r\n    0xcert/truffle\r\n    0xcert/web3.js\r\n\r\nWhat I need to do is use all of the above values and generate a file that contains:\r\n\r\n - Github Profile (already stored in the attached sheet) \r\n - The Date when accessing this information  \r\n - All the repositories belonging to that profile (code above but\r\n   filtered)\r\n\r\nNow the Interesting part:\r\nThe commit history\r\n\r\n - number of commit (ID)\r\n - number of commit (ID)\r\n - Date of commit\r\n - Description of commit\r\n - person who commited\r\n - checks passed\r\n - checks failed\r\n\r\nAlmost the same needs to be done for closed and open pull requests although I think when solving the &quot;problem&quot; above solving the pull requests is the same strategy.\r\n\r\nFor the commits I&#39;d do something like this:\r\n\r\n    for commits in $( $repoarray) do curl -i https://api.github.com/repos/$commits/commits | jq -r &#39;.[]|.author.lgoin (and whatever els is needed)&#39; done\r\n\r\nbasically this chart here needs to be filled\r\n\r\nhttps://docs.google.com/spreadsheets/d/1mFXiohiWNXNP8CVztFA1PFF41jn3J9sRUhYALZShsPY/edit?usp=sharing\r\n\r\nwhat I need help with:\r\n\r\n - storing my output from the first loop in a an array\r\n - loop through that array to get the number of commits\r\n - loop through that array to get the data to closed pull requests\r\n - loop through that array to get the data to open pull requests\r\n\r\nExcuse my &quot;noobish&quot; question.\r\nI&#39;m using bash/jq and the GitHub API for the time.\r\n\r\nI&#39;d appreciate any kind of help.\r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/54886306/export-github-commits-names-to-csv-with-bash-jq",
        "title": "export github commits/names to CSV with bash &amp; jq"
    },
    {
        "tags": [
            "json",
            "cmd",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1551195527,
                "last_edit_date": 1551195527,
                "creation_date": 1551190745,
                "answer_id": 54887577,
                "question_id": 54887133,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can try the following `jq` script:\r\n\r\n    &lt;file jq &#39;.bar as $b | .[] |= $b&#39;\r\n\r\nThis assigns the object `bar` to the variable `$b` and replace all elements with this variable.",
                "title": "Easiest way to modify JSON config file"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1551214332,
        "creation_date": 1551189367,
        "last_edit_date": 1551189946,
        "question_id": 54887133,
        "body_markdown": "I&#39;ve got files of different sizes (n entries) such as:\r\n\r\n\r\n&lt;!-- language: lang-js --&gt;\r\n\r\n    {\r\n    \t&quot;FOO&quot;: {\r\n    \t\t&quot;myParameters&quot;: [&quot;first&quot;, &quot;second&quot;, &quot;third&quot;, &quot;forth&quot;, &quot;fifth&quot;]\r\n    \t},\r\n    \t&quot;bar&quot;: {\r\n    \t\t&quot;myParameters&quot;: [&quot;first&quot;, &quot;third&quot;]\r\n    \t},\r\n    \t&quot;BAZQUUX&quot;: {\r\n    \t\t&quot;myParameters&quot;: [&quot;first&quot;, &quot;second&quot;, &quot;third&quot;, &quot;forth&quot;, &quot;fifth&quot;, &quot;sixth&quot;, &quot;seventh&quot;, &quot;eighth&quot;, &quot;ninth&quot;]\r\n    \t}\r\n    }\r\n\r\n\r\nand I&#39;d like to modify it like this:\r\n\r\n\r\n&lt;!-- language: lang-js --&gt;\r\n\r\n    {\r\n    \t&quot;FOO&quot;: {\r\n    \t\t&quot;myParameters&quot;: [&quot;first&quot;, &quot;third&quot;]\r\n    \t},\r\n    \t&quot;bar&quot;: {\r\n    \t\t&quot;myParameters&quot;: [&quot;first&quot;, &quot;third&quot;]\r\n    \t},\r\n    \t&quot;BAZQUUX&quot;: {\r\n    \t\t&quot;myParameters&quot;: [&quot;first&quot;, &quot;third&quot;]\r\n    \t}\r\n    }\r\n\r\n\r\nSo the *bar* object&#39;s property *myParameters* (the array containing two items) should be the template for all remaining objects (*FOO*, *BAZQUUX*, etc.) left, they should adopt the property of *bar*, discarding their existing properties.\r\n\r\nIs there a simple way to achieve this via jq?\r\n\r\nI need it for a batch script.",
        "link": "https://stackoverflow.com/questions/54887133/easiest-way-to-modify-json-config-file",
        "title": "Easiest way to modify JSON config file"
    },
    {
        "tags": [
            "arrays",
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1551256564,
                "creation_date": 1551256564,
                "answer_id": 54901152,
                "question_id": 54900788,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Your filter is looking for tags which has only one value 32.\r\n\r\nThis should do the job:\r\n\r\n    select(.tags | contains([32]) | not)",
                "title": "jq - How to filter out an object with multiple integers"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1551256564,
        "creation_date": 1551255036,
        "question_id": 54900788,
        "body_markdown": "I&#39;m trying to filter out arrays that don&#39;t contain the number &#39;32&#39; but it only filters out those that contain just one integer.\r\n\r\n    {\r\n      &quot;tags&quot;: [\r\n        21\r\n      ]\r\n    }\r\n    {\r\n      &quot;tags&quot;: [\r\n        32\r\n      ]\r\n    }\r\n    {\r\n      &quot;tags&quot;: [\r\n        21,\r\n        32\r\n      ]\r\n    }\r\n\r\nBut upon running:\r\n\r\n    select(.tags[] == 32 | not)\r\nI still get one array containing 32.",
        "link": "https://stackoverflow.com/questions/54900788/jq-how-to-filter-out-an-object-with-multiple-integers",
        "title": "jq - How to filter out an object with multiple integers"
    },
    {
        "tags": [
            "json",
            "select",
            "nested",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1551315676,
                "creation_date": 1551315676,
                "answer_id": 54916824,
                "question_id": 54909977,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "OP back after a few hours - I found something that seems to work, still very interested in any comments / other ways to crack the problem / improvements.\r\n\r\n```\r\n.content.data  \r\n  | .hits[].doc.notes |= map (\r\n    if ( .types | any(startswith(&quot;x&quot;) or startswith(&quot;y&quot;)))\r\n      then .\r\n      else empty\r\n    end \r\n  )\r\n```",
                "title": "pipe in del(... | select(... | ...)) works in v1.6, how to get same result in v1.5?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1551557347,
                "creation_date": 1551557347,
                "answer_id": 54962552,
                "question_id": 54909977,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This is just a variation of the solution proposed by the OP.  It illustrates how a complex use of `del` can be expressed in a more straightforward and robust way by crafting a suitable helper function.\r\n\r\nThe relevant helper function in the present case implements the stripping-out requirement:\r\n\r\n    # Input: an object some keys of which are to be removed\r\n    def prune:\r\n       to_entries\r\n       | map( select( any(.value.types[]; test(&quot;^(x|y)&quot;)) ) )\r\n       | from_entries ;\r\n\r\nThe task can now be accomplished using a one-liner:\r\n\r\n    .content.data | .hits |= map( .doc.notes |= prune )\r\n\r\n##  Invocation\r\n\r\nWith the above jq program in program.jq, a suitable invocation of jq\r\nwould look like this:\r\n\r\n    jq -f program.jq input.json\r\n\r\n",
                "title": "pipe in del(... | select(... | ...)) works in v1.6, how to get same result in v1.5?"
            }
        ],
        "is_answered": false,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1551557347,
        "creation_date": 1551284559,
        "last_edit_date": 1551285988,
        "question_id": 54909977,
        "body_markdown": "I&#39;m trying to remove some objects based on tags within an array.  I can get it working fine on jqplay.org (v1.6) but is there any way to get the same result in v1.5?  I just get an error `Invalid path expression with result`\r\n\r\nThe goal is to return the JSON stripped of the top two (`content` and `data`) levels, and with the properties of `notes` stripped out if there isn&#39;t a `types` tag starting with &#39;x&#39; or &#39;y&#39; for that note.\r\n\r\nHere&#39;s the v1.6 working example: https://jqplay.org/s/AVpz_IkfJa\r\n\r\nThere&#39;s also this: https://github.com/stedolan/jq/issues/1146 but I don&#39;t know how (or if it&#39;s possible) to apply the workaround for `del()` rather than `path()`, assuming it&#39;s the same basic problem.\r\n  \r\n### JQ instructions:\r\n&lt;!-- language: lang-jq --&gt;\r\n\r\n``` \r\n.content.data \r\n  | del(\r\n  .hits[].doc.notes[] \r\n    | select\r\n    ( .types \r\n      | any(startswith(&quot;x&quot;) or startswith(&quot;y&quot;)) \r\n      | not \r\n\t)\r\n  )\r\n```\r\n\r\n### input JSON:\r\n&lt;!-- language: lang-json --&gt;\r\n```\r\n{ \r\n  &quot;content&quot;: { &quot;data&quot;: {\r\n   &quot;meta&quot;: &quot;stuff&quot;,\r\n   &quot;hits&quot;: [\r\n    { &quot;doc&quot;: \r\n      {\r\n        &quot;id&quot;: &quot;10&quot;,\r\n        &quot;notes&quot;: {\r\n         &quot;f1&quot;: {&quot;name&quot;: &quot;F1&quot;, &quot;types&quot;: [&quot;wwwa&quot;, &quot;zzzb&quot;] },\r\n         &quot;f2&quot;: {&quot;name&quot;: &quot;F2&quot;, &quot;types&quot;: [&quot;xxxa&quot;, &quot;yyya&quot;] }\r\n       }\r\n     },\r\n     &quot;score&quot;: &quot;1&quot;\r\n   },\r\n   { &quot;doc&quot;: \r\n    {\r\n      &quot;id&quot;: &quot;11&quot;,\r\n      &quot;notes&quot;: {\r\n       &quot;f1&quot;: {&quot;name&quot;: &quot;F1&quot;, &quot;types&quot;: [&quot;wwwa&quot;, &quot;zzzb&quot;] },\r\n       &quot;f3&quot;: {&quot;name&quot;: &quot;F3&quot;, &quot;types&quot;: [&quot;qzxb&quot;, &quot;xxxb&quot;] }\r\n     }\r\n   },\r\n   &quot;score&quot;: &quot;2&quot;\r\n } ] } } }\t\r\n```\r\n### Desired result:\r\n&lt;!-- language: lang-json --&gt;\r\n```\r\n{\r\n  &quot;meta&quot;: &quot;stuff&quot;,\r\n  &quot;hits&quot;: [\r\n    {\r\n      &quot;doc&quot;: {\r\n        &quot;id&quot;: &quot;10&quot;,\r\n        &quot;notes&quot;: {\r\n          &quot;f2&quot;: {&quot;name&quot;: &quot;F2&quot;, &quot;types&quot;: [&quot;xxxa&quot;, &quot;yyya&quot;] }\r\n        }\r\n      },\r\n      &quot;score&quot;: &quot;1&quot;\r\n    },\r\n    {\r\n      &quot;doc&quot;: {\r\n        &quot;id&quot;: &quot;11&quot;,\r\n        &quot;notes&quot;: {\r\n          &quot;f3&quot;: {&quot;name&quot;: &quot;F3&quot;, &quot;types&quot;: [&quot;qzxb&quot;, &quot;xxxb&quot;] }\r\n        }\r\n      },\r\n      &quot;score&quot;: &quot;2&quot;\r\n} ] }\r\n\r\n```\r\n\r\nAny suggestions greatly appreciated. I&#39;m pretty much a jq novice. Even if it&#39;s not practically do-able in v1.5 at least I won&#39;t lose more hours trying to make it work.  ",
        "link": "https://stackoverflow.com/questions/54909977/pipe-in-del-select-works-in-v1-6-how-to-get-same-result-in-v1",
        "title": "pipe in del(... | select(... | ...)) works in v1.6, how to get same result in v1.5?"
    },
    {
        "tags": [
            "json",
            "bash",
            "timestamp",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1551349047,
                "creation_date": 1551349047,
                "answer_id": 54923265,
                "question_id": 54914675,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "As I understand it, you&#39;re taking those objects as inputs and generating a series of objects with a `timestamp` within the range of `start_time_*` dates for every minute and the `device_id`.\r\n\r\nIf your OS and build supports date functions, you could use this to generate your json.\r\n\r\n    def fromdateiso8601wd:\r\n        # strips fractional seconds\r\n        &quot;\\(.[:-5])Z&quot; | fromdateiso8601;\r\n    [\r\n        (.start_time_first | fromdateiso8601wd),\r\n        (.start_time_last  | fromdateiso8601wd + 60)\r\n    ] as [$s, $e] |\r\n    {\r\n        timestamp: (range($s; $e; 60) | todateiso8601),\r\n        device_id\r\n    }\r\n\r\nWould produce:\r\n\r\n    {\r\n      &quot;timestamp&quot;: &quot;2019-02-24T00:07:25Z&quot;,\r\n      &quot;device_id&quot;: &quot;8160a3f87a977379f12f8826fd3c9c86ca3ca48a&quot;\r\n    }\r\n    {\r\n      &quot;timestamp&quot;: &quot;2019-02-24T00:40:24Z&quot;,\r\n      &quot;device_id&quot;: &quot;181606aabbf155217f59e302541638bfc7e07837&quot;\r\n    }\r\n    {\r\n      &quot;timestamp&quot;: &quot;2019-02-24T00:41:24Z&quot;,\r\n      &quot;device_id&quot;: &quot;181606aabbf155217f59e302541638bfc7e07837&quot;\r\n    }\r\n    {\r\n      &quot;timestamp&quot;: &quot;2019-02-24T00:42:24Z&quot;,\r\n      &quot;device_id&quot;: &quot;181606aabbf155217f59e302541638bfc7e07837&quot;\r\n    }\r\n    {\r\n      &quot;timestamp&quot;: &quot;2019-02-24T00:43:24Z&quot;,\r\n      &quot;device_id&quot;: &quot;181606aabbf155217f59e302541638bfc7e07837&quot;\r\n    }\r\n    {\r\n      &quot;timestamp&quot;: &quot;2019-02-24T00:44:24Z&quot;,\r\n      &quot;device_id&quot;: &quot;181606aabbf155217f59e302541638bfc7e07837&quot;\r\n    }\r\n    {\r\n      &quot;timestamp&quot;: &quot;2019-02-24T00:45:24Z&quot;,\r\n      &quot;device_id&quot;: &quot;181606aabbf155217f59e302541638bfc7e07837&quot;\r\n    }\r\n    {\r\n      &quot;timestamp&quot;: &quot;2019-02-24T00:46:24Z&quot;,\r\n      &quot;device_id&quot;: &quot;181606aabbf155217f59e302541638bfc7e07837&quot;\r\n    }\r\n    {\r\n      &quot;timestamp&quot;: &quot;2019-02-24T00:47:24Z&quot;,\r\n      &quot;device_id&quot;: &quot;181606aabbf155217f59e302541638bfc7e07837&quot;\r\n    }\r\n    {\r\n      &quot;timestamp&quot;: &quot;2019-02-24T00:48:24Z&quot;,\r\n      &quot;device_id&quot;: &quot;181606aabbf155217f59e302541638bfc7e07837&quot;\r\n    }\r\n    {\r\n      &quot;timestamp&quot;: &quot;2019-02-24T00:49:24Z&quot;,\r\n      &quot;device_id&quot;: &quot;181606aabbf155217f59e302541638bfc7e07837&quot;\r\n    }\r\n    {\r\n      &quot;timestamp&quot;: &quot;2019-02-23T21:56:06Z&quot;,\r\n      &quot;device_id&quot;: &quot;1b62573cdfdab3902b72ec9e4797c422271f2efd&quot;\r\n    }\r\n    {\r\n      &quot;timestamp&quot;: &quot;2019-02-23T21:57:06Z&quot;,\r\n      &quot;device_id&quot;: &quot;1b62573cdfdab3902b72ec9e4797c422271f2efd&quot;\r\n    }\r\n    {\r\n      &quot;timestamp&quot;: &quot;2019-02-23T21:58:06Z&quot;,\r\n      &quot;device_id&quot;: &quot;1b62573cdfdab3902b72ec9e4797c422271f2efd&quot;\r\n    }",
                "title": "Generate timestamp by minutes and calculate sum of uniques by every minutes"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1551443378,
                "last_edit_date": 1551443378,
                "creation_date": 1551442521,
                "answer_id": 54944486,
                "question_id": 54914675,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "As I understand it, you want (for each &quot;minute&quot;) a count of the number of active devices. Here is a solution that assumes that the input specifies non-overlapping intervals for each &quot;device_id&quot;:\r\n\r\n    def seconds:\r\n        # strips fractional seconds\r\n        &quot;\\(.[:-5])Z&quot; | fromdateiso8601;\r\n    \r\n    def record($s; $e):\r\n      reduce range($s | round; $e + 1) as $i (.; .[$i|todate] += 1);\r\n    \r\n    reduce inputs as $in ({}; record( ($in | .start_time_first | seconds / 60); ($in | .start_time_last | seconds / 60)))\r\n\r\n\r\n# Invocation\r\nAn appropriate invocation would look like this:\r\n\r\n    jq -n -f program.jq input.ndjson\r\n\r\n  \r\n",
                "title": "Generate timestamp by minutes and calculate sum of uniques by every minutes"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1551469559,
        "creation_date": 1551302392,
        "last_edit_date": 1551469559,
        "question_id": 54914675,
        "body_markdown": "I have an ndjson like this \r\n\r\n    {&quot;start_time_last&quot;:&quot;2019-02-24T00:07:25.875Z&quot;,&quot;start_time_first&quot;:&quot;2019-02-24T00:07:25.875Z&quot;,&quot;device_id&quot;:&quot;8160a3f87a977379f12f8826fd3c9c86ca3ca48a&quot;}\r\n    {&quot;start_time_last&quot;:&quot;2019-02-24T00:48:56.100Z&quot;,&quot;start_time_first&quot;:&quot;2019-02-24T00:40:24.464Z&quot;,&quot;device_id&quot;:&quot;181606aabbf155217f59e302541638bfc7e07837&quot;}\r\n    {&quot;start_time_last&quot;:&quot;2019-02-23T21:57:36.024Z&quot;,&quot;start_time_first&quot;:&quot;2019-02-23T21:56:06.741Z&quot;,&quot;device_id&quot;:&quot;1b62573cdfdab3902b72ec9e4797c422271f2efd&quot;}\r\n\r\nAs you see each record shows an active period of a device, my question is if I want to generate a ndjson, which have two fields. One is &quot;timestamp&quot; which go through 2019-02-23T00:00, 2019-02-23T00:01, ..., 2019-02-24T23:59 (timestamps by minutes) and count the uniques of distinct device_id that is active by every timestamps.\r\n\r\nFor example, for the first record, it starts from 2019-02-24T00:07:25.875Z and end at 2019-02-24T00:07:25.875Z. This device id should be counted in timestamps:\r\n\r\n    2019-02-24T00:07\r\n\r\nAs it only appears in this minute. For second record, it should be counted in these timestamps \r\n\r\n    2019-02-24T00:40,\r\n    2019-02-24T00:41,\r\n    2019-02-24T00:42,\r\n    2019-02-24T00:43,\r\n    2019-02-24T00:44,\r\n    2019-02-24T00:45,\r\n    2019-02-24T00:46,\r\n    2019-02-24T00:47,\r\n    2019-02-24T00:48\r\n\r\nHow to realize this using jq? Or whatever command in Bash?\r\n",
        "link": "https://stackoverflow.com/questions/54914675/generate-timestamp-by-minutes-and-calculate-sum-of-uniques-by-every-minutes",
        "title": "Generate timestamp by minutes and calculate sum of uniques by every minutes"
    },
    {
        "tags": [
            "arrays",
            "json",
            "join",
            "merge",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 137273,
                    "reputation": 4396,
                    "user_id": 1236045,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b72f10b46a0597b7640906dde9db5bb5?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Michał Politowski",
                    "link": "https://stackoverflow.com/users/1236045/micha%c5%82-politowski"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1551514553,
                "post_id": 54925675,
                "comment_id": 96675046,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1551441319,
                "last_edit_date": 1551441319,
                "creation_date": 1551365697,
                "answer_id": 54928432,
                "question_id": 54925675,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use the `--slurp` option to read both files into one array, and from there it&#39;s relatively simple to loop over the keys of one of the arrays and add the corresponding elements of both arrays together.\r\n\r\n    jq --slurp &#39;\r\n    {\r\n      combined: [\r\n        .[0].input as $is|\r\n        .[1].result as $rs|\r\n        range(0; $is|length) as $n|\r\n        $is[$n]+$rs[$n]\r\n      ]\r\n    }\r\n    &#39; file1.json file2.json\r\n",
                "title": "combine array of objects from two files with jq under specific key 1.4"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1551385150,
                "creation_date": 1551385150,
                "answer_id": 54933615,
                "question_id": 54925675,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If more recent versions of jq were available to you, you could take advantage of the `transpose` function to combine them rather easily:\r\n\r\n    $ jq -n &#39;{ combined: ([inputs[]] | transpose | map(add)) }&#39; input1.json input2.json\r\n\r\nHowever, since you are limited to 1.4, your options are bit limited. When working with multiple files, it&#39;s useful to have all the inputs read into memory. `--slurp` allows you to do this reading all inputs in as an array. You will have to zip the inputs together differently however.\r\n\r\n    $ jq --slurp &#39;add | reduce range(0; .input | length) as $i (.;\r\n        .combined += [.input[$i] + .result[$i]]\r\n    ) | {combined}&#39; input1.json input2.json",
                "title": "combine array of objects from two files with jq under specific key 1.4"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1575808256,
        "creation_date": 1551356612,
        "last_edit_date": 1575808256,
        "question_id": 54925675,
        "body_markdown": "I have two files with the following JSON that I need to combine using the relative array position of each object:\r\n\r\nPS: - I am restricted to version 1.4 as am on Solaris so don&#39;t have the [inputs] feature \r\n\r\nFile 1\r\n\r\n    {\r\n      &quot;input&quot;: [\r\n        {\r\n          &quot;email&quot;: &quot;test1@gm.com&quot;,\r\n          &quot;firstName&quot;: &quot;Fred&quot;\r\n        },\r\n        {\r\n          &quot;email&quot;: &quot;someone@gm.com&quot;,\r\n          &quot;firstName&quot;: &quot;James&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\nFile 2:\r\n\r\n    {\r\n      &quot;result&quot;: [\r\n        {\r\n          &quot;id&quot;: 50,\r\n          &quot;status&quot;: &quot;created&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 51,\r\n          &quot;status&quot;: &quot;rejected&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\nthe expected result is the elements of input[1] combined with elements of result[1] and so on as follows:\r\n\r\n    {\r\n      &quot;combined&quot;: [\r\n        {\r\n          &quot;email&quot;: &quot;test1@gm.com&quot;,\r\n          &quot;firstName&quot;: &quot;Fred&quot;,\r\n          &quot;id&quot;: 50,\r\n          &quot;status&quot;: &quot;created&quot;\r\n        },\r\n        {\r\n          &quot;email&quot;: &quot;someone@gm.com&quot;,\r\n          &quot;firstName&quot;: &quot;James&quot;,\r\n          &quot;id&quot;: 51,\r\n          &quot;status&quot;: &quot;rejected&quot;\r\n        }\r\n      ]\r\n    }\r\n",
        "link": "https://stackoverflow.com/questions/54925675/combine-array-of-objects-from-two-files-with-jq-under-specific-key-1-4",
        "title": "combine array of objects from two files with jq under specific key 1.4"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1551371439,
                "creation_date": 1551371439,
                "answer_id": 54930235,
                "question_id": 54929491,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use `reduce` with `inputs`:\r\n\r\n    jq -n &#39;{ widgets : (reduce inputs as $p ({}; . + ($p | { (.name) : { url } }))) }&#39; file",
                "title": "Combine and rekey multiple objects in jq"
            },
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1551372002,
                "last_edit_date": 1551372002,
                "creation_date": 1551371609,
                "answer_id": 54930299,
                "question_id": 54929491,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I&#39;d do it like [this][1]:\r\n\r\n    jq -s &#39;{ widgets: map( { (.name): {url} } ) | add }&#39;\r\n\r\n- `-s` (`--slurp`) combines the objects to an array of objects\r\n- `map( { (.name): { url } } )` reshapes each object\r\n- `add` concatenates the array elements into a single object\r\n- and finally, I build an object with `{ widgets: ... }`.\r\n\r\n\r\n  [1]: https://jqplay.org/s/qlxyTJd3lv",
                "title": "Combine and rekey multiple objects in jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 3,
        "last_activity_date": 1551372002,
        "creation_date": 1551368943,
        "last_edit_date": 1551371829,
        "question_id": 54929491,
        "body_markdown": "I&#39;m starting with a JSON file that has multiple objects\r\n\r\n```json\r\n{\r\n  &quot;name&quot;: &quot;foo&quot;,\r\n  &quot;url&quot;: &quot;https://zombo.com&quot;\r\n}\r\n{\r\n  &quot;name&quot;: &quot;bar&quot;,\r\n  &quot;url&quot;: &quot;https://acme.com&quot;\r\n}\r\n```\r\n\r\nand I&#39;m trying to combine those into a single object with the `name` attribute as the key:\r\n\r\n```json\r\n{\r\n  &quot;widgets&quot;: {\r\n    &quot;foo&quot;: {\r\n      &quot;url&quot;: &quot;https://zombo.com&quot;\r\n    },\r\n    &quot;bar&quot;: {\r\n      &quot;url&quot;: &quot;https://acme.com&quot;\r\n    }\r\n  }\r\n}\r\n```\r\n\r\nI&#39;ve been banging my head against this for a while and I think I&#39;m fairly close with the following query:\r\n```\r\n{ widgets: (reduce . as $item ({}; . + {($item.name): {url: $item.url}})) }\r\n```\r\n\r\nHowever, this results in multiple objects and I&#39;m running out of ideas.\r\n\r\njqplay available here: https://jqplay.org/s/SI7XEMb5l9.",
        "link": "https://stackoverflow.com/questions/54929491/combine-and-rekey-multiple-objects-in-jq",
        "title": "Combine and rekey multiple objects in jq"
    },
    {
        "tags": [
            "json",
            "csv",
            "jq",
            "jsonlines"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1551381160,
                "creation_date": 1551381160,
                "answer_id": 54932699,
                "question_id": 54932167,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Ok, you want to scan the list of officers, extract some fields from there if they are present and write that in csv format.\r\n\r\nFirst part is to extract the data from the json. Assuming you loaded it is a `data` Python object, you have:\r\n\r\n    print(data[&#39;items&#39;][0][&#39;officer_role&#39;], data[&#39;items&#39;][0][&#39;appointed_on&#39;],\r\n          data[&#39;items&#39;][0][&#39;country_of_residence&#39;])\r\n\r\ngives:\r\n\r\n    llp-designated-member 2017-09-15 England\r\n\r\nTime to put everything together with the csv module:\r\n\r\n    import csv\r\n    ...\r\n    with open(&#39;output.csv&#39;, &#39;w&#39;, newline=&#39;&#39;) as fd:\r\n    \twr = csv.writer(fd)\r\n    \tfor officer in data[&#39;items&#39;]:\r\n    \t\t_ = wr.writerow((&#39;OC418979&#39;,\r\n    \t\t\t     officer.get(&#39;country_of_residence&#39;,&#39;&#39;),\r\n    \t\t\t     officer.get(&#39;officer_role&#39;, &#39;&#39;),\r\n    \t\t\t     officer.get(&#39;appointed_on&#39;, &#39;&#39;)\r\n    \t\t\t     ))\r\n\r\nThe `get` method on a dictionnary allows to use a default value (here the empty string) if the key is not present, and the `csv` module ensures that if a field contains a comma, it will be enclosed in quotation marks.\r\n\r\nWith your example input, it gives:\r\n\r\n    OC418979,England,llp-designated-member,2017-09-15\r\n    OC418979,,corporate-llp-designated-member,2017-09-15",
                "title": "reshape jq nested file and make csv"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1551437823,
                "last_edit_date": 1551437823,
                "creation_date": 1551388098,
                "answer_id": 54934292,
                "question_id": 54932167,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using jq, it&#39;s easier to extract values from the top-level object that will be shared and generate the desired rows. You&#39;ll want to limit the amounts of times you go through the items to at most once.\r\n\r\n    $ jq -r &#39;(.links.self | split(&quot;/&quot;)[2]) as $companyCode \r\n       | .items[]\r\n       | [ $companyCode, .country_of_residence, .officer_role, .appointed_on ]\r\n       | @csv\r\n    &#39; input.json",
                "title": "reshape jq nested file and make csv"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1551437823,
        "creation_date": 1551378967,
        "last_edit_date": 1551379899,
        "question_id": 54932167,
        "body_markdown": "I&#39;ve been struggling with this one for the whole day which i want to turn to a csv. \r\n\r\nIt represents the officers attached to company whose number is &quot;OC418979&quot; in the UK Company House API.\r\n\r\nI&#39;ve already truncated the json to contain just 2 objects inside &quot;items&quot;. \r\n\r\nWhat I would like to get is a csv like this\r\n\r\n    OC418979, country_of_residence, officer_role, appointed_on\r\n    OC418979, country_of_residence, officer_role, appointed_on\r\n    OC418979, country_of_residence, officer_role, appointed_on\r\n    OC418979, country_of_residence, officer_role, appointed_on\r\n    ...\r\n\r\nThere are 2 extra complication: there are 2 types of &quot;officers&quot;, some are people, some are companies, so not all key in people are present in the other and viceversa. I&#39;d like these entries to be &#39;null&#39;. Second complication is those nested objects like &quot;name&quot; which contains a comma in it! or address, which contains several sub-objects (which I guess I could flatten in pandas tho). \r\n\r\n    {\r\n      &quot;total_results&quot;: 13,\r\n      &quot;resigned_count&quot;: 9,\r\n      &quot;links&quot;: {\r\n        &quot;self&quot;: &quot;/company/OC418979/officers&quot;\r\n      },\r\n      &quot;items_per_page&quot;: 35,\r\n      &quot;etag&quot;: &quot;bc7955679916b089445c9dfb4bc597aa0daaf17d&quot;,\r\n      &quot;kind&quot;: &quot;officer-list&quot;,\r\n      &quot;active_count&quot;: 4,\r\n      &quot;inactive_count&quot;: 0,\r\n      &quot;start_index&quot;: 0,\r\n      &quot;items&quot;: [\r\n        {\r\n          &quot;officer_role&quot;: &quot;llp-designated-member&quot;,\r\n          &quot;name&quot;: &quot;BARRICK, David James&quot;,\r\n          &quot;date_of_birth&quot;: {\r\n            &quot;year&quot;: 1984,\r\n            &quot;month&quot;: 1\r\n          },\r\n          &quot;appointed_on&quot;: &quot;2017-09-15&quot;,\r\n          &quot;country_of_residence&quot;: &quot;England&quot;,\r\n          &quot;address&quot;: {\r\n            &quot;country&quot;: &quot;United Kingdom&quot;,\r\n            &quot;address_line_1&quot;: &quot;Old Gloucester Street&quot;,\r\n            &quot;locality&quot;: &quot;London&quot;,\r\n            &quot;premises&quot;: &quot;27&quot;,\r\n            &quot;postal_code&quot;: &quot;WC1N 3AX&quot;\r\n          },\r\n          &quot;links&quot;: {\r\n            &quot;officer&quot;: {\r\n              &quot;appointments&quot;: &quot;/officers/d_PT9xVxze6rpzYwkN_6b7og9-k/appointments&quot;\r\n            }\r\n          }\r\n        },\r\n        {\r\n          &quot;links&quot;: {\r\n            &quot;officer&quot;: {\r\n              &quot;appointments&quot;: &quot;/officers/M2Ndc7ZjpyrjzCXdFZyFsykJn-U/appointments&quot;\r\n            }\r\n          },\r\n          &quot;address&quot;: {\r\n            &quot;locality&quot;: &quot;Tadcaster&quot;,\r\n            &quot;country&quot;: &quot;United Kingdom&quot;,\r\n            &quot;address_line_1&quot;: &quot;Westgate&quot;,\r\n            &quot;postal_code&quot;: &quot;LS24 9AB&quot;,\r\n            &quot;premises&quot;: &quot;5a&quot;\r\n          },\r\n          &quot;identification&quot;: {\r\n            &quot;legal_authority&quot;: &quot;UK&quot;,\r\n            &quot;identification_type&quot;: &quot;non-eea&quot;,\r\n            &quot;legal_form&quot;: &quot;UK&quot;\r\n          },\r\n          &quot;name&quot;: &quot;PREMIER DRIVER LIMITED&quot;,\r\n          &quot;officer_role&quot;: &quot;corporate-llp-designated-member&quot;,\r\n          &quot;appointed_on&quot;: &quot;2017-09-15&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\nWhat I&#39;ve been doing is creating new json objects extracting the fields I needed like this:\r\n\r\n    {officer_address:.items[]?.address, appointed_on:.items[]?.appointed_on, country_of_residence:.items[]?.country_of_residence, officer_role:.items[]?.officer_role, officer_dob:items.date_of_birth, officer_nationality:.items[]?.nationality, officer_occupation:.items[]?.occupation}\r\n\r\nBut the query runs for hours - and I am sure there is a quicker way. \r\n\r\nRight now I am trying this new approach - creating a json whose root is the company number and as argument a list of its officers. \r\n\r\n    {(.links.self | split(&quot;/&quot;)[2]): .items[]}\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/54932167/reshape-jq-nested-file-and-make-csv",
        "title": "reshape jq nested file and make csv"
    },
    {
        "tags": [
            "json",
            "bash",
            "unix",
            "awk",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 4663062,
                    "reputation": 89888,
                    "user_id": 3776858,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Cagbk.jpg?s=256",
                    "display_name": "Cyrus",
                    "link": "https://stackoverflow.com/users/3776858/cyrus"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1551385436,
                "post_id": 54933502,
                "comment_id": 96631807,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 10015983,
                    "reputation": 144648,
                    "user_id": 9072753,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/EPmGy.jpg?s=256",
                    "display_name": "KamilCuk",
                    "link": "https://stackoverflow.com/users/9072753/kamilcuk"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1551386051,
                "post_id": 54933502,
                "comment_id": 96632151,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1551387547,
                "post_id": 54933502,
                "comment_id": 96632762,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1551387662,
                "post_id": 54933502,
                "comment_id": 96632811,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1551387065,
                "creation_date": 1551387065,
                "answer_id": 54934061,
                "question_id": 54933502,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If the files are tab delimited, you could read the file in raw, split on the tabs, parse and extract the json, then rejoin on tabs.\r\n\r\n    $ jq -Rr &#39;split(&quot;\\t&quot;) | .[1] |= fromjson.catId | join(&quot;\\t&quot;)&#39; input.log",
                "title": "Get JSON value from column"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1551388322,
                "creation_date": 1551388322,
                "answer_id": 54934328,
                "question_id": 54933502,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Just adding why your code didn&#39;t work as the previous answers are better. In your case `$2` was being interpreted as multiple arguments by `jq` as `$2` contains spaces.\r\n\r\nSo, in the below code `$2` is put within hex values single-quotes `\\x27` and then double-quotes.\r\nAlso a little bit of formatting to keep the output in the same line.\r\n\r\n`awk -F &#39;\\t&#39; &#39;{printf &quot;%s\\t&quot;, $1;system(&quot;jq .catId &lt;&lt;&lt; \\x27&quot;$2&quot;\\x27&quot;)}&#39; file`\r\n\r\nOutput:\r\n\r\n    2019-02-28T19:43:48.585Z        42\r\n    2019-02-28T19:44:48.585Z        999\r\n    2019-02-28T19:44:48.585Z        42\r\n    2019-02-28T19:46:48.585Z        765\r\n\r\n",
                "title": "Get JSON value from column"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1551389364,
                "creation_date": 1551389364,
                "answer_id": 54934570,
                "question_id": 54933502,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "in bash:\r\n\r\n    while IFS=$&#39;\\t&#39; read -r timestamp json; do\r\n        printf &#39;%s\\t%s\\n&#39; &quot;$timestamp&quot; &quot;$(jq -r .catId &lt;&lt;&lt;&quot;$json&quot;)&quot;\r\n    done &lt; file\r\n\r\n\r\nthis will be much slower than the jq oneliner.",
                "title": "Get JSON value from column"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1551397677,
                "creation_date": 1551397677,
                "answer_id": 54936017,
                "question_id": 54933502,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "    awk &#39;{sub(/,/,&quot;&quot;,$5);print $1&quot;\\t&quot;$5}&#39; file\r\n    \r\n    2019-02-28T19:43:48.585Z\t42\r\n    2019-02-28T19:44:48.585Z\t999\r\n    2019-02-28T19:44:48.585Z\t42\r\n    2019-02-28T19:46:48.585Z\t765",
                "title": "Get JSON value from column"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1551433117,
                "creation_date": 1551433117,
                "answer_id": 54941806,
                "question_id": 54933502,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using Perl\r\n\r\n    perl -lanE &#39; $x=$_=~s/(^.*catId&quot;:\\s*)(\\d+).*$/$2/gr; print &quot;$F[0]\\t$x&quot; &#39;\r\n\r\nwith the given inputs\r\n\r\n    $ cat test.log\r\n    2019-02-28T19:43:48.585Z        {&quot;id&quot;: 1234, &quot;catId&quot;: 42, &quot;img&quot;: &quot;other.jpg&quot;}\r\n    2019-02-28T19:44:48.585Z        {&quot;id&quot;: 4321, &quot;catId&quot;: 999, &quot;img&quot;: &quot;my.jpg&quot;}\r\n    2019-02-28T19:44:48.585Z        {&quot;id&quot;: 1234, &quot;catId&quot;: 42, &quot;img&quot;: &quot;new.jpg&quot;}\r\n    2019-02-28T19:46:48.585Z        {&quot;id&quot;: 1234, &quot;catId&quot;: 765, &quot;img&quot;: &quot;cat.jpg&quot;}\r\n    \r\n    $  perl -lanE &#39; $x=$_=~s/(^.*catId&quot;:\\s*)(\\d+).*$/$2/gr; print &quot;$F[0]\\t$x&quot; &#39; test.log\r\n    2019-02-28T19:43:48.585Z        42\r\n    2019-02-28T19:44:48.585Z        999\r\n    2019-02-28T19:44:48.585Z        42\r\n    2019-02-28T19:46:48.585Z        765\r\n    \r\n    $\r\n\r\n",
                "title": "Get JSON value from column"
            }
        ],
        "is_answered": true,
        "answer_count": 5,
        "score": 3,
        "last_activity_date": 1551433117,
        "creation_date": 1551384599,
        "last_edit_date": 1551385400,
        "question_id": 54933502,
        "body_markdown": "I have a bunch of two column logs which are separated by tabs. The second column is valid JSON:\r\n```\r\n2019-02-28T19:43:48.585Z        {&quot;id&quot;: 1234, &quot;catId&quot;: 42, &quot;img&quot;: &quot;other.jpg&quot;}\r\n2019-02-28T19:44:48.585Z        {&quot;id&quot;: 4321, &quot;catId&quot;: 999, &quot;img&quot;: &quot;my.jpg&quot;}\r\n2019-02-28T19:44:48.585Z        {&quot;id&quot;: 1234, &quot;catId&quot;: 42, &quot;img&quot;: &quot;new.jpg&quot;}\r\n2019-02-28T19:46:48.585Z        {&quot;id&quot;: 1234, &quot;catId&quot;: 765, &quot;img&quot;: &quot;cat.jpg&quot;}\r\n```\r\n\r\nMy aim to to retain the timestamp column, and print the `catId` property:\r\n```\r\n2019-02-28T19:43:48.585Z        42\r\n2019-02-28T19:44:48.585Z        999\r\n2019-02-28T19:44:48.585Z        42\r\n2019-02-28T19:46:48.585Z        765\r\n```\r\n\r\nMy attempt so far has been to plug `jq` with `awk`, but I am struggling with the `system` command.\r\n```bash\r\nawk -F &#39;\\t&#39; &#39;{printf &quot;\\n %s \\t %s \\n&quot;, $1, system(&quot;jq .catId &lt;&lt;&lt; &quot; $2)}&#39; file\r\n```\r\n\r\nAny help in the right direction will be much appreciated.\r\n",
        "link": "https://stackoverflow.com/questions/54933502/get-json-value-from-column",
        "title": "Get JSON value from column"
    },
    {
        "tags": [
            "json",
            "csv",
            "multidimensional-array",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 52839,
                    "reputation": 99133,
                    "user_id": 157957,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/MBRE7.jpg?s=256",
                    "display_name": "IMSoP",
                    "link": "https://stackoverflow.com/users/157957/imsop"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1551439598,
                "post_id": 54943615,
                "comment_id": 96649975,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1551445074,
                "last_edit_date": 1551445074,
                "creation_date": 1551441008,
                "answer_id": 54944089,
                "question_id": 54943615,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Since you want a rectangular result, you will have to &quot;pad&quot; the &quot;natures_of_control&quot; array.  Based on the sample input, you will need to &quot;slurp&quot; the input in order to obtain a global maximum.\r\n\r\nTo pad the array, you could use the helper function:\r\n\r\n    # emit a stream of exactly $n items\r\n    def pad($n): range(0;$n) as $i | .[$i];\r\n\r\nThe solution to the problem as posted on jqplay then becomes:\r\n\r\n    ([.[] | .items[] | .natures_of_control | length] | max) as $mx\r\n    | .[]\r\n    | (.active_count) as $active_count\r\n    | (.ceased_count) as $ceased_count\r\n    | (.links.self | split(&quot;/&quot;)[2]) as $companyCode\r\n    | .items[]\r\n    | [$companyCode, $active_count, $ceased_count, .name, .country_of_residence, .nationality, .notified_on, (.natures_of_control | pad($mx))]\r\n    | @csv\r\n\r\n### Invocation\r\nThe appropriate invocation would look like this:\r\n\r\n    jq -sr -f program.jq input.json\r\n\r\n## Handling missing data\r\n\r\nTo ignore objects that have no &quot;items&quot; you could tweak the above, e.g. as follows:\r\n\r\n    ([.[] | .items[]? | .natures_of_control | length] | max) as $mx\r\n     | .[]\r\n     | select(.items)\r\n     | (.active_count) as $active_count\r\n     | (.ceased_count) as $ceased_count\r\n     | (.links.self | split(&quot;/&quot;)[2]) as $companyCode\r\n     | .items[]\r\n     | [$companyCode, $active_count, $ceased_count, .name, .country_of_residence, .nationality, .notified_on, (.natures_of_control | pad($mx))]\r\n     | @csv\r\n\r\n\r\n",
                "title": "Pad JSON array with JQ to obtain rectangular result"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1551445074,
        "creation_date": 1551439294,
        "last_edit_date": 1551444259,
        "question_id": 54943615,
        "body_markdown": "I have json that looks like [this][1]  (jq play in the link), and I want to build csv in the end looking like this (reproducible sample at the bottom). \r\n\r\n    &quot;SO302993&quot;,items1,item2,item3.1,item3.2,item3.3, item3.4,...\r\n    &quot;SO302994&quot;,items1,item2,item3.1,item3.2,       ,        ,...\r\n    &quot;SO302995&quot;,items1,item2,item3.1,item3.2,item3.3,        ,...\r\n\r\nitem3 elements are in an array and my current solution:\r\n\r\n    .[] | [.number, .item1, item2, item3[]?]\r\n\r\ngives me this:\r\n\r\n    &quot;SO302993&quot;,items1,item2,item3.1,item3.2,item3.3, item3.4,...\r\n    &quot;SO302994&quot;,items1,item2,item3.1,item3.2,...\r\n    &quot;SO302995&quot;,items1,item2,item3.1,item3.2,item3.3,...\r\n\r\nwhich will create an uneven number of columns in the csv. \r\n\r\nI tried adding `.item3[:]?` in a Python flavor-style, but it didn&#39;t work. \r\n\r\nAny help would be much appreciated! And if I wasn&#39;t clear do ask to clarify! My snippet and toy data are in the link above. \r\n\r\n\r\n  [1]: https://jqplay.org/s/xVtQsILfhr\r\n\r\n    {\r\n      &quot;items&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;Mr Simon Mackin&quot;,\r\n          &quot;country_of_residence&quot;: &quot;Scotland&quot;,\r\n          &quot;natures_of_control&quot;: [\r\n            &quot;voting-rights-25-to-50-percent-limited-liability-partnership&quot;,\r\n            &quot;significant-influence-or-control-limited-liability-partnership&quot;\r\n          ],\r\n          &quot;premises&quot;: &quot;4&quot;\r\n        }\r\n      ]\r\n    }\r\n    {\r\n      &quot;items&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;Mrs Simonne Mackinni&quot;,\r\n          &quot;country_of_residence&quot;: &quot;France&quot;,\r\n          &quot;natures_of_control&quot;: [\r\n            &quot;significant-influence-or-control-limited-liability-partnership&quot;\r\n          ],\r\n          &quot;premises&quot;: &quot;4&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\nwith this query:\r\n\r\n    .items[] | [.name, .country_of_residence, .natures_of_control[]?, .premises] | @csv\r\n\r\nI get this results\r\n\r\n    &quot;Mr Simon Mackin&quot;,&quot;Scotland&quot;,&quot;voting-rights&quot;,&quot;significant-influence&quot;,&quot;4&quot;\r\n    &quot;Mrs Simonne Mackinni&quot;,&quot;France&quot;,&quot;significant-influence&quot;,&quot;4&quot;\r\n\r\nBut I&#39;d like to get this (second line has extra comma after &quot;significant-influence). \r\n\r\n    &quot;Mr Simon Mackin&quot;,&quot;Scotland&quot;,&quot;voting-rights&quot;,&quot;significant-influence&quot;,&quot;4&quot;\r\n    &quot;Mrs Simonne Mackinni&quot;,&quot;France&quot;,&quot;significant-influence&quot;,,&quot;4&quot;\r\n\r\n",
        "link": "https://stackoverflow.com/questions/54943615/pad-json-array-with-jq-to-obtain-rectangular-result",
        "title": "Pad JSON array with JQ to obtain rectangular result"
    },
    {
        "tags": [
            "json",
            "bash",
            "pipe",
            "immutability",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1551455690,
                "last_edit_date": 1551455690,
                "creation_date": 1551453958,
                "answer_id": 54947619,
                "question_id": 54947468,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "What about using `sponge` along with `jq` like this:\r\n\r\n```\r\njq &#39;.env_production.abc = &quot;123&quot;&#39; pm2.json | sponge pm2.json\r\n```\r\nThe above command will append `abc: &quot;123&quot;` to `env_production` key and the output (the full json object) will be passed to `sponge` in order to update the file\r\n\r\n&gt;`sponge` is a part of [moreutils](https://joeyh.name/code/moreutils/) package\r\n\r\n`sponge` has an advantage over shell redirection according to it&#39;s description in man pages:\r\n&gt;sponge reads standard input and writes it out to the specified file. Unlike a shell redirect, sponge soaks up all its input before opening the output file. This allows constricting pipelines that read from and write to the same file. ",
                "title": "jq - Add field to child, print parent"
            },
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1551456306,
                "last_edit_date": 1551456306,
                "creation_date": 1551454198,
                "answer_id": 54947697,
                "question_id": 54947468,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The best tool to use here is an updating addition operator, `+=`\r\n\r\n    &lt; pm2.json jq &#39;.env_production += {&quot;abc&quot;: &quot;123&quot;}&#39;\r\n\r\nwill output\r\n\r\n    {\r\n      &quot;name&quot;: &quot;api&quot;,\r\n      &quot;script&quot;: &quot;index.js&quot;,\r\n      &quot;instances&quot;: &quot;1&quot;,\r\n      &quot;env&quot;: {\r\n        &quot;PORT&quot;: 3000\r\n      },\r\n      &quot;env_production&quot;: {\r\n        &quot;PORT&quot;: 3000,\r\n        &quot;abc&quot;: &quot;123&quot;\r\n      }\r\n    }\r\n\r\nIt works out to something similar to \r\n\r\n    . + {&quot;env_production&quot;: (.env_production + {&quot;abc&quot;:&quot;123&quot;})}\r\n\r\nexcept of course it&#39;s far simpler :)",
                "title": "jq - Add field to child, print parent"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1551456306,
        "creation_date": 1551453489,
        "question_id": 54947468,
        "body_markdown": "Problem: from a json file, read it up from disk and add a field to a child object and print it back to disk. \r\n\r\nFile: \r\n\r\n    {\r\n      &quot;name&quot;: &quot;api&quot;,\r\n      &quot;script&quot;: &quot;index.js&quot;,\r\n      &quot;instances&quot;: &quot;1&quot;,\r\n      &quot;env&quot;: {\r\n        &quot;PORT&quot;: 3000\r\n      },\r\n      &quot;env_production&quot;: {\r\n        &quot;PORT&quot;: 3000\r\n      }\r\n    }\r\n\r\nSo i&#39;ve managed to pipe it and add the field: \r\n\r\n    cat pm2.json | jq --arg key val &#39;. as $parent | .env_production + {&quot;abc&quot;: &quot;123&quot;}&#39;\r\n\r\nWhich returns the child object with the field added. However, I need to update the file on disk. So I also need to print the whole object (the parent). \r\n\r\nI can do that by printing it the `$parent` variable. But I cannot get it to work since it is immutable. \r\n\r\n    cat pm2.json | jq --arg key val &#39;. as $parent | .env_production + {&quot;abc&quot;: &quot;123&quot;}| $parent&#39;\r\n\r\n\r\nQuestion: how can I do this so that the `$parent` variable have the new added field, so that I can pipe it back to the original file?",
        "link": "https://stackoverflow.com/questions/54947468/jq-add-field-to-child-print-parent",
        "title": "jq - Add field to child, print parent"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq",
            "wp-cli"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 11829413,
                    "reputation": 15849,
                    "user_id": 8656552,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/BP640.png?s=256",
                    "display_name": "Paul Hodges",
                    "link": "https://stackoverflow.com/users/8656552/paul-hodges"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1551478347,
                "post_id": 54952736,
                "comment_id": 96668581,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 7,
                "is_accepted": false,
                "score": 7,
                "last_activity_date": 1551478268,
                "creation_date": 1551478268,
                "answer_id": 54952984,
                "question_id": 54952736,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use a `while` to read entire lines, rather than iterating over the *words* resulting from the command substitution.\r\n\r\n    while IFS= read -r obj; do\r\n        ...\r\n    done &lt; &lt;(jq -c &#39;.[]&#39; posts.json)",
                "title": "How to iterate a JSON array in bash from jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1551516850,
                "last_edit_date": 1551516850,
                "creation_date": 1551516289,
                "answer_id": 54956719,
                "question_id": 54952736,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Maybe this would work for you:\r\n\r\nMake a bash executable, maybe call it `wpfunction.sh`\r\n\r\n    #!/bin/bash\r\n    \r\n    wp post create \\\r\n      --post_type=&quot;$1&quot;\\\r\n      --post_title=&quot;$2&quot; \\\r\n      --post_content=&quot;$3&quot; \\\r\n      --post_status=&quot;$4&quot;\r\n\r\nThen run `jq` on your `posts.json` and pipe it into `xargs`\r\n\r\n    jq -M -c &#39;.[] | [.post_type, .post_title, .post_content, .post_status][]&#39; \\\r\n    posts.json | xargs -n4 ./wpfunction`\r\n\r\nI am experimenting to see how this would handle post_content that contained quotes...",
                "title": "How to iterate a JSON array in bash from jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1551518253,
                "creation_date": 1551518253,
                "answer_id": 54956969,
                "question_id": 54952736,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "First generate an array of the arguments you wish to pass then convert to a shell compatible form using `@sh`. Then you could pass to xargs to invoke the command.\r\n\r\n    $ jq -r &#39;.[] | [&quot;post&quot;, &quot;create&quot;, (to_entries[] | &quot;--\\(.key)=\\(.value|tojson)&quot;)] | @sh&#39; input.json | xargs wp",
                "title": "How to iterate a JSON array in bash from jq"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 3,
        "last_activity_date": 1551520264,
        "creation_date": 1551476822,
        "question_id": 54952736,
        "body_markdown": "Background\r\n--\r\nI want to be able to pass a json file to WP CLI, to iteratively create posts.\r\n\r\nSo I thought I could create a JSON file:\r\n\r\n```json\r\n[\r\n    {\r\n        &quot;post_type&quot;: &quot;post&quot;,\r\n        &quot;post_title&quot;: &quot;Test&quot;,\r\n        &quot;post_content&quot;: &quot;[leaflet-map][leaflet-marker]&quot;,\r\n        &quot;post_status&quot;: &quot;publish&quot;\r\n    },\r\n    {\r\n        &quot;post_type&quot;: &quot;post&quot;,\r\n        &quot;post_title&quot;: &quot;Number 2&quot;,\r\n        &quot;post_content&quot;: &quot;[leaflet-map fitbounds][leaflet-circle]&quot;,\r\n        &quot;post_status&quot;: &quot;publish&quot;\r\n    }\r\n]\r\n```\r\n\r\nand iterate the array with jq:\r\n\r\n```bash\r\ncat posts.json | jq --raw-output .[]\r\n```\r\n\r\nI want to be able to iterate these to execute a similar function:\r\n\r\n```bash\r\nwp post create \\\r\n  --post_type=post \\\r\n  --post_title=&#39;Test Map&#39; \\\r\n  --post_content=&#39;[leaflet-map] [leaflet-marker]&#39; \\\r\n  --post_status=&#39;publish&#39;\r\n```\r\n\r\nIs there a way I can do this with `jq`, or similar?\r\n\r\nThe closest I&#39;ve gotten so far is this:\r\n\r\n```bash\r\n&gt; for i in $(cat posts.json | jq -c .[]); do echo $i; done\r\n```\r\n\r\nBut this seems to take issue with the (valid) spaces in the strings.  Output:\r\n\r\n```bash\r\n{&quot;post_type&quot;:&quot;post&quot;,&quot;post_title&quot;:&quot;Test&quot;,&quot;post_content&quot;:&quot;[leaflet-map][leaflet-marker]&quot;,&quot;post_status&quot;:&quot;publish&quot;}\r\n{&quot;post_type&quot;:&quot;post&quot;,&quot;post_title&quot;:&quot;Number\r\n2&quot;,&quot;post_content&quot;:&quot;[leaflet-map\r\nfitbounds][leaflet-circle]&quot;,&quot;post_status&quot;:&quot;publish&quot;}\r\n```\r\n\r\nAm I way off with this approach, or can it be done?",
        "link": "https://stackoverflow.com/questions/54952736/how-to-iterate-a-json-array-in-bash-from-jq",
        "title": "How to iterate a JSON array in bash from jq"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1551517740,
                "last_edit_date": 1551517740,
                "creation_date": 1551516581,
                "answer_id": 54956755,
                "question_id": 54956517,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "A simple way would be to concatenate the arrays, group the elements by id and map each group into a single object using `add`;\r\n\r\n    jq &#39;.listA+.listB | group_by(.id) | map(add)&#39; test.json\r\n\r\nIf there may be more than two arrays you need to merge in the file, you could instead use `flatten` to concatenate all of them.\r\n\r\nTest case below\r\n\r\n    # cat test.json\r\n\r\n    {\r\n      &quot;listA&quot;: [\r\n        { &quot;id&quot;: &quot;12345&quot;, &quot;code&quot;: &quot;001&quot; },\r\n        { &quot;id&quot;: &quot;12346&quot;, &quot;code&quot;: &quot;002&quot; }\r\n      ],\r\n      &quot;listB&quot;: [\r\n        { &quot;id&quot;: &quot;12345&quot;, &quot;prop&quot;: &quot;AABBCC&quot; }\r\n      ]\r\n    }\r\n\r\n    # jq &#39;flatten | group_by(.id) | map(add)&#39; test.json\r\n    # or\r\n    # jq &#39;.listA+.listB | group_by(.id) | map(add)&#39; test.json\r\n\r\n    [\r\n      {\r\n        &quot;id&quot;: &quot;12345&quot;,\r\n        &quot;code&quot;: &quot;001&quot;,\r\n        &quot;prop&quot;: &quot;AABBCC&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: &quot;12346&quot;,\r\n        &quot;code&quot;: &quot;002&quot;\r\n      }\r\n    ]\r\n",
                "title": "Use jq to combine two arrays of objects on a certain key"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1551522520,
                "creation_date": 1551522520,
                "answer_id": 54957509,
                "question_id": 54956517,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using `group_by` entails a sort, which is unnecessary, so if efficiency is a concern, then an alternative approach such as the following should be considered:\r\n\r\n    INDEX(.listA[]; .id) as $one\r\n    | INDEX(.listB[]; .id) as $two\r\n    | reduce ($one|keys_unsorted[]) as $k ($two; .[$k] += $one[$k])\r\n    | {listC: [.[]] }\r\n",
                "title": "Use jq to combine two arrays of objects on a certain key"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1551522520,
        "creation_date": 1551514289,
        "question_id": 54956517,
        "body_markdown": "I am trying to use `jq` to solve this problem.\r\n\r\nSuppose I have the following object\r\n\r\n    {\r\n      &quot;listA&quot;: [\r\n        {\r\n          &quot;id&quot;: &quot;12345&quot;,\r\n          &quot;code&quot;: &quot;001&quot;\r\n        }\r\n      ]\r\n      &quot;listB&quot;: [\r\n        {\r\n          &quot;id&quot;: &quot;12345&quot;,\r\n          &quot;prop&quot;: &quot;AABBCC&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\nIn reality my two lists are longer, but the `id` isn&#39;t repeated within each list.\r\n\r\nHow may I combine the two lists into a single list where each item is an object with the non-`id` properties for the given `id` are collected into a single object?\r\n\r\nFor example, from the object above, I&#39;d like the following:\r\n\r\n    {\r\n      &quot;listC&quot; : [\r\n        {\r\n          &quot;id&quot;: &quot;12345&quot;,\r\n          &quot;code&quot;: &quot;001&quot;,\r\n          &quot;prop&quot;: &quot;AABBCC&quot;\r\n        }\r\n      ]\r\n    }",
        "link": "https://stackoverflow.com/questions/54956517/use-jq-to-combine-two-arrays-of-objects-on-a-certain-key",
        "title": "Use jq to combine two arrays of objects on a certain key"
    },
    {
        "tags": [
            "json",
            "translation",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 15264538,
                    "reputation": 512,
                    "user_id": 11013589,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/-SjzgI1NBqHE/AAAAAAAAAAI/AAAAAAAAAFE/WfN1HD9az5g/s256-rj/photo.jpg",
                    "display_name": "CootMoon",
                    "link": "https://stackoverflow.com/users/11013589/cootmoon"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1551574009,
                "post_id": 54964527,
                "comment_id": 96689712,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1551580888,
                "post_id": 54964527,
                "comment_id": 96690840,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1551609317,
                "last_edit_date": 1551609317,
                "creation_date": 1551583901,
                "answer_id": 54965305,
                "question_id": 54964527,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The problem as stated is a bit perplexing, but here is a solution, assuming that jq is invoked like so:\r\n\r\n    jq -f program.jq —-argfile dict translation.jq form.json\r\n\r\nwhere program.jq contains:\r\n\r\n    .label |= if $dict.label == . then $dict.translation else . end\r\n\r\nEquivalently:\r\n\r\n    if .label == $dict.label then .label = $dict.translation else . end\r\n\r\n## if ... then ... end\r\n\r\nThe &quot;master&quot; version of jq allows `if ... then ... end` so that the above solutions can be respectively shortened to:\r\n\r\n    .label |= if $dict.label == . then $dict.translation end\r\n\r\nand:\r\n\r\n    if .label == $dict.label then .label = $dict.translation end\r\n\r\n",
                "title": "Lookup values from one JSON file and replace in another"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1551609317,
        "creation_date": 1551573891,
        "last_edit_date": 1551595517,
        "question_id": 54964527,
        "body_markdown": "I have 2 files\r\n1. Translation.json\r\n\r\n    \t\t{\r\n\t\t   &quot;sKEY&quot;: &quot;CustomField.Account.Preferred_Name_Local_Language.Fieldlabel&quot;,\r\n\t\t   &quot;label&quot;: &quot;Preferred Name&quot;,\r\n\t\t   &quot;translation&quot;: &quot;Nombre Preferido&quot;,\r\n\t\t    }\r\n2. Form.json\r\n\r\n    \t\t{\r\n          &quot;fullName&quot;: &quot;Student_Information/Preferred_Name__pc&quot;,\r\n          &quot;description&quot;: &quot;Preferred Name&quot;,\r\n          &quot;inlineHelpText&quot;: &quot;Preferred Name&quot;,\r\n          &quot;label&quot;: &quot;Preferred Name&quot;          \r\n            }\r\nI need to lookup the &quot;label&quot; by value in translation.json and replace the &quot;label&quot; value in Form.json with the &quot;tranlsation&quot; value from translation.json.",
        "link": "https://stackoverflow.com/questions/54964527/lookup-values-from-one-json-file-and-replace-in-another",
        "title": "Lookup values from one JSON file and replace in another"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 6,
                "is_accepted": true,
                "score": 6,
                "last_activity_date": 1551656582,
                "last_edit_date": 1551656582,
                "creation_date": 1551654789,
                "answer_id": 54974761,
                "question_id": 54974458,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You will need to &quot;slurp&quot; file1.json, e.g. by invoking jq as follows:\r\n\r\n    jq -n -f merge.jq --slurpfile file1 file1.json file2.json\r\n\r\nwhere merge.jq contains:\r\n\r\n    INDEX($file1[]; .uid) as $dict\r\n    | inputs\r\n    | . + $dict[.uid]\r\n\r\n## def INDEX\r\nIf your jq does not have INDEX/2, then simply add its def:\r\n\r\n    def INDEX(stream; idx_expr):\r\n      reduce stream as $row ({}; .[$row|idx_expr|tostring] = $row);\r\n\r\n",
                "title": "JQ Group By by Key, Merge Value, then Flatten Object"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 5,
        "last_activity_date": 1551656582,
        "creation_date": 1551652476,
        "question_id": 54974458,
        "body_markdown": "With the following inputs:\r\n\r\n    # file1.json\r\n    {\r\n      &quot;uid&quot;: &quot;1&quot;,\r\n      &quot;name&quot;: &quot;jack&quot;\r\n    }\r\n    {\r\n      &quot;uid&quot;: &quot;2&quot;,\r\n      &quot;name&quot;: &quot;jill&quot;\r\n    }\r\n\r\n    # file2.json\r\n    {\r\n      &quot;fid&quot;: &quot;a&quot;,\r\n      &quot;file&quot;: &quot;sample1.txt&quot;,\r\n      &quot;uid&quot;: &quot;1&quot;\r\n    }\r\n    {\r\n      &quot;fid&quot;: &quot;b&quot;,\r\n      &quot;file&quot;: &quot;sample2.txt&quot;,\r\n      &quot;uid&quot;: &quot;1&quot;\r\n    }\r\n    {\r\n      &quot;fid&quot;: &quot;c&quot;,\r\n      &quot;file&quot;: &quot;sample3.txt&quot;,\r\n      &quot;uid&quot;: &quot;2&quot;\r\n    }\r\n\r\nHow do I go about inserting the `name` key-value pair to the object in the `file2.json`. The output I&#39;m trying to get is as follows:\r\n\r\n    {\r\n      &quot;fid&quot;: &quot;a&quot;,\r\n      &quot;file&quot;: &quot;sample1.txt&quot;,\r\n      &quot;uid&quot;: &quot;1&quot;,\r\n      &quot;name&quot;: &quot;jack&quot;\r\n    }\r\n    {\r\n      &quot;fid&quot;: &quot;b&quot;,\r\n      &quot;file&quot;: &quot;sample2.txt&quot;,\r\n      &quot;uid&quot;: &quot;1&quot;,\r\n      &quot;name&quot;: &quot;jack&quot;\r\n    }\r\n    {\r\n      &quot;fid&quot;: &quot;c&quot;,\r\n      &quot;file&quot;: &quot;sample3.txt&quot;,\r\n      &quot;uid&quot;: &quot;2&quot;,\r\n      &quot;name&quot;: &quot;jill&quot;\r\n    }\r\n\r\nSolutions posted on https://stackoverflow.com/questions/46254655/merge-json-objects-with-jq and https://stackoverflow.com/questions/39830426/join-two-json-files-based-on-common-key-with-jq-utility-or-alternative-way-from both seems to only return the last matching pair. See below.\r\n\r\n    {&quot;uid&quot;:&quot;1&quot;,&quot;name&quot;:&quot;jack&quot;,&quot;fid&quot;:&quot;b&quot;,&quot;file&quot;:&quot;sample2.txt&quot;}\r\n    {&quot;uid&quot;:&quot;2&quot;,&quot;name&quot;:&quot;jill&quot;,&quot;fid&quot;:&quot;c&quot;,&quot;file&quot;:&quot;sample3.txt&quot;}",
        "link": "https://stackoverflow.com/questions/54974458/jq-group-by-by-key-merge-value-then-flatten-object",
        "title": "JQ Group By by Key, Merge Value, then Flatten Object"
    },
    {
        "tags": [
            "awk",
            "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": 1551691536,
                "post_id": 54980112,
                "comment_id": 96718386,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 189706,
                    "reputation": 7562,
                    "user_id": 429199,
                    "user_type": "registered",
                    "accept_rate": 93,
                    "profile_image": "https://www.gravatar.com/avatar/0032472303819b86829b681b7b20639c?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "day0ops",
                    "link": "https://stackoverflow.com/users/429199/day0ops"
                },
                "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": 1551691819,
                "post_id": 54980112,
                "comment_id": 96718549,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1551691920,
                "creation_date": 1551691920,
                "answer_id": 54980266,
                "question_id": 54980112,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The contents of that file isn&#39;t purely json if those periods are actually present at the end of the lines. _If_ every line in that file is a single json object immediately followed by a period, you could read the file in raw (which passes as input every line in the file as a string), strip out the period, then parse the json and process like normal.\r\n\r\nFor example, dumping all user login names:\r\n\r\n    $ jq -R &#39;.[:-1] | fromjson | .userData[].user.loginName&#39; input.txt",
                "title": "Combining Awk smart ranges and jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1551691920,
        "creation_date": 1551691337,
        "question_id": 54980112,
        "body_markdown": "I&#39;ve got a file with multiple lines in the following `json` format that I want to pipe to `jq` to extract few fields.\r\n\r\nThe format is,\r\n```\r\n{&quot;userData&quot;:[{&quot;user&quot;:{&quot;loginName&quot;:&quot;TEST&quot;,....]}.\r\n\r\n{&quot;userData&quot;:[{&quot;user&quot;:{&quot;loginName&quot;:&quot;TEST1&quot;,....]}.\r\n```\r\n`....` represents &quot;some&quot; `json` data.\r\n\r\nI can extract the lines with `awk &#39;/{\\&quot;userData\\&quot;/{p=1}; p; /}\\./{p=0};&#39;` which seems to be printing just fine.\r\n\r\nThe difficulty I&#39;m having is to run `jq` on each of the lines and extract the `json` fields. How can achieve this with a single `awk` command ?",
        "link": "https://stackoverflow.com/questions/54980112/combining-awk-smart-ranges-and-jq",
        "title": "Combining Awk smart ranges and jq"
    },
    {
        "tags": [
            "json",
            "bash",
            "file",
            "merge",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1551803976,
                "last_edit_date": 1551803976,
                "creation_date": 1551788161,
                "answer_id": 55002623,
                "question_id": 55001822,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Roughly based on [peak&#39;s answer](https://stackoverflow.com/a/51219620/5291015) use inputs with `-n` to read the JSON contents in one shot and removing the extension from the filename\r\n\r\n    jq -n &#39;\r\n      [inputs\r\n       | {(input_filename | gsub(&quot;.*/|\\\\.json$&quot;;&quot;&quot;)): .}]\r\n       | add&#39; *.json\r\n\r\nAlso as suggested by the original author, the solution above only removes UNIX-style paths, but not Windows-style paths.",
                "title": "Merging JSON files under their own key using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1551803976,
        "creation_date": 1551785470,
        "last_edit_date": 1551795356,
        "question_id": 55001822,
        "body_markdown": "Trying to merge an undefined number of JSON files into one, each represented in their own key (using `jq`).\r\n\r\nExample:\r\n```\r\n$ cat foo.json\r\n{\r\n  &quot;test1&quot;:&quot;Foo&quot;\r\n}\r\n$ cat bar.json\r\n{\r\n  &quot;test2&quot;:&quot;Bar&quot;\r\n}\r\n$ jq -s &quot;{`ls | sed -r &#39;s/\\.json$/: \\./&#39; | tr &#39;\\n&#39; &#39;, &#39; | sed &#39;s/.$//&#39;`}&quot; `ls`\r\n{\r\n  &quot;foo&quot;: [\r\n    {\r\n      &quot;test1&quot;: &quot;Foo&quot;\r\n    },\r\n    {\r\n      &quot;test2&quot;: &quot;Bar&quot;\r\n    }\r\n  ],\r\n  &quot;bar&quot;: [\r\n    {\r\n      &quot;test1&quot;: &quot;Foo&quot;\r\n    },\r\n    {\r\n      &quot;test2&quot;: &quot;Bar&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nAs I am trying to output:\r\n```\r\n{\r\n  &quot;foo&quot;: {\r\n    &quot;test1&quot;: &quot;Foo&quot;\r\n  },\r\n  &quot;bar&quot;: {\r\n    &quot;test2&quot;: &quot;Bar&quot;\r\n  }\r\n}\r\n```\r\n\r\nFor example: `foo` being the name of the first file and expected to be the key for its content in the final output.\r\n\r\n(Also, I feel like this is not really pretty to call `ls` twice for the same thing, but not sure if there is a way around).",
        "link": "https://stackoverflow.com/questions/55001822/merging-json-files-under-their-own-key-using-jq",
        "title": "Merging JSON files under their own key using jq"
    },
    {
        "tags": [
            "json",
            "key",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 419940,
                    "reputation": 2071,
                    "user_id": 797369,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/6a84e973e72f2d972dd1498c1604ffee?s=256&d=identicon&r=PG",
                    "display_name": "Vetras",
                    "link": "https://stackoverflow.com/users/797369/vetras"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1551814228,
                "post_id": 55009991,
                "comment_id": 96775292,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 419940,
                    "reputation": 2071,
                    "user_id": 797369,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/6a84e973e72f2d972dd1498c1604ffee?s=256&d=identicon&r=PG",
                    "display_name": "Vetras",
                    "link": "https://stackoverflow.com/users/797369/vetras"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1551814284,
                "post_id": 55009991,
                "comment_id": 96775315,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "reply_to_user": {
                    "account_id": 419940,
                    "reputation": 2071,
                    "user_id": 797369,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/6a84e973e72f2d972dd1498c1604ffee?s=256&d=identicon&r=PG",
                    "display_name": "Vetras",
                    "link": "https://stackoverflow.com/users/797369/vetras"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1551814798,
                "post_id": 55009991,
                "comment_id": 96775539,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": -1,
                "last_activity_date": 1551814494,
                "creation_date": 1551814494,
                "answer_id": 55010261,
                "question_id": 55009991,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "(without a sample input/output this is the best I can guess)\r\n\r\nmaybe this: \r\n\r\n    &lt;&lt;input&gt;&gt; | jq &#39;.[] | {foo: .name, bar: .url}&#39;\r\n\r\nany of this helps? https://stedolan.github.io/jq/tutorial/",
                "title": "select from object stream given array of keys"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1551814546,
                "creation_date": 1551814546,
                "answer_id": 55010276,
                "question_id": 55009991,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you simply want fields from the top level object from an array, you could just index normally:\r\n\r\n    $ jq --arg fields &#39;name,url&#39; &#39;.[$fields | split(&quot;,&quot;)[]]&#39; input.json\r\n\r\nAnd in general, if you need values at arbitrary paths, it&#39;d be better to input as paths:\r\n\r\n    $ jq --argjson paths &#39;[[&quot;foo&quot;],[&quot;foo&quot;,&quot;bar&quot;]]&#39; &#39;getpath($paths[])&#39; input.json",
                "title": "select from object stream given array of keys"
            },
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": -1,
                "last_activity_date": 1551814613,
                "creation_date": 1551814613,
                "answer_id": 55010293,
                "question_id": 55009991,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I think it will be this : \r\n\r\n    $ jq --argjson paths &#39;[[&quot;foo&quot;],[&quot;foo&quot;,&quot;bar&quot;]]&#39; &#39;getpath($paths[])&#39; input.json",
                "title": "select from object stream given array of keys"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1551814696,
                "creation_date": 1551814696,
                "answer_id": 55010306,
                "question_id": 55009991,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "For just the values, you could use `getpath`:\r\n\r\n    $ echo &#39;{&quot;a&quot;:1,&quot;b&quot;:2,&quot;c&quot;:3}&#39; |\r\n      jq --argjson keys &#39;[&quot;a&quot;,&quot;c&quot;]&#39; &#39;$keys[] as $key | getpath([$key])&#39;\r\n    1\r\n    3",
                "title": "select from object stream given array of keys"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": 0,
        "last_activity_date": 1551818793,
        "creation_date": 1551813382,
        "last_edit_date": 1551814757,
        "question_id": 55009991,
        "body_markdown": "How can I select in jq some fields from an array of keys? Not constants, but a list of keys:\r\n\r\n    | $fields = [&quot;name&quot;, &quot;url&quot;]\r\n    | . [$fields]",
        "link": "https://stackoverflow.com/questions/55009991/select-from-object-stream-given-array-of-keys",
        "title": "select from object stream given array of keys"
    },
    {
        "tags": [
            "json",
            "stream",
            "bigdata",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1664263,
                    "reputation": 3537,
                    "user_id": 1532004,
                    "user_type": "registered",
                    "accept_rate": 80,
                    "profile_image": "https://www.gravatar.com/avatar/035d61885b5217e4d2840d88afcdb2b8?s=256&d=identicon&r=PG",
                    "display_name": "Zim84",
                    "link": "https://stackoverflow.com/users/1532004/zim84"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1551886572,
                "post_id": 55023433,
                "comment_id": 96806332,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1551889577,
                "last_edit_date": 1551889577,
                "creation_date": 1551886367,
                "answer_id": 55026751,
                "question_id": 55023433,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "In the following, we&#39;ll assume $key holds the key of interest.\r\n\r\nThe key to efficiency here is to terminate once the processing of the stream produced by the `--stream` option completes handling the $key key. \r\n To do so, we can define a helper function as follows.  Notice that it uses `inputs`, and hence the invocation of jq must use the -n command-line option.\r\n\r\n    # break out early\r\n    def filter($key):\r\n      label $out\r\n      | foreach inputs as $in ( null;\r\n          if . == null\r\n          then if $in[0][0] == $key then $in\r\n    \t       else empty\r\n               end\r\n          elif $in[0][0] != $key then break $out\r\n          else $in\r\n          end;\r\n          select(length==2) );\r\n\r\nThe reconstruction of the desired key-value pair can now be accomplished as follows:\r\n\r\n    reduce filter($key) as $in ({};\r\n      setpath($in[0]; $in[1]) )\r\n\r\n\r\n## Example input.json\r\n\r\n    {\r\n      &quot;key1&quot;: {\r\n        &quot;subtree1&quot;: {\r\n    \t&quot;a&quot;: {&quot;aa&quot;:[1,2,3]}\r\n        }\r\n      },\r\n      &quot;key2&quot;: {\r\n        &quot;subtree2&quot;: {\r\n    \t    &quot;b1&quot;:  {&quot;bb&quot;:[11,12,13]},\r\n            &quot;b2&quot;:  {&quot;bb&quot;:[11,12,13]}\r\n        }\r\n      },\r\n      &quot;key3&quot;: {\r\n        &quot;subtree3&quot;: {\r\n          &quot;c&quot;:  {&quot;cc&quot;:[21,22,23]}\r\n        }\r\n      }\r\n    }\r\n\r\n## Illustration\r\n\r\n    jq -n -c --arg key &quot;key2&quot; --stream -f extract.jq input.json\r\n\r\n\r\n## Output\r\n\r\n    {&quot;key2&quot;:{&quot;subtree2&quot;:{&quot;b1&quot;:{&quot;bb&quot;:[11,12,13]},&quot;b2&quot;:{&quot;bb&quot;:[11,12,13]}}}}\r\n\r\n\r\n",
                "title": "jq extract one subtree from huge (10 GB) JSON file via streaming"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1678103358,
                "creation_date": 1678103358,
                "answer_id": 75650508,
                "question_id": 55023433,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here’s a simple one-liner using jq’s —-stream option:\r\n\r\n\r\n    jq —-stream &#39;first(fromstream(select(.[0][0]==&quot;key2&quot;), [[&quot;key2&quot;]]))&#39;",
                "title": "jq extract one subtree from huge (10 GB) JSON file via streaming"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1678103358,
        "creation_date": 1551876239,
        "last_edit_date": 1678102159,
        "question_id": 55023433,
        "body_markdown": "I have a database dump that consists of one huge JSON tree.\r\nI want to extract a specific subtree that will be much smaller than the rest, with a known specific key.\r\n\r\n    { &quot;key1&quot;: { subtree1... }, &quot;key2&quot;: { subtree2... }, ... }\r\n\r\nHow do I extract `subtreeN` with streaming jq?\r\n",
        "link": "https://stackoverflow.com/questions/55023433/jq-extract-one-subtree-from-huge-10-gb-json-file-via-streaming",
        "title": "jq extract one subtree from huge (10 GB) JSON file via streaming"
    },
    {
        "tags": [
            "json",
            "nested",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 19,
                "is_accepted": true,
                "score": 19,
                "last_activity_date": 1551890418,
                "creation_date": 1551890418,
                "answer_id": 55028089,
                "question_id": 55027717,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "One way would be to recurse deep with the `..` to get as deep as possible and _if_ the value is present and _not_ null as\r\n\r\n    jq &#39;.. | .name? | select(. != null)&#39;\r\n",
                "title": "JQ: accessing element no matter how many levels deep"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 10,
        "last_activity_date": 1698386491,
        "creation_date": 1551889228,
        "last_edit_date": 1698386491,
        "question_id": 55027717,
        "body_markdown": "Given the file `test.json`\r\n\r\n    {\r\n      &quot;file&quot;: {\r\n        &quot;id&quot;: &quot;123456789&quot;,\r\n        &quot;name&quot;: &quot;137.txt&quot;\r\n      },\r\n      &quot;lines&quot;: 219,\r\n      &quot;characters&quot;: 2456\r\n    }\r\n\r\nI would like to access element `name` using JQ from the command line. \r\n\r\nTyping `jq .file.name test.json` produces `137.txt`. Perfect!\r\n\r\nUnfortunately our real json structure is much bigger and typing the full path of an element can be painful. \r\n\r\nIs it possible to retrieve the value of `name` without typing the full path? Something like `jq *.name test.json` with `*` being a wildcard?\r\n\r\n",
        "link": "https://stackoverflow.com/questions/55027717/jq-accessing-element-no-matter-how-many-levels-deep",
        "title": "JQ: accessing element no matter how many levels deep"
    },
    {
        "tags": [
            "json",
            "group-by",
            "aggregate",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1551902196,
                "last_edit_date": 1551902196,
                "creation_date": 1551894923,
                "answer_id": 55029413,
                "question_id": 55028748,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a simple solution using `group_by`:\r\n\r\n    group_by(.code)\r\n    | map( reduce .[] as $x (.[0] | del(.name); \r\n             .people += [$x.name]) )\r\n",
                "title": "restructure JSON file with jq: regroup values in an array"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1551895548,
                "creation_date": 1551895548,
                "answer_id": 55029578,
                "question_id": 55028748,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a solution that is more efficient than one using `group_by` in that the latter involves a sort.  \r\n\r\nEfficiency can be achieved using the builtin `INDEX/1`, and the generic function `aggregate_by` defined as:\r\n\r\n    def aggregate_by(s; f; g):\r\n      reduce s as $x  (null; .[$x|f] += [$x|g]);\r\n\r\n    aggregate_by(.[]; .code; .name) as $dict\r\n    | INDEX(.code)\r\n    | [.[]]\r\n    | map(del(.name) | .person = $dict[.code])\r\n\r\n\r\n\r\n",
                "title": "restructure JSON file with jq: regroup values in an array"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1551913182,
        "creation_date": 1551892669,
        "last_edit_date": 1551895654,
        "question_id": 55028748,
        "body_markdown": "I&#39;m new to jq and I can&#39;t quite figure out how to transform a JSON file formatted like this:\r\n\r\n```\r\n[\r\n  {\r\n    &quot;name&quot;: &quot;person 1&quot;,\r\n    &quot;code&quot;: &quot;AAA&quot;,\r\n    &quot;latitude&quot;: 11,\r\n    &quot;longitude&quot;: 22 \r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;person 2&quot;,\r\n    &quot;code&quot;: &quot;AAA&quot;,\r\n    &quot;latitude&quot;: 11,\r\n    &quot;longitude&quot;: 22 \r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;person 3&quot;,\r\n    &quot;code&quot;: &quot;BBB&quot;,\r\n    &quot;latitude&quot;: 33,\r\n    &quot;longitude&quot;: 44 \r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;person 4&quot;,\r\n    &quot;code&quot;: &quot;BBB&quot;,\r\n    &quot;latitude&quot;: 33,\r\n    &quot;longitude&quot;: 44 \r\n  }\r\n]\r\n```\r\n\r\ninto this:\r\n\r\n```\r\n[\r\n  {\r\n   &quot;code&quot;: &quot;AAA&quot;,\r\n   &quot;latitude&quot;: 11,\r\n   &quot;longitude&quot;: 22,\r\n   &quot;people&quot;: [&quot;person 1&quot;, &quot;person 2&quot;]\r\n  },\r\n  {\r\n   &quot;code&quot;: &quot;BBB&quot;,\r\n   &quot;latitude&quot;: 33,\r\n   &quot;longitude&quot;: 44,\r\n   &quot;people&quot;: [&quot;person 3&quot;, &quot;person 4&quot;]\r\n  }\r\n]\r\n```\r\n\r\nI figured out how to use `map()` and `unique` to get the unique combinations of `code`, `latitude`, `longitude` but not how to add the names into an array.",
        "link": "https://stackoverflow.com/questions/55028748/restructure-json-file-with-jq-regroup-values-in-an-array",
        "title": "restructure JSON file with jq: regroup values in an array"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1143565,
                    "reputation": 535973,
                    "user_id": 1126841,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa05233b2357f8d11c22ef4cfc7bb85c?s=256&d=identicon&r=PG",
                    "display_name": "chepner",
                    "link": "https://stackoverflow.com/users/1126841/chepner"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1551896400,
                "post_id": 55029614,
                "comment_id": 96812137,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1551897170,
                "post_id": 55029614,
                "comment_id": 96812482,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3151396,
                    "reputation": 19,
                    "user_id": 2664774,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/894b7c44bd44d4b37227572dfa987426?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "TarekZ",
                    "link": "https://stackoverflow.com/users/2664774/tarekz"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1551897628,
                "post_id": 55029614,
                "comment_id": 96812695,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1551896839,
                "last_edit_date": 1551896839,
                "creation_date": 1551896168,
                "answer_id": 55029728,
                "question_id": 55029614,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`jq` provides a `fromjson` function to parse embedded JSON. For example, \r\n\r\n    $ jq &#39;.[].JSON | fromjson | .field1&#39; tmp.json\r\n    &quot;value1&quot;\r\n    &quot;value2&quot;\r\n\r\nUpdate:\r\n\r\nThe problem is not `jq`, but the fact that `tee` writes its input to standard output as well as to any files named as arguments. Redirect to `/dev/null`\r\n\r\n    echo &quot;$result&quot; | tee json_in_json.json &gt; /dev/null\r\n\r\nor don&#39;t use `tee` in the first place.\r\n\r\n    echo &quot;$result&quot; &gt; json_in_json.json",
                "title": "JQ unable to parse JSON with embedded JSON on GIT BASH for WINDOWS"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1553189064,
                "creation_date": 1553189064,
                "answer_id": 55286010,
                "question_id": 55029614,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I had filed a bug with jq about this, but closed it since it wasn&#39;t reproducible on ubuntu or macos. Nico Williams explained what is happening here:\r\n\r\nhttps://github.com/stedolan/jq/issues/1855\r\n\r\n",
                "title": "JQ unable to parse JSON with embedded JSON on GIT BASH for WINDOWS"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1553189064,
        "creation_date": 1551895732,
        "last_edit_date": 1552313980,
        "question_id": 55029614,
        "body_markdown": "I have a bash script (running on git bash for windows) that uses curl to get a json response from a server. The response contain a field that contain json data. The response looks like this:\r\n\r\n    [{\r\n    \t&quot;Status&quot;: &quot;A&quot;,\r\n    \t&quot;JSON&quot;: &quot;{\\&quot;field1\\&quot;:\\&quot;value1\\&quot;}&quot;\r\n    }, {\r\n    \t&quot;Status&quot;: &quot;B&quot;,\r\n    \t&quot;JSON&quot;: &quot;{\\&quot;field1\\&quot;:\\&quot;value2\\&quot;}&quot;\r\n    }]\r\n\r\nhere is the bash script I am trying to parse this string with:\r\n\r\n    #!/bin/bash\r\n    echo &quot;parsing result in variable&quot;\r\n    result=&#39;[{&quot;Status&quot;:&quot;A&quot;, &quot;JSON&quot;:&quot;{\\&quot;field1\\&quot;:\\&quot;value1\\&quot;}&quot;},{&quot;Status&quot;:&quot;B&quot;, &quot;JSON&quot;:&quot;{\\&quot;field1\\&quot;:\\&quot;value2\\&quot;}&quot;}]&#39;\r\n    echo $result &gt; json_in_json.json\r\n    result=$(echo &quot;$result&quot; | jq &#39;[.[].&quot;Status&quot;]&#39;)\r\n    echo $result\r\n    \r\n    echo &quot;parsing result from file&quot;\r\n     jq &#39;[.[].&quot;Status&quot;]&#39; json_in_json.json\r\n\r\nand here is what I see in terminal\r\n\r\n    parsing result in variable\r\n    [{&quot;Status&quot;:&quot;A&quot;, &quot;JSON&quot;:&quot;{\\&quot;field1\\&quot;:\\&quot;value1\\&quot;}&quot;},{&quot;Status&quot;:&quot;B&quot;, &quot;JSON&quot;:&quot;{\\&quot;field1\\&quot;:\\&quot;value2\\&quot;}&quot;}]\r\n     ]B&quot;,\r\n    parsing result from file\r\n    [\r\n      &quot;A&quot;,\r\n      &quot;B&quot;\r\n    ]\r\n\r\nIs there a way to make jq output the same result without going through a temp file?",
        "link": "https://stackoverflow.com/questions/55029614/jq-unable-to-parse-json-with-embedded-json-on-git-bash-for-windows",
        "title": "JQ unable to parse JSON with embedded JSON on GIT BASH for WINDOWS"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1551946633,
                "last_edit_date": 1551946633,
                "creation_date": 1551939359,
                "answer_id": 55037190,
                "question_id": 55037108,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "After a fairly long experimentation phase trying to make this work, I finally came up with what seems like a feasible and reliable solution without the extremely unsettling flaws that could come from utilizing `eval`.  \r\n\r\nTo better highlight the overall final solution, I am providing a bit more of the handling that I am currently working with below:\r\n\r\n### Goal\r\n\r\n1. Grab a secret from [AWS Secrets Manager](https://aws.amazon.com/secrets-manager/)\r\n\r\n2. Parse the returned JSON, which looks like this:\r\n\r\n```json\r\n{\r\n  &quot;ARN&quot;: &quot;arn:aws:secretsmanager:us-west-2:123456789012:secret:MyTestDatabaseSecret-a1b2c3&quot;,\r\n  &quot;Name&quot;: &quot;MyTestDatabaseSecret&quot;,\r\n  &quot;VersionId&quot;: &quot;EXAMPLE1-90ab-cdef-fedc-ba987EXAMPLE&quot;,\r\n  &quot;SecretString&quot;: &quot;{\\n  \\&quot;username\\&quot;:\\&quot;david\\&quot;,\\n  \\&quot;password\\&quot;:\\&quot;BnQw&amp;XDWgaEeT9XGTT29\\&quot;\\n}\\n&quot;,\r\n  &quot;VersionStages&quot;: [\r\n    &quot;AWSPREVIOUS&quot;\r\n  ],\r\n  &quot;CreatedDate&quot;: 1523477145.713\r\n}\r\n```\r\n\r\n3. Run some modifications on the JSON string received and pick only the statically requested keys from the secret\r\n\r\n4. Set and export those values as environment variables\r\n\r\n\r\n### Script\r\n\r\n```bash\r\n# Capture a AWS Secret from secretsmanager, parse the JSON and expand the given\r\n# variables within it to pick them from the secret and return given portion of \r\n# the secret requested.\r\n# @note similar to _.pick(obj, [&quot;foo&quot;, &quot;bar&quot;])\r\ngetKeysFromSecret() {\r\n  aws secretsmanager get-secret-value --secret-id &quot;$1&quot; \\\r\n    | jq -r &#39;.SecretString | fromjson&#39; \\\r\n    | jq -r &quot;{ $2 }&quot;\r\n}\r\n\r\n# Uses `getKeysFromSecret` to capture the requested keys from the secret\r\n# then transforms the JSON into a string that we can read and loop through\r\n# to set each resulting value as an exported environment variable.\r\n#\r\n## Transformation Flow:\r\n#   { &quot;foo&quot;: &quot;bar&quot;, &quot;baz&quot;: &quot;qux&quot; } \r\n# --&gt; \r\n#   foo=bar\r\n#   baz=qux \r\n# --&gt; \r\n#   export foo=bar\r\n#   export baz=qux\r\nexportVariablesInSecret() {\r\n  while IFS== read -r key value; do\r\n    if [ -n &quot;$value&quot; ]; then \r\n      export &quot;${key}&quot;=&quot;${value}&quot;;\r\n    fi\r\n  done &lt; &lt;(getKeysFromSecret &quot;$1&quot; &quot;$2&quot; | jq -r &#39;to_entries | .[] | .key + &quot;=&quot; + .value&#39;)\r\n}\r\n\r\n\r\n```\r\n\r\n### Example JSON\r\n\r\n```json\r\n{\r\n  ...othervalues\r\n  &quot;SecretString&quot;: &quot;{\\&quot;foo\\&quot;: \\&quot;bar\\&quot;, \\&quot;baz\\&quot;: \\&quot;qux\\&quot;}&quot;\r\n}\r\n```\r\n\r\n### Example Usage\r\n\r\n```bash\r\nexportVariablesInSecret MY_SECRET &quot;foo, bar&quot;\r\necho $foo\r\n# bar\r\n```\r\n\r\n### Some Notes / Context\r\n\r\n1. This is meant to set a given set of values as variables so that we aren&#39;t just setting an entire arbitrary JSON object as variables that could possibly cause issues / shadowing if someone adds a value like &quot;path&quot; to a secret\r\n\r\n3. A critical goal was to absolutely never use `eval` to prevent possible injection situations.  Far too easy to inject things otherwise.\r\n\r\n4. Happy to see if anyone has a nicer way of accomplishing this.  I saw many people recommending the use of `declare` but that sets the var to the local function scope only so its essentially useless.\r\n\r\n---\r\n\r\nThanks to @cas https://unix.stackexchange.com/a/413917/308550 for getting me on the right track! ",
                "title": "How to expand variable value to build a"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1551946633,
        "creation_date": 1551938894,
        "question_id": 55037108,
        "body_markdown": "Sorry if this is included somewhere, looked for a good 30-60 minutes for something along these lines.  I am sure I just missed something! Total jq nub!\r\n\r\nBasically I am trying to do a `pick` operation that is dynamic.  My thought process was to do something like this:\r\n\r\n```bash\r\npickJSON() {\r\n  getSomeJSON | jq -r --arg PICK &quot;$1&quot; &#39;{ $PICK }&#39;\r\n}\r\n\r\npickJSON &quot;foo, bar&quot;\r\n```\r\n\r\nbut this produces\r\n\r\n```\r\n{ &quot;PICK&quot;: &quot;foo, bar&quot; }\r\n```\r\n\r\nIs there a way to essentially ask it to expand shell-style?\r\n\r\n---\r\n\r\n### Desired Result:\r\n\r\n```bash\r\npickJSON() {\r\n  getSomeJSON | jq -r --arg PICK &quot;$1&quot; &#39;{ $PICK }&#39;\r\n  # perhaps something like...\r\n  # getSomeJSON | jq -r --arg PICK &quot;$1&quot; &#39;{ ...$PICK }&#39;\r\n}\r\n\r\npickJSON &quot;foo, bar&quot;\r\n```\r\n\r\n```\r\n{ &quot;foo&quot;: &quot;foovalue&quot;, &quot;bar&quot;: &quot;barvalue&quot; }\r\n```\r\n\r\n&gt; Note that I am new to `jq` and i just simplified what i am doing - if the syntax is broken that is why :-D my actual implementaiton has a few pipes in there and it does work if i dont try to pick the values out of it.",
        "link": "https://stackoverflow.com/questions/55037108/how-to-expand-variable-value-to-build-a",
        "title": "How to expand variable value to build a"
    },
    {
        "tags": [
            "arrays",
            "json",
            "parsing",
            "object",
            "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": 1551968386,
                "post_id": 55045197,
                "comment_id": 96842315,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 12963036,
                    "reputation": 2448,
                    "user_id": 9371654,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/-XdUIqdMkCWA/AAAAAAAAAAI/AAAAAAAAAAA/4252rscbv5M/s256-rj/photo.jpg",
                    "display_name": "user9371654",
                    "link": "https://stackoverflow.com/users/9371654/user9371654"
                },
                "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": 1551968677,
                "post_id": 55045197,
                "comment_id": 96842527,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1551969138,
                "post_id": 55045197,
                "comment_id": 96842816,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1551972131,
                "last_edit_date": 1551972131,
                "creation_date": 1551968877,
                "answer_id": 55046167,
                "question_id": 55045197,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Since the value of the &quot;content&quot; field cannot be processed directly by `fromjson`, the following solution first translates the single-quotes to escaped double-quotes, and then applies your filter:\r\n\r\n    map(.final.content |= (gsub(&quot;&#39;&quot;;&quot;\\&quot;&quot;) | fromjson))\r\n    | .[]\r\n    | &quot;\\(.start),\\(.final[&quot;name&quot;]),\\(.final[&quot;content&quot;][&quot;Type&quot;])&quot;\r\n\r\nOutput using the -r command-line option:\r\n\r\n    xxx,uuu,text\r\n    yyy,nnn,null\r\n\r\n## CSV\r\n\r\nIf you want valid CSV output, it would probably be better to use the `@csv` filter:\r\n\r\n    .[]\r\n    | .final.content |= (gsub(&quot;&#39;&quot;;&quot;\\&quot;&quot;) | fromjson)\r\n    | [.start, .final[&quot;name&quot;], .final[&quot;content&quot;][&quot;Type&quot;]]\r\n    | @csv\r\n\r\n\r\n## Invocation\r\n\r\nWith the jq program in a file, say program.jq, the appropriate invocation would look like this:\r\n\r\n    jq -r -f program.jq test.json\r\n\r\n## Variation\r\n\r\nIf you want to handle missing values specially, you could use `//` e.g as follows:\r\n\r\n    (.final[&quot;content&quot;][&quot;Type&quot;] // &quot;NA&quot;)\r\n\r\n## Handling embedded double-quotes\r\n\r\n    .final.content |= (gsub(&quot;\\&quot;&quot;;&quot;\\\\\\&quot;&quot;) | gsub(&quot;&#39;&quot;;&quot;\\&quot;&quot;) | fromjson)",
                "title": "jq: error Cannot index string with string. How to parse json file with variable object values using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1551972131,
        "creation_date": 1551965904,
        "last_edit_date": 1551968223,
        "question_id": 55045197,
        "body_markdown": "I have a json file that looks like:\r\n\r\n    [\r\n    {&quot;start&quot;: &quot;xxx&quot;, &quot;final&quot;: {&quot;name&quot;: &quot;uuu&quot;, &quot;content&quot;: &quot;{&#39;Date&#39;: &#39;Thu, 07 Mar 2019&#39;, &#39;Type&#39;: &#39;text&#39;}&quot;}},\r\n    {&quot;start&quot;: &quot;yyy&quot;, &quot;final&quot;: {&quot;name&quot;: &quot;nnn&quot;, &quot;content&quot;: &quot;{&#39;Date&#39;: &#39;Thu, 07 Mar 2019&#39;}&quot;}}\r\n    ]\r\n\r\nThe `&quot;final&quot;` holds an object which contains two keys: `name` and `content`. The `content` value is an object. It may be empty, and it may contains different keys. \r\n\r\nHowever, I am interested in certain keys if appeared in the `content`. In this example, if &quot;Type&quot; is included, I want to parse it. If not, just insert &quot;not found&quot;.\r\n\r\nWhen I run this `jq` command, I get this error:\r\n\r\n    jq: error (at &lt;stdin&gt;:4): Cannot index string with string &quot;Type&quot;\r\n\r\nThis is because the second object in my json file does not contain `Type`.  \r\n\r\nIs there a solution to this problem?\r\n\r\n    cat test.json | jq -r &#39;.[] | &quot;\\(.start),\\(.final[&quot;name&quot;]),\\(.final[&quot;content&quot;][&quot;Type&quot;])&quot;&#39;\r\n    jq: error (at &lt;stdin&gt;:4): Cannot index string with string &quot;Type&quot;\r\n\r\n",
        "link": "https://stackoverflow.com/questions/55045197/jq-error-cannot-index-string-with-string-how-to-parse-json-file-with-variable",
        "title": "jq: error Cannot index string with string. How to parse json file with variable object values using jq"
    },
    {
        "tags": [
            "json",
            "dictionary",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1551976566,
                "creation_date": 1551976566,
                "answer_id": 55048735,
                "question_id": 55048439,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It looks like you&#39;re missing an invocation of `add`.  Adding `add` to your jq:\r\n\r\n    { errorMessage,\r\n      errorCode,\r\n      orderId:\r\n        (.orderId\r\n         | map({ (.orderId) :\r\n                   { orderId,\r\n                     targetRequirements:\r\n                       (.targetRequirements\r\n                        | map({preferenceOrder,targetID }) ) } })\r\n         | add ) }\r\n\r\nThis yields the structure you want, but the output differs in some details from what you have shown as the expected output, so you will probably want to tweak the filter accordingly.",
                "title": "Trying to create a Map but ending with List in JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1551976566,
        "creation_date": 1551975683,
        "question_id": 55048439,
        "body_markdown": "I am trying to get the Input JSON given below in the Output Structure given, but i am getting the structure as List instead of Map.\r\n\r\n**Input Structure:**\r\n\r\n    {\r\n          \r\n          &quot;errorMessage&quot;: null,\r\n          &quot;errorCode&quot;: null,\r\n          &quot;state&quot;: &quot;Complete&quot;,\r\n           &quot;status&quot;: &quot;Completed&quot;,\r\n           &quot;createdDate&quot;: &quot;234234234234&quot;,\r\n           &quot;createdTime&quot;: &quot;332432423433&quot;,\r\n           \r\n          &quot;orderId&quot;: {\r\n            &quot;Order394&quot;: {\r\n              &quot;orderId&quot;: &quot;Order394&quot;,\r\n              &quot;targetRequirements&quot;: [\r\n               \r\n                { &quot;targetID&quot; : &quot;1234&quot;,\r\n                &quot;targetDate&quot; : &quot;targetDate&quot;,\r\n                  &quot;preferenceOrder&quot;: 1,\r\n                  &quot;matchID&quot;: &quot;502&quot;\r\n                },\r\n                { &quot;targetID&quot; : &quot;1235&quot;,\r\n                &quot;targetDate&quot; : &quot;targetDate&quot;,\r\n                  &quot;preferenceOrder&quot;: 1,\r\n                  &quot;matchID&quot;: &quot;503&quot;\r\n                }\r\n              ],\r\n              &quot;username&quot;: &quot;Arun&quot;,\r\n              &quot;address&quot;: &quot;6166192&quot;,\r\n              &quot;Title&quot;: &quot;Kumar&quot;\r\n            },\r\n            &quot;Order395&quot;: {\r\n              &quot;orderId&quot;: &quot;Order395&quot;,\r\n              &quot;targetRequirements&quot;: [\r\n              \r\n                { &quot;targetDate&quot; : &quot;targetDate&quot;,\r\n               &quot;targetID&quot; : &quot;1234&quot;,\r\n                  &quot;preferenceOrder&quot;: 1,\r\n                  &quot;matchID&quot;: &quot;502&quot;\r\n                }\r\n              ],\r\n              &quot;username&quot;: &quot;Arun&quot;,\r\n              &quot;address&quot;: &quot;6166192&quot;,\r\n              &quot;Title&quot;: &quot;Kumar&quot;\r\n            }\r\n          }\r\n        }\r\n\r\n\r\n**Expected Response:**\r\n\r\n\r\n    {\r\n          &quot;errorCode&quot;: null,\r\n          &quot;errorMessage&quot;: null,\r\n          &quot;orderId&quot;: {\r\n            &quot;Order394&quot;: {\r\n              &quot;orderId&quot;: &quot;Order394&quot;,\r\n              &quot;targetRequirements&quot;: [\r\n                {\r\n                  &quot;matchID&quot;: &quot;502&quot;,\r\n                  &quot;preferenceOrder&quot;: 1\r\n                },\r\n                {\r\n                  &quot;matchID&quot;: &quot;503&quot;,\r\n                  &quot;preferenceOrder&quot;: 1\r\n                }\r\n              ]\r\n            },\r\n            &quot;Order395&quot;: {\r\n              &quot;orderId&quot;: &quot;Order395&quot;,\r\n              &quot;targetRequirements&quot;: [\r\n                {\r\n                  &quot;matchID&quot;: &quot;502&quot;,\r\n                  &quot;preferenceOrder&quot;: 1\r\n                }\r\n              ]\r\n            }\r\n          }\r\n        }\r\n\r\n\r\nI tried using the JQ Query given below, however this is creating a LIST of orderId, but i need a map.\r\n\r\n    { errorMessage,errorCode,  orderId :  (.orderId |                               map({    (.orderId) : {   orderId ,          targetRequirements : (.targetRequirements |              map({             preferenceOrder               ,targetID             })            )      }   }) )  }\r\n\r\n\r\n\r\nSample working example can be found at https://jqplay.org/s/exd2QjrS9V\r\n\r\nThanks in advance.\r\nArunkumar ",
        "link": "https://stackoverflow.com/questions/55048439/trying-to-create-a-map-but-ending-with-list-in-jq",
        "title": "Trying to create a Map but ending with List in JQ"
    },
    {
        "tags": [
            "regex",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 18,
                "is_accepted": false,
                "score": 18,
                "last_activity_date": 1551976493,
                "creation_date": 1551976493,
                "answer_id": 55048709,
                "question_id": 55048593,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Oh, just found it after a few more attemps\r\n\r\n    &#39;.taskDefinition.containerDefinitions[].image |= sub(&quot;(?&lt;repo&gt;.*:).*&quot;; &quot;\\(.repo)new&quot;)&#39;",
                "title": "Replacing values in JSON with JQ and regex"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 14,
        "last_activity_date": 1575346090,
        "creation_date": 1551976140,
        "last_edit_date": 1575346090,
        "question_id": 55048593,
        "body_markdown": "I have the following JSON where I want to change the &quot;tag&quot; of the &quot;image&quot; strings.\r\n```\r\n{\r\n  &quot;taskDefinition&quot;: {\r\n    &quot;containerDefinitions&quot;: [\r\n      {\r\n        &quot;name&quot;: &quot;php&quot;,\r\n        &quot;image&quot;: &quot;xxxxxx.dkr.ecr.eu-west-1.amazonaws.com/repo/php:latest&quot;,\r\n        &quot;cpu&quot;: 0,\r\n        &quot;memory&quot;: 512\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;nginx&quot;,\r\n        &quot;image&quot;: &quot;xxxxxx.dkr.ecr.eu-west-1.amazonaws.com/repo/nginx:latest&quot;,\r\n        &quot;cpu&quot;: 0,\r\n        &quot;memory&quot;: 256\r\n      }\r\n    ],\r\n    &quot;family&quot;: &quot;service-be&quot;\r\n  }\r\n}\r\n```\r\nIt should become:\r\n\r\n    {\r\n      &quot;taskDefinition&quot;: {\r\n        &quot;containerDefinitions&quot;: [\r\n          {\r\n            &quot;name&quot;: &quot;php&quot;,\r\n            &quot;image&quot;: &quot;xxxxxx.dkr.ecr.eu-west-1.amazonaws.com/repo/php:new&quot;,\r\n            &quot;cpu&quot;: 0,\r\n            &quot;memory&quot;: 512\r\n          },\r\n          {\r\n            &quot;name&quot;: &quot;nginx&quot;,\r\n            &quot;image&quot;: &quot;xxxxxx.dkr.ecr.eu-west-1.amazonaws.com/repo/nginx:new&quot;,\r\n            &quot;cpu&quot;: 0,\r\n            &quot;memory&quot;: 256\r\n          }\r\n        ],\r\n        &quot;family&quot;: &quot;service-be&quot;\r\n      }\r\n    }\r\n\r\nOf course &quot;latest&quot; can be anything.\r\n\r\nSo far I&#39;ve found the following regex sub to modify the strings.\r\n\r\n    &#39;.taskDefinition.containerDefinitions[].image | sub(&quot;(?&lt;repo&gt;.*:).*&quot;;  \\(.repo)new&quot;)&#39;\r\n\r\nBut I want to edit them in place and keep the whole JSON.\r\nSo far my attempts to change the value were unsuccessful.\r\nI can change the image value to a fixed string but not to the substituted original value.\r\n\r\nI&#39;ve tried several variations of this:\r\n\r\n    &#39;.taskDefinition.containerDefinitions[].image |= . | sub(&quot;(?&lt;repo&gt;.*:).*&quot;; &quot;\\(.repo)new&quot;)&#39;\r\n\r\n \r\nIt seems like the version I can simply use (in Bitbucket pipelines) doesn&#39;t have the walk function, so I&#39;d avoid it.\r\n",
        "link": "https://stackoverflow.com/questions/55048593/replacing-values-in-json-with-jq-and-regex",
        "title": "Replacing values in JSON with JQ and regex"
    },
    {
        "tags": [
            "json",
            "bash",
            "if-statement",
            "while-loop",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 4663062,
                    "reputation": 89888,
                    "user_id": 3776858,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Cagbk.jpg?s=256",
                    "display_name": "Cyrus",
                    "link": "https://stackoverflow.com/users/3776858/cyrus"
                },
                "edited": false,
                "score": 4,
                "creation_date": 1551985760,
                "post_id": 55051099,
                "comment_id": 96852116,
                "content_license": "CC BY-SA 4.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": 1,
                "creation_date": 1551985771,
                "post_id": 55051099,
                "comment_id": 96852126,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 3,
                "creation_date": 1551986335,
                "post_id": 55051099,
                "comment_id": 96852403,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1551986455,
                "post_id": 55051099,
                "comment_id": 96852462,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1551986763,
                "post_id": 55051099,
                "comment_id": 96852612,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1551986247,
                "creation_date": 1551986247,
                "answer_id": 55051286,
                "question_id": 55051099,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It looks like you have a simple typo: you&#39;re outputting the result of the curl as `raw.json` but using `cat returns_raw.json` as the input to your further JQ commands. If you fix the file name in all places, does it start working?",
                "title": "Bash loop won&#39;t stop looping"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1551986247,
        "creation_date": 1551985527,
        "last_edit_date": 1551985648,
        "question_id": 55051099,
        "body_markdown": "I have a JSON blob structured as such:\r\n\r\n    {\r\n        &quot;total_items&quot;: 2371,\r\n        &quot;page_count&quot;: 3,\r\n        &quot;items&quot;: [\r\n            {\r\n                &quot;landing_id&quot;: &quot;503a654cfaf5614b2069de304dbdb3c9&quot;,\r\n                &quot;token&quot;: &quot;503a654cfaf5614b2069de304dbdb3c9&quot;,\r\n                &quot;response_id&quot;: &quot;503a654cfaf5614b2069de304dbdb3c9&quot;,\r\n                &quot;landed_at&quot;: &quot;2019-03-07T18:35:06Z&quot;,\r\n                &quot;submitted_at&quot;: &quot;2019-03-07T18:36:17Z&quot;,\r\n                &quot;metadata&quot;: {\r\n                    &quot;user_agent&quot;: &quot;Mozilla/5.0 (Macintosh; Intel Mac OS X 10_14_2) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/12.0.2 Safari/605.1.15&quot;,\r\n                    &quot;platform&quot;: &quot;other&quot;,\r\n                    &quot;network_id&quot;: &quot;321c8d9867&quot;,\r\n                    &quot;browser&quot;: &quot;default&quot;\r\n                },\r\n                &quot;answers&quot;: [\r\n                    {\r\n                        &quot;field&quot;: {\r\n                            &quot;id&quot;: &quot;uqZV4j2RSapJ&quot;,\r\n                            &quot;type&quot;: &quot;opinion_scale&quot;,\r\n                            &quot;ref&quot;: &quot;bed55d05-b5e2-46dd-af91-337519830e3e&quot;\r\n                        },\r\n                        &quot;type&quot;: &quot;number&quot;,\r\n                        &quot;number&quot;: 5\r\n                    }\r\n                ],\r\n            },\r\n            {\r\n                &quot;landing_id&quot;: &quot;b9d50e6734d30753de42b78a2ad5d741&quot;,\r\n                &quot;token&quot;: &quot;b9d50e6734d30753de42b78a2ad5d741&quot;,\r\n                &quot;response_id&quot;: &quot;b9d50e6734d30753de42b78a2ad5d741&quot;,\r\n                &quot;landed_at&quot;: &quot;2019-03-07T18:12:29Z&quot;,\r\n                &quot;submitted_at&quot;: &quot;2019-03-07T18:13:54Z&quot;,\r\n                &quot;metadata&quot;: {\r\n                    &quot;user_agent&quot;: &quot;Mozilla/5.0 (iPhone; CPU iPhone OS 12_1_4 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/12.0 Mobile/15E148 Safari/604.1&quot;,\r\n                    &quot;platform&quot;: &quot;mobile&quot;,\r\n                    &quot;network_id&quot;: &quot;3a74e2b874&quot;,\r\n                    &quot;browser&quot;: &quot;touch&quot;\r\n                },\r\n                &quot;answers&quot;: [\r\n                    {\r\n                        &quot;field&quot;: {\r\n                            &quot;id&quot;: &quot;uqZV4j2RSapJ&quot;,\r\n                            &quot;type&quot;: &quot;opinion_scale&quot;,\r\n                            &quot;ref&quot;: &quot;bed55d05-b5e2-46dd-af91-337519830e3e&quot;\r\n                        },\r\n                        &quot;type&quot;: &quot;number&quot;,\r\n                        &quot;number&quot;: 1\r\n                    },\r\n                    {\r\n                        &quot;field&quot;: {\r\n                            &quot;id&quot;: &quot;v8nQgm61VdLp&quot;,\r\n                            &quot;type&quot;: &quot;dropdown&quot;,\r\n                            &quot;ref&quot;: &quot;d20b5f19-dc7c-4497-b798-239924054367&quot;\r\n                        },\r\n                        &quot;type&quot;: &quot;text&quot;,\r\n                        &quot;text&quot;: &quot;Inconsistent information&quot;\r\n                    }\r\n                ],\r\n            },\r\n            {\r\n                &quot;landing_id&quot;: &quot;96f601b5769bacf7208b1a9c8c390278&quot;,\r\n                &quot;token&quot;: &quot;96f601b5769bacf7208b1a9c8c390278&quot;,\r\n                &quot;response_id&quot;: &quot;96f601b5769bacf7208b1a9c8c390278&quot;,\r\n                &quot;landed_at&quot;: &quot;2019-03-07T18:09:08Z&quot;,\r\n                &quot;submitted_at&quot;: &quot;2019-03-07T18:09:40Z&quot;,\r\n                &quot;metadata&quot;: {\r\n                    &quot;user_agent&quot;: &quot;Mozilla/5.0 (iPhone; CPU iPhone OS 12_1_4 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/12.0 Mobile/15E148 Safari/604.1&quot;,\r\n                    &quot;platform&quot;: &quot;mobile&quot;,\r\n                    &quot;network_id&quot;: &quot;1c59eb873c&quot;,\r\n                    &quot;browser&quot;: &quot;touch&quot;\r\n                },\r\n                &quot;answers&quot;: [\r\n                    {\r\n                        &quot;field&quot;: {\r\n                            &quot;id&quot;: &quot;uqZV4j2RSapJ&quot;,\r\n                            &quot;type&quot;: &quot;opinion_scale&quot;,\r\n                            &quot;ref&quot;: &quot;bed55d05-b5e2-46dd-af91-337519830e3e&quot;\r\n                        },\r\n                        &quot;type&quot;: &quot;number&quot;,\r\n                        &quot;number&quot;: 5\r\n                    },\r\n                    {\r\n                        &quot;field&quot;: {\r\n                            &quot;id&quot;: &quot;llTPythU272I&quot;,\r\n                            &quot;type&quot;: &quot;multiple_choice&quot;,\r\n                            &quot;ref&quot;: &quot;bf54c521-3749-4c80-93bf-bb5448d03b34&quot;\r\n                        },\r\n                        &quot;type&quot;: &quot;choices&quot;,\r\n                        &quot;choices&quot;: {\r\n                            &quot;labels&quot;: [\r\n                                &quot;Travis&quot;\r\n                            ]\r\n                        }\r\n                    }\r\n                ],\r\n            }\r\n        ]\r\n    }\r\n\r\nI&#39;ve put together a script that looks something like this:\r\n\r\n    curl https://api.xyz.com/forms/Te8Fy9/responses?page_size=1000 -H &#39;Authorization: Bearer xxxxxx&#39; -H &#39;cache-control: no-cache&#39; &gt; raw.json\r\n    \r\n    page_parameter=`cat raw.json | jq -c &#39;.items | last | .token&#39; | tr -d &#39;&quot;&#39;`\r\n    \r\n    items_parameter=`cat raw.json | jq -c &#39;.total_items&#39;`\r\n    \r\n    cat raw.json | jq -c &#39;.items[]&#39; &gt; clean.json\r\n    \r\n    bq load --source_format NEWLINE_DELIMITED_JSON --autodetect bq-test:sandox.test clean.json\r\n    \r\n    while [[ ${#items_parameter} -gt 0 ]]\r\n    do\r\n    \r\n        curl &#39;https://api.xyz.com/forms/Te8Fy9/responses?page_size=1000&amp;after=&#39;${page_parameter} -H &#39;Authorization: Bearer xxxxxx&#39; -H &#39;cache-control: no-cache&#39; &gt; raw.json\r\n            \r\n        page_parameter=`cat returns_raw.json | jq -c &#39;.items | last | .token&#39; | tr -d &#39;&quot;&#39;`\r\n    \r\n    \titems_parameter=`cat returns_raw.json | jq -c &#39;.total_items&#39;`\r\n    \r\n        cat returns_raw.json | jq -c &#39;.items[]&#39; &gt; clean.json\r\n    \r\n        if [[  ${#items_parameter} -gt 0 ]]; then\r\n        \r\n            bq load --source_format NEWLINE_DELIMITED_JSON --autodetect bq-test:sandox.test clean.json\r\n            \r\n        fi\r\n            \r\n    done\r\n\r\nSo what I want it to do is:\r\n\r\n1.) Run the API call (`curl https...`), store as `raw.json`\r\n\r\n2.) Store a specified value, the last value of `token`, as a parameter. In this example that value would be `96f601b5769bacf7208b1a9c8c390278` and stored as `page_parameter`\r\n\r\n3.) Store another specified value, the value associated with `total_items` at the top. In this examople, that value is `2371` and stored as `items_parameter`\r\n\r\n4.) Use `jq -c &#39;.items[]&#39;` to clean `raw.json` and create that as `clean.json`\r\n\r\n5.) Push to BigQuery\r\n\r\n6.) Assuming it&#39;s run correctly, it should produce an `items_parameter` greater than 0, which if that&#39;s the case, take the value of `page_parameter` to iterate through the subsuqent `curl` command to pull the next 1000 records\r\n\r\n7.) Repeat step #2 (`page_parameter`), step #3 (`items_parameter`), and step #4 (clean `raw.json` and save as `clean.json`)\r\n\r\n8.) IF the `items_parameter` value is greater than 0, THEN load it to BigQuery\r\n\r\nSo the hope is that it would do that until that value equals 0, in which point, it would break out of the loop. But it&#39;s not doing that. It just continuously iterates over the same records. \r\n\r\nIn theory, it should run three different cycles of records which are loaded: 1 - 1000, 1001 - 2000, 2001-2371, and then break it off.\r\n\r\nWhat am I missing? I think I&#39;m pretty close and likely just doing something obviously wrong.\r\n",
        "link": "https://stackoverflow.com/questions/55051099/bash-loop-wont-stop-looping",
        "title": "Bash loop won&#39;t stop looping"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1552017071,
                "creation_date": 1552017071,
                "answer_id": 55056455,
                "question_id": 55052429,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using the following command:\r\n\r\n    jq -s &#39;\r\n    def merge:\r\n     {&quot;protocol&quot;: .[0].protocol,\r\n      &quot;port&quot;: .[0].port,\r\n      &quot;name&quot;: .[0].name,\r\n      &quot;stubs&quot;: (reduce .[].stubs as $item ([]; . + $item) | unique)};\r\n    [[.[].imposters[]] | group_by(.port) | .[] | merge] |\r\n    {&quot;imposters&quot;: .}&#39; a.json\r\n\r\nThis type of output can be generated:\r\n\r\n    {\r\n      &quot;imposters&quot;: [\r\n        {\r\n          &quot;protocol&quot;: &quot;http&quot;,\r\n          &quot;port&quot;: 9000,\r\n          &quot;name&quot;: &quot;sanc&quot;,\r\n          &quot;stubs&quot;: []\r\n        },\r\n        {\r\n          &quot;protocol&quot;: &quot;http&quot;,\r\n          &quot;port&quot;: 9001,\r\n          &quot;name&quot;: &quot;sanp&quot;,\r\n          &quot;stubs&quot;: [\r\n            {\r\n              &quot;predicates&quot;: [\r\n                {\r\n                  &quot;deepEquals&quot;: {\r\n                    &quot;path&quot;: &quot;/pay/5&quot;\r\n                  }\r\n                }\r\n              ],\r\n              &quot;responses&quot;: [\r\n                {\r\n                  &quot;is&quot;: {\r\n                    &quot;statusCode&quot;: 200,\r\n                    &quot;body&quot;: &quot;H4sIAAAAAAAAA6quBQAAAP//AwBDv6ajAgAAAA==&quot;\r\n                  }\r\n                }\r\n              ]\r\n            },\r\n            {\r\n              &quot;predicates&quot;: [\r\n                {\r\n                  &quot;deepEquals&quot;: {\r\n                    &quot;path&quot;: &quot;/pay/resources&quot;\r\n                  }\r\n                }\r\n              ],\r\n              &quot;responses&quot;: [\r\n                {\r\n                  &quot;is&quot;: {\r\n                    &quot;statusCode&quot;: 200,\r\n                    &quot;body&quot;: &quot;H4sIAAAAAAAAA4yRQYvCMBCF=&quot;\r\n                  }\r\n                }\r\n              ]\r\n            },\r\n            {\r\n              &quot;predicates&quot;: [\r\n                {\r\n                  &quot;deepEquals&quot;: {\r\n                    &quot;path&quot;: &quot;/user/access/pilot&quot;\r\n                  }\r\n                }\r\n              ],\r\n              &quot;responses&quot;: [\r\n                {\r\n                  &quot;is&quot;: {\r\n                    &quot;statusCode&quot;: 200,\r\n                    &quot;body&quot;: &quot;H4sIAAAAAAAAA6quBQAAAP//AwBDv6ajAgAAAA==&quot;\r\n                  }\r\n                }\r\n              ]\r\n            },\r\n            {\r\n              &quot;predicates&quot;: [\r\n                {\r\n                  &quot;deepEquals&quot;: {\r\n                    &quot;path&quot;: &quot;/user/access/resources&quot;\r\n                  }\r\n                }\r\n              ],\r\n              &quot;responses&quot;: [\r\n                {\r\n                  &quot;is&quot;: {\r\n                    &quot;statusCode&quot;: 200,\r\n                    &quot;body&quot;: &quot;H4sIAAAAAAAAA4yRQYvCMBCF=&quot;\r\n                  }\r\n                }\r\n              ]\r\n            }\r\n          ]\r\n        }\r\n      ]\r\n    }\r\n\r\n",
                "title": "JQ: Merging deep data"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1552017071,
        "creation_date": 1551991106,
        "question_id": 55052429,
        "body_markdown": "How can I merge the data in `stubs[]` matched by `port` property.\r\n\r\n```\r\n{\r\n  &quot;imposters&quot;: [\r\n    {\r\n      &quot;protocol&quot;: &quot;http&quot;,\r\n      &quot;port&quot;: 9000,\r\n      &quot;name&quot;: &quot;sanc&quot;,\r\n      &quot;stubs&quot;: []\r\n    },\r\n    {\r\n      &quot;protocol&quot;: &quot;http&quot;,\r\n      &quot;port&quot;: 9001,\r\n      &quot;name&quot;: &quot;sanp&quot;,\r\n      &quot;stubs&quot;: [\r\n        {\r\n          &quot;predicates&quot;: [\r\n            {\r\n              &quot;deepEquals&quot;: {\r\n                &quot;path&quot;: &quot;/user/access/resources&quot;\r\n              }\r\n            }\r\n          ],\r\n          &quot;responses&quot;: [\r\n            {\r\n              &quot;is&quot;: {\r\n                &quot;statusCode&quot;: 200,\r\n                &quot;body&quot;: &quot;H4sIAAAAAAAAA4yRQYvCMBCF=&quot;\r\n              }\r\n            }\r\n          ]\r\n        },\r\n        {\r\n          &quot;predicates&quot;: [\r\n            {\r\n              &quot;deepEquals&quot;: {\r\n                &quot;path&quot;: &quot;/user/access/pilot&quot;\r\n              }\r\n            }\r\n          ],\r\n          &quot;responses&quot;: [\r\n            {\r\n              &quot;is&quot;: {\r\n                &quot;statusCode&quot;: 200,\r\n                &quot;body&quot;: &quot;H4sIAAAAAAAAA6quBQAAAP//AwBDv6ajAgAAAA==&quot;\r\n              }\r\n            }\r\n          ]\r\n        }\r\n      ]\r\n    }\r\n  ]\r\n}\r\n\r\n\r\n\r\n\r\n\r\n\r\n{\r\n  &quot;imposters&quot;: [\r\n    {\r\n      &quot;protocol&quot;: &quot;http&quot;,\r\n      &quot;port&quot;: 9000,\r\n      &quot;name&quot;: &quot;sanc&quot;,\r\n      &quot;stubs&quot;: []\r\n    },\r\n    {\r\n      &quot;protocol&quot;: &quot;http&quot;,\r\n      &quot;port&quot;: 9001,\r\n      &quot;name&quot;: &quot;sanp&quot;,\r\n      &quot;stubs&quot;: [\r\n        {\r\n          &quot;predicates&quot;: [\r\n            {\r\n              &quot;deepEquals&quot;: {\r\n                &quot;path&quot;: &quot;/pay/resources&quot;\r\n              }\r\n            }\r\n          ],\r\n          &quot;responses&quot;: [\r\n            {\r\n              &quot;is&quot;: {\r\n                &quot;statusCode&quot;: 200,\r\n                &quot;body&quot;: &quot;H4sIAAAAAAAAA4yRQYvCMBCF=&quot;\r\n              }\r\n            }\r\n          ]\r\n        },\r\n        {\r\n          &quot;predicates&quot;: [\r\n            {\r\n              &quot;deepEquals&quot;: {\r\n                &quot;path&quot;: &quot;/pay/5&quot;\r\n              }\r\n            }\r\n          ],\r\n          &quot;responses&quot;: [\r\n            {\r\n              &quot;is&quot;: {\r\n                &quot;statusCode&quot;: 200,\r\n                &quot;body&quot;: &quot;H4sIAAAAAAAAA6quBQAAAP//AwBDv6ajAgAAAA==&quot;\r\n              }\r\n            }\r\n          ]\r\n        }\r\n      ]\r\n    }\r\n  ]\r\n}\r\n```",
        "link": "https://stackoverflow.com/questions/55052429/jq-merging-deep-data",
        "title": "JQ: Merging deep data"
    },
    {
        "tags": [
            "json",
            "group-by",
            "aggregate",
            "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": 1551992838,
                "post_id": 55052588,
                "comment_id": 96855440,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1551993723,
                "creation_date": 1551993723,
                "answer_id": 55052984,
                "question_id": 55052588,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "After fixing the JSON, the following filter produces the output as shown below:\r\n\r\n    group_by(.ItemID)\r\n    | map( reduce .[] as $x ( .[0] | {ItemID};\r\n             .Price += ($x | {(.Size|tostring): .Price}) ) )\r\n\r\n\r\nOutput:\r\n\r\n    [\r\n      {\r\n        &quot;ItemID&quot;: 1,\r\n        &quot;Price&quot;: {\r\n          &quot;10&quot;: 5,\r\n          &quot;11&quot;: 7,\r\n          &quot;12&quot;: 10\r\n        }\r\n      },\r\n      {\r\n        &quot;ItemID&quot;: 2,\r\n        &quot;Price&quot;: {\r\n          &quot;11&quot;: 15,\r\n          &quot;12&quot;: 20\r\n        }\r\n      }\r\n    ]\r\n",
                "title": "jq filter to aggregate into an object&#39;s property"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1551997445,
        "creation_date": 1551991808,
        "last_edit_date": 1551997445,
        "question_id": 55052588,
        "body_markdown": "I need to transform JSON to update a firebase firestore.\r\n\r\nMy incoming json looks like this:\r\n\r\n    [{\r\n\t\t&quot;ItemID&quot;: 1,\r\n\t\t&quot;Size&quot;: 10,\r\n\t\t&quot;Price&quot;: 5\r\n\t},\r\n\t{\r\n\t\t&quot;ItemID&quot;: 1,\r\n\t\t&quot;Size&quot;: 11,\r\n\t\t&quot;Price&quot;: 7\r\n\t},\r\n\t{\r\n\t\t&quot;ItemID&quot;: 1,\r\n\t\t&quot;Size&quot;: 12,\r\n\t\t&quot;Price&quot;: 10\r\n\t},\r\n\t{\r\n\t\t&quot;ItemID&quot;: 2,\r\n\t\t&quot;Size&quot;: 11,\r\n\t\t&quot;Price&quot;: 15\r\n\t},\r\n\t{\r\n\t\t&quot;ItemID&quot;: 2,\r\n\t\t&quot;Size&quot;: 12,\r\n\t\t&quot;Price&quot;: 20\r\n\t}]\r\n\r\nAnd I need JSON to look like this:\r\n\r\n    [{\r\n\t\t&quot;ItemID&quot;: 1,\r\n\t\t&quot;Price&quot;: {\r\n\t\t\t&quot;10&quot;: 5,\r\n\t\t\t&quot;11&quot;: 7,\r\n\t\t\t&quot;12&quot;: 10\r\n\t\t}\r\n\t},\r\n\t{\r\n\t\t&quot;ItemID&quot;: 2,\r\n\t\t&quot;Price&quot;: {\r\n\t\t\t&quot;11&quot;: 15,\r\n\t\t\t&quot;12&quot;: 20\r\n\t\t}\r\n\t}]\r\n\r\nWhat jq filter do I need to do that please?\r\n\r\nMy other alternatives are to loop through it in javascript, however I want to make this extendable so the pattern can be added, saved and run.\r\n\r\nMy other alternative is not to store values as keys, to do something like:\r\n\r\n    [\r\n      {\r\n        &quot;ItemID&quot;:1,\r\n        &quot;Prices&quot;:[\r\n          {&quot;Size&quot;:10, &quot;Price&quot;:5}\r\n        ]\r\n      }\r\n    ]",
        "link": "https://stackoverflow.com/questions/55052588/jq-filter-to-aggregate-into-an-objects-property",
        "title": "jq filter to aggregate into an object&#39;s property"
    },
    {
        "tags": [
            "curl",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6929975,
                    "reputation": 2562,
                    "user_id": 5319738,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/33be75bf8acd83e41411d134106c8811?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Kamal",
                    "link": "https://stackoverflow.com/users/5319738/kamal"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1552022012,
                "post_id": 55052690,
                "comment_id": 96862932,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 15480171,
                    "reputation": 1,
                    "user_id": 11167719,
                    "user_type": "registered",
                    "profile_image": "https://lh4.googleusercontent.com/-_TdQ5cQxcjY/AAAAAAAAAAI/AAAAAAAAAAA/ACHi3reGUOWXFJNUWSN-DWDO6vOV43Quxg/mo/s256-rj/photo.jpg",
                    "display_name": "MrShawn",
                    "link": "https://stackoverflow.com/users/11167719/mrshawn"
                },
                "reply_to_user": {
                    "account_id": 6929975,
                    "reputation": 2562,
                    "user_id": 5319738,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/33be75bf8acd83e41411d134106c8811?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Kamal",
                    "link": "https://stackoverflow.com/users/5319738/kamal"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1552049050,
                "post_id": 55052690,
                "comment_id": 96874892,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1663588630,
                "post_id": 55052690,
                "comment_id": 130267811,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 0,
        "last_activity_date": 1551992286,
        "creation_date": 1551992286,
        "question_id": 55052690,
        "body_markdown": "I am basically running this command:\r\n\r\n    curl --request POST --form &quot;file=@tag.txt&quot; https://gitlab.com/api/v4/projects/:id/uploads?private_token=&lt;myToken&gt; | jq .markdown\r\n\r\nThe response I get from the curl looks like this: \r\n\r\n    {&quot;alt&quot;:&quot;tag.txt&quot;,&quot;url&quot;:&quot;/uploads/16467a94cf5ea64f4b4541105d03ceaf/tag.txt&quot;,&quot;markdown&quot;:&quot;[tag.txt](/uploads/16467a94cf5ea64f4b4541105d03ceaf/tag.txt)&quot;}\r\n\r\nI am basically able to run this on a normal GET request - however when I try to jq on this response it fails with the follow error:\r\n\r\n**jq: error: syntax error, unexpected INVALID_CHARACTER, expecting $end (Windows cmd shell quoting issues?) at &lt;top-level&gt;, line 1:**\r\n\r\nAny help is appreciated I am calling these in cmd.exe in windows 7.  I also tried adding &#39;.&#39; but still have the same issue.\r\n\r\n-MrShawn",
        "link": "https://stackoverflow.com/questions/55052690/windows-cmd-jq-on-a-curl-response-not-working",
        "title": "Windows cmd jq on a curl response not working"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1552073848,
                "last_edit_date": 1552073848,
                "creation_date": 1552042633,
                "answer_id": 55061756,
                "question_id": 55060292,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "In short, no. The shortcut syntax can only be used under very special conditions. For example, it cannot be used with key names that are jq [keywords][1].\r\n\r\n## Alternatives\r\n\r\nThe method described in the Q is the preferred one, but for the record, here are two alternatives:\r\n\r\n    jq --arg myarg &quot;foo&quot; &#39;\r\n      .[$myarg] as $v | {} | .[$myarg] = $v&#39;\r\n\r\nAnd of course there&#39;s the alternative that comes with numerous caveats:\r\n\r\n    myarg=foo ; jq &quot;{ $myarg }&quot;\r\n\r\n\r\n  [1]: https://github.com/stedolan/jq/wiki/How-to:-Avoid-Pitfalls#keywords",
                "title": "Get field from JSON object using jq and command line argument"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1552073848,
        "creation_date": 1552037512,
        "last_edit_date": 1592644375,
        "question_id": 55060292,
        "body_markdown": "Assume the following JSON file\n\n    { \n       &quot;foo&quot;: &quot;hello&quot;,\n       &quot;bar&quot;: &quot;world&quot;\n    }\n\nI want to get the `foo` field from the JSON object in a standalone object, and I do this:\n\n    &lt;file jq &#39;{foo}&#39;\n    {\n       &quot;foo&quot;: &quot;hello&quot;\n    }\n\nNow the field I actually want is coming from the shell and is given to `jq` as an argument like this:\n\n    &lt;file jq --arg myarg &quot;foo&quot; &#39;{$myarg}&#39;\n    {\n       &quot;myarg&quot;: &quot;foo&quot;\n    }\n\nUnfortunately this doesn&#39;t give the expected result `{&quot;foo&quot;:&quot;hello&quot;}`. \nAny idea why the name of the variable gets into the object? \n\nA workaround to this is to explicitly defined the object:\n\n    &lt;file jq &#39;{($myarg):.[$myarg]}&#39;\n\nFine, but is there a way to use the shortcut syntax as explained in the man page, but with a variable ?\n\n&gt;You can use this to select particular fields of an object: if the input is an object with “user”, “title”, “id”, and “content” fields and you just want “user” and “title”, you can write\n&gt;\n&gt; `{user: .user, title: .title}`\n&gt;\n&gt;Because that is so common, there’s a shortcut syntax for it: `{user, title}`.\n\n_If that matters, I&#39;m using jq version 1.5_",
        "link": "https://stackoverflow.com/questions/55060292/get-field-from-json-object-using-jq-and-command-line-argument",
        "title": "Get field from JSON object using jq and command line argument"
    },
    {
        "tags": [
            "json",
            "ubuntu",
            "sed",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1020072,
                    "reputation": 243994,
                    "user_id": 1030675,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/957956ce51706d03f19a4dc85a767bb1?s=256&d=identicon&r=PG",
                    "display_name": "choroba",
                    "link": "https://stackoverflow.com/users/1030675/choroba"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1552041753,
                "post_id": 55061437,
                "comment_id": 96871024,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 10414452,
                    "reputation": 21,
                    "user_id": 7678969,
                    "user_type": "registered",
                    "profile_image": "https://lh5.googleusercontent.com/-h5uOoFpiDAE/AAAAAAAAAAI/AAAAAAAAABE/ryAgyj5o6f4/s256-rj/photo.jpg",
                    "display_name": "Vageesh S M",
                    "link": "https://stackoverflow.com/users/7678969/vageesh-s-m"
                },
                "reply_to_user": {
                    "account_id": 1020072,
                    "reputation": 243994,
                    "user_id": 1030675,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/957956ce51706d03f19a4dc85a767bb1?s=256&d=identicon&r=PG",
                    "display_name": "choroba",
                    "link": "https://stackoverflow.com/users/1030675/choroba"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1552042136,
                "post_id": 55061437,
                "comment_id": 96871218,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 57200,
                    "reputation": 158728,
                    "user_id": 171318,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/ePRKy.jpg?s=256",
                    "display_name": "hek2mgl",
                    "link": "https://stackoverflow.com/users/171318/hek2mgl"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1552042356,
                "post_id": 55061437,
                "comment_id": 96871333,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1552116827,
                "last_edit_date": 1552116827,
                "creation_date": 1552042534,
                "answer_id": 55061716,
                "question_id": 55061437,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Let&#39;s say you have this file.json:\r\n\r\n    {\r\n      &quot;name&quot;: &quot;foo&quot;,\r\n      &quot;regex_features&quot;: [\r\n        [\r\n          {\r\n            &quot;name&quot;: &quot;jobname&quot;,\r\n            &quot;pattern&quot;: &quot;[A-Z]+-[0-9]&quot;\r\n          },\r\n          {\r\n            &quot;name&quot;: &quot;project&quot;,\r\n            &quot;pattern&quot;: &quot;[A-Z]{4}&quot;\r\n          }\r\n        ]\r\n      ]\r\n    }\r\n\r\nYou can use the update assignment operator to replace the list by its first element (which is the inner list):\r\n\r\n    jq &#39;.regex_features|=.[0]&#39; file.json\r\n\r\nOutput:\r\n\r\n    {\r\n      &quot;name&quot;: &quot;foo&quot;,\r\n      &quot;regex_features&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;jobname&quot;,\r\n          &quot;pattern&quot;: &quot;[A-Z]+-[0-9]&quot;\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;project&quot;,\r\n          &quot;pattern&quot;: &quot;[A-Z]{4}&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\n\r\n",
                "title": "how to remove square brackets from particular place in json file in linux using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1552154495,
        "creation_date": 1552041611,
        "last_edit_date": 1552071901,
        "question_id": 55061437,
        "body_markdown": "i want to remove square brackets as illustrated in this example: \r\n\r\n\r\nInput file : file1.json\r\n\r\n    { &quot;regex_features&quot;: [\r\n          [ // This bracket needs to be removed\r\n            {\r\n              &quot;name&quot;: &quot;jobname&quot;,\r\n              &quot;pattern&quot;: &quot;[A-Z]+-[0-9]&quot;\r\n            },\r\n            {\r\n              &quot;name&quot;: &quot;project&quot;,\r\n              &quot;pattern&quot;: &quot;[A-Z]{4}&quot;\r\n            },\r\n            {\r\n              &quot;name&quot;: &quot;summary&quot;,\r\n              &quot;pattern&quot;: &quot;[a-z]+[a-z]+[a-z]{4}&quot;\r\n            },\r\n            {\r\n              &quot;name&quot;: &quot;description&quot;,\r\n              &quot;pattern&quot;: &quot;[a-z]+[a-z]+[a-z]+[a-z]{4}&quot;\r\n            }\r\n          ] // this bracket needs to be removed. \r\n         ]\r\n    }\r\n\r\nplease suggest. ",
        "link": "https://stackoverflow.com/questions/55061437/how-to-remove-square-brackets-from-particular-place-in-json-file-in-linux-using",
        "title": "how to remove square brackets from particular place in json file in linux using jq"
    },
    {
        "tags": [
            "bash",
            "shell",
            "awk",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 69266,
                    "reputation": 12562,
                    "user_id": 201657,
                    "user_type": "registered",
                    "accept_rate": 62,
                    "profile_image": "https://i.sstatic.net/Tsj9N.jpg?s=256",
                    "display_name": "jamiet",
                    "link": "https://stackoverflow.com/users/201657/jamiet"
                },
                "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": 1552070587,
                "post_id": 55069082,
                "comment_id": 96885786,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1143565,
                    "reputation": 535973,
                    "user_id": 1126841,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa05233b2357f8d11c22ef4cfc7bb85c?s=256&d=identicon&r=PG",
                    "display_name": "chepner",
                    "link": "https://stackoverflow.com/users/1126841/chepner"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1552070626,
                "post_id": 55069082,
                "comment_id": 96885806,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 69266,
                    "reputation": 12562,
                    "user_id": 201657,
                    "user_type": "registered",
                    "accept_rate": 62,
                    "profile_image": "https://i.sstatic.net/Tsj9N.jpg?s=256",
                    "display_name": "jamiet",
                    "link": "https://stackoverflow.com/users/201657/jamiet"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1552070641,
                "post_id": 55069082,
                "comment_id": 96885812,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 69266,
                    "reputation": 12562,
                    "user_id": 201657,
                    "user_type": "registered",
                    "accept_rate": 62,
                    "profile_image": "https://i.sstatic.net/Tsj9N.jpg?s=256",
                    "display_name": "jamiet",
                    "link": "https://stackoverflow.com/users/201657/jamiet"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1552071013,
                "post_id": 55069082,
                "comment_id": 96886015,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 12662798,
                    "reputation": 11150,
                    "user_id": 9203110,
                    "user_type": "registered",
                    "profile_image": "https://lh4.googleusercontent.com/-PQESrk-PCHA/AAAAAAAAAAI/AAAAAAAAAJk/6bqvsnrh4Dg/s256-rj/photo.jpg",
                    "display_name": "match",
                    "link": "https://stackoverflow.com/users/9203110/match"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1552071093,
                "post_id": 55069082,
                "comment_id": 96886061,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 69266,
                    "reputation": 12562,
                    "user_id": 201657,
                    "user_type": "registered",
                    "accept_rate": 62,
                    "profile_image": "https://i.sstatic.net/Tsj9N.jpg?s=256",
                    "display_name": "jamiet",
                    "link": "https://stackoverflow.com/users/201657/jamiet"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1552071290,
                "post_id": 55069082,
                "comment_id": 96886152,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 69266,
                    "reputation": 12562,
                    "user_id": 201657,
                    "user_type": "registered",
                    "accept_rate": 62,
                    "profile_image": "https://i.sstatic.net/Tsj9N.jpg?s=256",
                    "display_name": "jamiet",
                    "link": "https://stackoverflow.com/users/201657/jamiet"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1552071529,
                "post_id": 55069082,
                "comment_id": 96886262,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1552073327,
                "last_edit_date": 1552073327,
                "creation_date": 1552072127,
                "answer_id": 55069508,
                "question_id": 55069082,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can do it all in `awk` using `gsub` and `sprintf`, for example:\r\n\r\n**(edit to add `&quot;,&quot;` separating json records)**\r\n\r\n    awk &#39;BEGIN {ol=0; print &quot;{&quot; } \r\n    /^[^#]/ { \r\n        if (ol) print &quot;,&quot;\r\n        gsub (&quot;\\047&quot;, &quot;\\042&quot;)\r\n        $1 = sprintf (&quot;  \\&quot;%s\\&quot;:&quot;, substr ($1, 1, length ($1) - 1))\r\n        printf &quot;%s %s&quot;, $1, $2\r\n        ol++ \r\n    } \r\n    END { print &quot;\\n}&quot; }&#39; file.yaml\r\n\r\n(**note:** though `jq` is the proper tool for json formatting)\r\n\r\n**Explanation**\r\n\r\n * `awk &#39;BEGIN { ol=0; print &quot;{&quot; }` call `awk` setting the *output line* variable `ol=0` for `&quot;,&quot;` output control and printing the header `&quot;{&quot;`,\r\n * `/^[^#]/ {` only match non-comment lines,\r\n * `if (ol) print &quot;,&quot;` if the output line `ol` is greater than zero, output a trailing `&quot;,&quot;`\r\n * `gsub (&quot;\\047&quot;, &quot;\\042&quot;)` replace all single-quotes with double-quotes,\r\n * `$1 = sprintf (&quot;  \\&quot;%s\\&quot;:&quot;, substr ($1, 1, length ($1) - 1))` add 2 leading spaces and double-quotes around the first field (except for the last character) and then append a `&#39;:&#39;` at the end.\r\n * `print $1, $2` output the reformatted fields,\r\n * `ol++` increment the output line count, and\r\n * `END { print &quot;}&quot; }&#39;` close by printing the `&quot;}&quot;` footer\r\n\r\n**Example Use/Output**\r\n\r\nJust select/paste the `awk` command above (changing the filename as needed)\r\n\r\n    $ awk &#39;BEGIN {ol=0; print &quot;{&quot; }\r\n    &gt; /^[^#]/ {\r\n    &gt;     if (ol) print &quot;,&quot;\r\n    &gt;     gsub (&quot;\\047&quot;, &quot;\\042&quot;)\r\n    &gt;     $1 = sprintf (&quot;  \\&quot;%s\\&quot;:&quot;, substr ($1, 1, length ($1) - 1))\r\n    &gt;     printf &quot;%s %s&quot;, $1, $2\r\n    &gt;     ol++\r\n    &gt; }\r\n    &gt; END { print &quot;\\n}&quot; }&#39; file.yaml\r\n    {\r\n      &quot;spark:spark.ui.enabled&quot;: &quot;false&quot;,\r\n      &quot;spark:spark.sql.adaptive.enabled&quot;: &quot;true&quot;\r\n    }\r\n",
                "title": "Convert a key:value file w/ comments into JSON document with UNIX tools"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1552188603,
                "last_edit_date": 1552188603,
                "creation_date": 1552072136,
                "answer_id": 55069511,
                "question_id": 55069082,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Implemented in pure `jq` (tested with version 1.6):\r\n\r\n```\r\n#!/usr/bin/env bash\r\n\r\njq_script=$(cat &lt;&lt;&#39;EOF&#39;\r\ndef content_for_line:\r\n  &quot;^[[:space:]]*([#]|$)&quot; as $ignore_re |           # regex for comments, blank lines\r\n  &quot;^(?&lt;key&gt;.*): (?&lt;value&gt;.*)$&quot; as $content_re |    # regex for actual k/v pairs\r\n  &quot;^&#39;(?&lt;value&gt;.*)&#39;$&quot; as $quoted_re |               # regex for values in single quotes\r\n  if test($ignore_re) then {} else                 # empty lines add nothing to the data\r\n    if test($content_re) then (                    # non-empty: match against $content_re\r\n      capture($content_re) as $content |           # ...and put the groups into $content\r\n      $content.key as $key |                       # string before &quot;: &quot; becomes $key\r\n      (if ($content.value | test($quoted_re)) then # if value contains literal quotes...\r\n         ($content.value | capture($quoted_re)).value # ...take string from inside quotes\r\n       else\r\n         $content.value                               # no quotes to strip\r\n       end) as $value |                     # result of the above block becomes $value\r\n      {&quot;\\($key)&quot;: &quot;\\($value)&quot;}              # and return a map from one key to one value\r\n    ) else\r\n      # we get here if a line didn&#39;t match $ignore_re *or* $content_re\r\n      error(&quot;Line \\(.) is not recognized as a comment, empty, or valid content&quot;)\r\n    end\r\n  end;\r\n\r\n# iterate over our input lines, passing each one to content_for_line and merging the result\r\n# into the object we&#39;re building, which we eventually return as our result.\r\nreduce inputs as $item ({}; . + ($item | content_for_line))\r\nEOF\r\n)\r\n\r\n# jq -R: read input as raw strings\r\n# jq -n: don&#39;t read from stdin until requested with &quot;input&quot; or &quot;inputs&quot;\r\njq -Rn &quot;$jq_script&quot; &lt;file.yaml &gt;file.json\r\n```\r\n\r\nUnlike syntax-unaware tools, this can *never* generate output that isn&#39;t valid JSON; and it can easily be extended with application-specific logic (f/e, to emit some values but not others as numeric literals rather than string literals) by adding an additional filter stage to inspect and modify the output of `content_for_line`.",
                "title": "Convert a key:value file w/ comments into JSON document with UNIX tools"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1552091696,
                "creation_date": 1552091696,
                "answer_id": 55072838,
                "question_id": 55069082,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a no-frills but simple solution:\r\n\r\n\r\n    def tidy: sub(&quot;^ *&#39;?&quot;;&quot;&quot;) | sub(&quot; *&#39;?$&quot;;&quot;&quot;);\r\n    def kv: split(&quot;:&quot;) | [ (.[:-1] | join(&quot;:&quot;)), (.[-1]|tidy)];\r\n    \r\n    reduce (inputs| select( test(&quot;^ *#|^ *$&quot;)|not) | kv) as $row ({};\r\n    \t.[$row[0]] = $row[1] )\r\n\r\n\r\n### Invocation\r\n\r\n    jq -n -R -f tojson.jq input.txt\r\n",
                "title": "Convert a key:value file w/ comments into JSON document with UNIX tools"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1552188603,
        "creation_date": 1552070090,
        "last_edit_date": 1552088842,
        "question_id": 55069082,
        "body_markdown": "I have a file in a subset of YAML with data such as the below:\r\n\r\n```\r\n# This is a comment\r\n# This is another comment\r\n\r\n\r\nspark:spark.ui.enabled: &#39;false&#39;\r\nspark:spark.sql.adaptive.enabled: &#39;true&#39;\r\nyarn:yarn.nodemanager.log.retain-seconds: &#39;259200&#39;\r\n\r\n\r\n```\r\n\r\nI need to convert that into a JSON document looking like this (note that strings containing booleans and integers still remain strings):\r\n\r\n```json\r\n{\r\n  &quot;spark:spark.ui.enabled&quot;: &quot;false&quot;,\r\n  &quot;spark:spark.sql.adaptive.enabled&quot;: &quot;true&quot;,\r\n  &quot;yarn:yarn.nodemanager.log.retain-seconds&quot;, &quot;259200&quot;\r\n}\r\n```\r\n\r\nThe closest I got was this:\r\n\r\n```\r\ncat &lt;&lt; EOF &gt; ./file.yaml\r\n&gt; # This is a comment\r\n&gt; # This is another comment\r\n&gt; \r\n&gt; \r\n&gt; spark:spark.ui.enabled: &#39;false&#39;\r\n&gt; spark:spark.sql.adaptive.enabled: &#39;true&#39;\r\n&gt; yarn:yarn.nodemanager.log.retain-seconds: &#39;259200&#39;\r\n&gt; EOF\r\necho {$(cat file.yaml | grep -o &#39;^[^#]*&#39; | sed &#39;/^$/d&#39; | awk -F&quot;: &quot; &#39;{sub($1, &quot;\\&quot;&amp;\\&quot;&quot;); print}&#39; | paste -sd &quot;,&quot; -  )}\r\n```\r\n\r\nwhich apart from looking rather gnarly doesn&#39;t give the correct answer, it returns:\r\n\r\n```\r\n{&quot;spark:spark.ui.enabled&quot;: &#39;false&#39;,&quot;spark:spark.sql.adaptive.enabled&quot;: &#39;true&#39;,&quot;dataproc:dataproc.monitoring.stackdriver.enable&quot;: &#39;true&#39;,&quot;spark:spark.submit.deployMode&quot;: &#39;cluster&#39;}\r\n```\r\n\r\nwhich, if I pipe to `jq` causes a parse error.\r\n\r\n\r\nI&#39;m hoping I&#39;m missing a much much easier way of doing this but I can&#39;t figure it out. Can anyone help?",
        "link": "https://stackoverflow.com/questions/55069082/convert-a-keyvalue-file-w-comments-into-json-document-with-unix-tools",
        "title": "Convert a key:value file w/ comments into JSON document with UNIX tools"
    },
    {
        "tags": [
            "batch-file",
            "curl",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1066600,
                    "reputation": 22163,
                    "user_id": 1067003,
                    "user_type": "registered",
                    "accept_rate": 62,
                    "profile_image": "https://www.gravatar.com/avatar/e3af2bd4b5604b0b661b5e6646544eba?s=256&d=identicon&r=PG",
                    "display_name": "hanshenrik",
                    "link": "https://stackoverflow.com/users/1067003/hanshenrik"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1552208736,
                "post_id": 55085812,
                "comment_id": 96917266,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 11340281,
                    "reputation": 29,
                    "user_id": 8314613,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/714b3e914b0dde74163e2b2b35dff90d?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Ori Shalhno",
                    "link": "https://stackoverflow.com/users/8314613/ori-shalhno"
                },
                "reply_to_user": {
                    "account_id": 1066600,
                    "reputation": 22163,
                    "user_id": 1067003,
                    "user_type": "registered",
                    "accept_rate": 62,
                    "profile_image": "https://www.gravatar.com/avatar/e3af2bd4b5604b0b661b5e6646544eba?s=256&d=identicon&r=PG",
                    "display_name": "hanshenrik",
                    "link": "https://stackoverflow.com/users/1067003/hanshenrik"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1552210067,
                "post_id": 55085812,
                "comment_id": 96917546,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 11340281,
                    "reputation": 29,
                    "user_id": 8314613,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/714b3e914b0dde74163e2b2b35dff90d?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Ori Shalhno",
                    "link": "https://stackoverflow.com/users/8314613/ori-shalhno"
                },
                "reply_to_user": {
                    "account_id": 9045527,
                    "reputation": 38872,
                    "user_id": 6738015,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/FYDxX.jpg?s=256",
                    "display_name": "Compo",
                    "link": "https://stackoverflow.com/users/6738015/compo"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1552215460,
                "post_id": 55085812,
                "comment_id": 96918859,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 11340281,
                    "reputation": 29,
                    "user_id": 8314613,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/714b3e914b0dde74163e2b2b35dff90d?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Ori Shalhno",
                    "link": "https://stackoverflow.com/users/8314613/ori-shalhno"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1552219133,
                "post_id": 55085812,
                "comment_id": 96919745,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 11340281,
                    "reputation": 29,
                    "user_id": 8314613,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/714b3e914b0dde74163e2b2b35dff90d?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Ori Shalhno",
                    "link": "https://stackoverflow.com/users/8314613/ori-shalhno"
                },
                "reply_to_user": {
                    "account_id": 9045527,
                    "reputation": 38872,
                    "user_id": 6738015,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/FYDxX.jpg?s=256",
                    "display_name": "Compo",
                    "link": "https://stackoverflow.com/users/6738015/compo"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1552220529,
                "post_id": 55085812,
                "comment_id": 96920127,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1552221429,
                "last_edit_date": 1552221429,
                "creation_date": 1552221072,
                "answer_id": 55087699,
                "question_id": 55085812,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&lt;!-- language-all: lang-bat --&gt;You should be able to use a `For /F` command in a batch file to return the output of a command to a variable:\r\n\r\n    For /F &quot;Delims=&quot; %%A In (&#39;&quot;curl -s  http://&lt;jenkins_url&gt;/job/&lt;job_name&gt;/lastCompletedBuild/api/json | jq .&quot;result&quot;&quot;&#39;) Do Set &quot;test=%%~A&quot;\r\n    If /I &quot;%test%&quot;==&quot;failed&quot; ...DoSomething\r\n    If /I &quot;%test%&quot;==&quot;success&quot; ...DoSomethingElse\r\n    If /I &quot;%test%&quot;==&quot;unstable&quot; ...DoAnotherThing\r\n\r\nHowever there may be no need to set a variable at all, because you can work with the returned metavariable directly:\r\n\r\n    For /F &quot;Delims=&quot; %%A In (&#39;\r\n        &quot;curl -s  http://&lt;jenkins_url&gt;/job/&lt;job_name&gt;/lastCompletedBuild/api/json | jq .&quot;result&quot;&quot;\r\n    &#39;) Do (\r\n        If /I &quot;%%~A&quot;==&quot;failed&quot; ...DoSomething\r\n        If /I &quot;%%~A&quot;==&quot;success&quot; ...DoSomethingElse\r\n        If /I &quot;%%~A&quot;==&quot;unstable&quot; ...DoAnotherThing\r\n    )",
                "title": "Saving cURL and jq output to a variable in batch script"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1552221429,
        "creation_date": 1552206309,
        "last_edit_date": 1552215652,
        "question_id": 55085812,
        "body_markdown": "I use this command in order to retrieve a result of a build in Jenkins:\r\n\r\n    curl -s  http://&lt;jenkins_url&gt;/job/&lt;job_name&gt;/lastCompletedBuild/api/json | jq .&quot;result&quot;\r\n\r\nBased on that result I need to decide an action to be performed using a batch command,\r\n\r\nHow do I save the output of the command as a variable?",
        "link": "https://stackoverflow.com/questions/55085812/saving-curl-and-jq-output-to-a-variable-in-batch-script",
        "title": "Saving cURL and jq output to a variable in batch script"
    },
    {
        "tags": [
            "json",
            "dictionary",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1552240924,
                "last_edit_date": 1552240924,
                "creation_date": 1552232565,
                "answer_id": 55089398,
                "question_id": 55087333,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "[This is a response to the original question. It allows for arbitrarily many &quot;class&quot; files, and requires only one invocation of jq.  For a solution that does not involve &quot;slurping&quot; the JSON stream, see elsewhere on this page.]\r\n\r\nThe tricky part here is managing the unknown number of .txt files.  Here, we&#39;ll assume we can write &#39;*.txt&#39; to capture them, so the invocation of jq will look like this:\r\n\r\n    jq -n -R -f program.jq --slurpfile input object_count.json *.txt\r\n\r\nTo construct the dictionary, we&#39;ll use the following helper functions:\r\n\r\n    def trim: sub(&quot;^ +&quot;; &quot;&quot;) | sub(&quot; +$&quot;; &quot;&quot;);\r\n    \r\n    # construct the dictionary\r\n    def dictionary(s):\r\n      reduce (s | trim | select(length&gt;0)) as $in ({};\r\n         (input_filename | sub(&quot;.txt&quot;;&quot;&quot;) | sub(&quot;s$&quot;;&quot;&quot;)) as $class\r\n         | .[$in] = $class );\r\n\r\nNow the task reduces to the following three lines:\r\n\r\n    dictionary(inputs) as $class\r\n    | $input[]\r\n    | .class = ($class[.name] // &quot;other&quot;)\r\n\r\n\r\n",
                "title": "Label elements based on class they belong to"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1552255774,
                "last_edit_date": 1552255774,
                "creation_date": 1552239859,
                "answer_id": 55090547,
                "question_id": 55087333,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "\r\nIn accordance with the updated question, here is a solution that avoids slurping the contents of object_count.json.\r\n\r\n## dictionary.jq\r\n\r\n    def trim: sub(&quot;^ +&quot;; &quot;&quot;) | sub(&quot; +$&quot;; &quot;&quot;);\r\n\r\n    def dictionary(s):\r\n      reduce (s | trim | select(length&gt;0)) as $in ({};\r\n         (input_filename | sub(&quot;.txt&quot;;&quot;&quot;) | sub(&quot;s$&quot;;&quot;&quot;)) as $class\r\n         | .[$in] = $class );\r\n    \r\n    dictionary(inputs) \r\n\r\n## Invocation\r\n    jq --argfile class &lt;(jq -n -R -f dictionary.jq *.txt)  &#39;\r\n     .class = ($class[.name] // &quot;other&quot;)&#39;  object_count.json\r\n\r\n## Postscript\r\nUsing &quot;other&quot; as the default class name might be a requirement, but if not, then in situations like this, it would probably be preferable to go with the flow and use JSON&#39;s `null` as the default value for an object&#39;s key.\r\n\r\n\r\n\r\n\r\n",
                "title": "Label elements based on class they belong to"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1552255774,
        "creation_date": 1552218517,
        "last_edit_date": 1552252090,
        "question_id": 55087333,
        "body_markdown": "I have a stream of elements `object_count.json` looking like:\r\n\r\n    {\r\n        &quot;name&quot;:&quot;apple&quot;,\r\n        &quot;count&quot;:10\r\n    }\r\n    {\r\n        &quot;name&quot;:&quot;potato&quot;,\r\n        &quot;count&quot;:18\r\n    }\r\n    {\r\n        &quot;name&quot;:&quot;stone&quot;,\r\n        &quot;count:7\r\n    }\r\n\r\nSeparate from the stream, I have two files, each listing names of objects of its class:\r\n\r\n    cat fruits.txt\r\n      apple\r\n      peach\r\n\r\n    cat vegetables.txt\r\n      potato\r\n      tomato\r\n\r\n**How can I construct a stream where each object from `object_count.json` is attributed with its respective class name?** I.e.:\r\n\r\n    {\r\n        &quot;name&quot;:&quot;apple&quot;,\r\n        &quot;count&quot;:10\r\n        &quot;class&quot;:&quot;fruit&quot;\r\n    }\r\n    {\r\n        &quot;name&quot;:&quot;potato&quot;,\r\n        &quot;count&quot;:18\r\n        &quot;class&quot;:&quot;vegetable&quot;\r\n    }\r\n    {\r\n        &quot;name&quot;:&quot;stone&quot;,\r\n        &quot;count&quot;:7\r\n        &quot;class&quot;:&quot;other&quot;\r\n    }\r\n\r\nWe can assume there is only one entry per object name in `object_count.json`.\r\n\r\n----\r\nI would most prefer a solution which:\r\n\r\n* works well 3, 4 and more classes--each still listed in a separate file; it&#39;s OK if each class is hardcoded\r\n* `object_count.json` is considered an input stream, while `{fruits|vegetables}.txt` are provided each as a separate `--rawfile` argument \r\n\r\nVersion as reported by JQ:\r\n\r\n     $ jq --version\r\n     jq-1.6\r\n\r\n\r\n----\r\nI managed to feed the class file as an command-line argument, but failing to find a proper `join` / `in` expression which will work and solve the problem:\r\n\r\n    cat object_count.json | jq -n --rawfile fruits &quot;fruits.txt&quot; &#39;($fruits | split(&quot;\\n&quot;) | map(select(. != &quot;&quot;)) | sort) as $frts | inputs&#39;\r\n",
        "link": "https://stackoverflow.com/questions/55087333/label-elements-based-on-class-they-belong-to",
        "title": "Label elements based on class they belong to"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 468289,
                    "reputation": 190915,
                    "user_id": 874188,
                    "user_type": "registered",
                    "accept_rate": 62,
                    "profile_image": "https://www.gravatar.com/avatar/091f411d57db5be8298e057a32e5ad72?s=256&d=identicon&r=PG",
                    "display_name": "tripleee",
                    "link": "https://stackoverflow.com/users/874188/tripleee"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1552243108,
                "post_id": 55090964,
                "comment_id": 96926710,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1143565,
                    "reputation": 535973,
                    "user_id": 1126841,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa05233b2357f8d11c22ef4cfc7bb85c?s=256&d=identicon&r=PG",
                    "display_name": "chepner",
                    "link": "https://stackoverflow.com/users/1126841/chepner"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1552244576,
                "post_id": 55090964,
                "comment_id": 96927159,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1552252000,
                "last_edit_date": 1552252000,
                "creation_date": 1552242881,
                "answer_id": 55091015,
                "question_id": 55090964,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Yes! \r\n\r\n    jq &#39;{foo}&#39;\r\n\r\n## Explanation\r\n\r\n`{foo}` is an abbreviation for `{&quot;foo&quot;: .foo}`\r\n\r\n:-)\r\n\r\n## Caveat\r\nThe abbreviated form can only be used for key names that are not jq [keywords][1] (such as `if`).  However:\r\n\r\n    $ jq -n &#39;{&quot;if&quot;}&#39;\r\n    {\r\n      &quot;if&quot;: null\r\n    }\r\n\r\n\r\n  [1]: https://github.com/stedolan/jq/wiki/How-to:-Avoid-Pitfalls#keywords",
                "title": "Output key with the value"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1552252000,
        "creation_date": 1552242553,
        "question_id": 55090964,
        "body_markdown": "Given a json object (stored as bash variable $test)\r\n\r\n    {\r\n      &quot;foo&quot;: {\r\n        &quot;name&quot;: &quot;my foo&quot;\r\n      },\r\n      &quot;bar&quot;: {\r\n        &quot;name&quot;: &quot;my bar&quot;\r\n      }\r\n    }\r\n\r\nIf I want to output \r\n\r\n    {\r\n      &quot;foo&quot;: {\r\n        &quot;name&quot;: &quot;my foo&quot;\r\n      }\r\n    }\r\n\r\nIt looks like I have to use \r\n\r\n\r\n    $ jq &#39;. | with_entries(select(.key == &quot;foo&quot;))&#39; &lt;&lt;&lt;$test\r\n    {\r\n      &quot;foo&quot;: {\r\n        &quot;name&quot;: &quot;my foo&quot;\r\n      }\r\n    }\r\n\r\nIs there a simpler method to achieve same outcome?\r\n\r\n",
        "link": "https://stackoverflow.com/questions/55090964/output-key-with-the-value",
        "title": "Output key with the value"
    },
    {
        "tags": [
            "jq",
            "weather-api",
            "conky"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1560174238,
                "creation_date": 1560174238,
                "answer_id": 56527639,
                "question_id": 55092665,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If displaying the probabilities from when conky starts and thereafter is sufficient, you could use `${execgraph ...}` and just pass the latest value in the series each time conky updates.",
                "title": "display weather forecast data from weather api in conky graph"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1560174238,
        "creation_date": 1552253839,
        "last_edit_date": 1552255312,
        "question_id": 55092665,
        "body_markdown": "I would like my conky system monitor to show a time series of rain forecast probabilities as a graph. I request the forecast data via the darksky API and format it to csv with `jq` like this\r\n\r\n```\r\ncurl &quot;https://api.darksky.net/forecast/&lt;myapikey&gt;/&lt;mylat&gt;,&lt;mylon&gt;&quot; | \r\njq &#39;.minutely.data | map([.time, .precipProbability] | join(&quot;,&quot;)) | join(&quot;\\n&quot;) &#39; | \r\nsed &#39;s/&quot;//g&#39; | sed &#39;s/\\\\n/\\n/g&#39;\r\n```\r\n\r\nwhich produces output like this\r\n\r\n```\r\n1552253100,0\r\n1552253160,0\r\n1552253220,0\r\n1552253280,0\r\n1552253340,0\r\n1552253400,0.01\r\n1552253460,0.03\r\n...\r\n```\r\n\r\nIs there a way to display this data in conky with `${execgraph ...}` or similar? As far as I understand, you can only pass a single value at a time to update `execgraph`, but I want to display an entire time series at once.\r\n\r\nAt the moment I pass the data to gnuplot, produce a graph and include it in conky as an `${image ...}` which works alright, but perhaps there is a native conky solution.\r\n",
        "link": "https://stackoverflow.com/questions/55092665/display-weather-forecast-data-from-weather-api-in-conky-graph",
        "title": "display weather forecast data from weather api in conky graph"
    },
    {
        "tags": [
            "json",
            "datetime",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1552322131,
                "last_edit_date": 1552322131,
                "creation_date": 1552321290,
                "answer_id": 55106220,
                "question_id": 55101715,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Ignoring timezone considerations, you could use the following helper function as the basic building block for time comparisons:\r\n\r\n    def secs: sub(&quot;\\\\....(?&lt;z&gt;.)$&quot;; .z) | fromdate;\r\n\r\nWith it, you could select the JSON objects within the array, while preserving the array structure, as follows:\r\n\r\n    now as $now\r\n    | map(select(.startdate|secs) &lt;= $now and $now &lt;= (.enddate|secs)) )\r\n\r\nThis doesn&#39;t quite match your description, but it does make sense.\r\n\r\nOnce the objects have been selected, you can extract the fields of interest in the usual way.\r\n\r\n\r\n",
                "title": "how to select the json objects between given dates"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1552325323,
        "creation_date": 1552306684,
        "last_edit_date": 1552325323,
        "question_id": 55101715,
        "body_markdown": "Below is the json response of an api. Need to fetch exchange rate from the json using jq(within shell script).\r\nBelow are the conditions:\r\n    startdate should be eqaul to or greater than current date and enddate should be equal to or less than the current date for given currencyfrom and currencyto.\r\n\r\n```\r\n[\r\n    {\r\n        &quot;status&quot;: &quot;ACTIVE&quot;,\r\n        &quot;startdate&quot;: &quot;2019-01-31T00:00:00.000Z&quot;,\r\n        &quot;enddate&quot;: &quot;2019-02-07T00:00:00.000Z&quot;,\r\n        &quot;source&quot;: &quot;default&quot;,\r\n        &quot;exchangerate&quot;: &quot;12&quot;,\r\n        &quot;currencyfrom&quot;: &quot;AUD&quot;,\r\n        &quot;currencyto&quot;: &quot;BRL&quot;,\r\n        &quot;id&quot;: &quot;64ce2916-af8a-42b9-9fb9-def47f824ea2&quot;\r\n    },\r\n    {\r\n        &quot;status&quot;: &quot;ACTIVE&quot;,\r\n        &quot;startdate&quot;: &quot;2019-03-10T00:00:00.000Z&quot;,\r\n        &quot;enddate&quot;: &quot;2019-03-30T00:00:00.000Z&quot;,\r\n        &quot;source&quot;: &quot;default&quot;,\r\n        &quot;exchangerate&quot;: &quot;13&quot;,\r\n        &quot;currencyfrom&quot;: &quot;BRL&quot;,\r\n        &quot;currencyto&quot;: &quot;GBP&quot;,\r\n        &quot;id&quot;: &quot;4fd0dc10-d6b7-4298-924d-281a0d49c2e9&quot;\r\n    },\r\n    {\r\n        &quot;status&quot;: &quot;ACTIVE&quot;,\r\n        &quot;startdate&quot;: &quot;2019-03-10T00:00:00.000Z&quot;,\r\n        &quot;enddate&quot;: &quot;2019-03-10T16:20:10.813Z&quot;,\r\n        &quot;source&quot;: &quot;default&quot;,\r\n        &quot;exchangerate&quot;: &quot;17&quot;,\r\n        &quot;currencyfrom&quot;: &quot;AUD&quot;,\r\n        &quot;currencyto&quot;: &quot;BRL&quot;,\r\n        &quot;id&quot;: &quot;52bfe481-f4cf-4822-9566-886c4faeaf10&quot;\r\n    }\r\n]\r\n```",
        "link": "https://stackoverflow.com/questions/55101715/how-to-select-the-json-objects-between-given-dates",
        "title": "how to select the json objects between given dates"
    },
    {
        "tags": [
            "json",
            "kubernetes",
            "yaml",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1552339544,
                "last_edit_date": 1552339544,
                "creation_date": 1552336966,
                "answer_id": 55110109,
                "question_id": 55108680,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "[The following has been revised to reflect the update to the question.]\r\n\r\nAssuming CI_COMMIT_REF_NAME is available to jq as $CI_COMMIT_REF_NAME, which can be done using jq with the command-line argument:\r\n\r\n    --arg CI_COMMIT_REF_NAME &quot;$CI_COMMIT_REF_NAME&quot;\r\n\r\nan appropriate jq filter would be along the following lines:\r\n\r\n    .spec.rules[0].http.paths |=\r\n      (map(select(.path | index($CI_COMMIT_REF_NAME) | not)) as $new\r\n       | if ($new | length) == length\r\n         then . + [{ &quot;backend&quot;: { &quot;serviceName&quot;: $CI_COMMIT_REF_NAME, &quot;servicePort&quot;: 80}, &quot;path&quot;: ($CI_COMMIT_REF_NAME + &quot;/*&quot;) }]\r\n         else $new\r\n         end )\r\n\r\nYou can test this with the following jq invocation:\r\n\r\n    jq --arg CI_COMMIT_REF_NAME task-4444 -f program.jq input.json\r\n\r\n\r\nwhere of course `input.json` is the JSON version of your YAML.\r\n\r\n(I&#39;d use `index` in preference to `contains` if at all possible.)\r\n\r\n\r\n",
                "title": "ADD / REMOVE a backend block within k8s ingress manifest with JQ (YQ)"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1552339544,
        "creation_date": 1552331009,
        "last_edit_date": 1552338726,
        "question_id": 55108680,
        "body_markdown": "I have a kubernetes ingress manifest YAML, looking like next:\r\n\r\n```\r\napiVersion: extensions/v1beta1\r\nkind: Ingress\r\nmetadata:\r\n  annotations:\r\n    certmanager.k8s.io/acme-http01-edit-in-place: &quot;true&quot;\r\n    certmanager.k8s.io/cluster-issuer: letsencrypt\r\n  name: staging\r\n  namespace: dev\r\nspec:\r\n  rules:\r\n  - host: staging.domain.com\r\n    http:\r\n      paths:\r\n      - backend:\r\n          serviceName: task-11111\r\n          servicePort: 80\r\n        path: /task-11111/*\r\n      - backend:\r\n          serviceName: task-22222\r\n          servicePort: 80\r\n        path: /task-22222/*\r\n      - backend:\r\n          serviceName: task-33333\r\n          servicePort: 80\r\n        path: /task-33333/*\r\n  tls:\r\n  - hosts:\r\n    - staging.domain.com\r\n    secretName: staging-domain-com\r\n```\r\n\r\nWhat I&#39;m trying to achieve is to add (if not present) or remove (if present) a backend block. What I have now:\r\n\r\n    yq -y &#39;.spec.rules[].http.paths += [{ &quot;backend&quot;: { &quot;serviceName&quot;: &quot;&#39;${CI_COMMIT_REF_NAME}&#39;&quot;, &quot;servicePort&quot;: 80}, &quot;path&quot;: &quot;/&#39;${CI_COMMIT_REF_NAME}&#39;/*&quot;}]&#39;\r\n\r\n(adds a new block with variable value, but doesn&#39;t bother if it already exists)\r\n\r\n    yq -y &#39;del(.. | .paths? // empty | .[] | select(.path |contains(&quot;&#39;${CI_COMMIT_REF_NAME}&#39;&quot;)) )&#39;\r\n\r\n(fails with `jq: error (at &lt;stdin&gt;:0): Invalid path expression with result {&quot;backend&quot;:{&quot;serviceName&quot;:...`)\r\n\r\nSo rules may look like this after deletion (assume that `CI_COMMIT_REF_NAME` = `task-33333`):\r\n\r\n```\r\nspec:\r\n  rules:\r\n  - host: staging.domain.com\r\n    http:\r\n      paths:\r\n      - backend:\r\n          serviceName: task-11111\r\n          servicePort: 80\r\n        path: /task-11111/*\r\n      - backend:\r\n          serviceName: task-22222\r\n          servicePort: 80\r\n        path: /task-22222/*\r\n```\r\nor like this after adding (assume that `CI_COMMIT_REF_NAME` = `task-44444`):\r\n```\r\nspec:\r\n  rules:\r\n  - host: staging.domain.com\r\n    http:\r\n      paths:\r\n      - backend:\r\n          serviceName: task-11111\r\n          servicePort: 80\r\n        path: /task-11111/*\r\n      - backend:\r\n          serviceName: task-22222\r\n          servicePort: 80\r\n        path: /task-22222/*\r\n      - backend:\r\n          serviceName: task-33333\r\n          servicePort: 80\r\n        path: /task-33333/*\r\n      - backend:\r\n          serviceName: task-44444\r\n          servicePort: 80\r\n        path: /task-44444/*\r\n```\r\n\r\nAny help is greatly appreciated.  ",
        "link": "https://stackoverflow.com/questions/55108680/add-remove-a-backend-block-within-k8s-ingress-manifest-with-jq-yq",
        "title": "ADD / REMOVE a backend block within k8s ingress manifest with JQ (YQ)"
    },
    {
        "tags": [
            "json",
            "command-line",
            "jq",
            "data-manipulation"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1552337557,
                "last_edit_date": 1552337557,
                "creation_date": 1552333570,
                "answer_id": 55109264,
                "question_id": 55109037,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "A simple but efficient solution can be obtained by using these two generic helper functions:\r\n\r\n    def aggregate_by(s; f; g):\r\n      reduce s as $x  (null; .[$x|f] += [$x|g]);\r\n    \r\n    def max_by(s; f):\r\n      reduce s as $s (null;\r\n        if . == null then {s: $s, m: ($s|f)}\r\n        else  ($s|f) as $m\r\n        | if $m &gt; .m then {s: $s, m: $m} else . end\r\n        end)\r\n      | .s ;\r\n    \r\nWith these, a solution is the two-liner:\r\n\r\n    [ aggregate_by(.[]; .timestamp; .)[]\r\n      | max_by(.[]; .count) ]\r\n",
                "title": "jq how to choose from unique keys based on values"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1552337557,
        "creation_date": 1552332523,
        "question_id": 55109037,
        "body_markdown": "I&#39;ve been learning more about JSON lately and stumbled upon the &quot;jq&quot; command-line JSON processor. I am trying to combine multiple json files regarding clones from our Github repository. Some of these dates overlap, and since they were accessed at different points of the day, have slightly different count and unique values. Here is an example:\r\n\r\n\r\n    [\r\n      {\r\n        &quot;timestamp&quot;: &quot;2018-12-24T00:00:00Z&quot;,\r\n        &quot;count&quot;: 1,\r\n        &quot;uniques&quot;: 1\r\n      },\r\n      {\r\n        &quot;timestamp&quot;: &quot;2018-12-24T00:00:00Z&quot;,\r\n        &quot;count&quot;: 2,\r\n        &quot;uniques&quot;: 1\r\n      },\r\n      {\r\n        &quot;timestamp&quot;: &quot;2018-12-24T00:00:00Z&quot;,\r\n        &quot;count&quot;: 3,\r\n        &quot;uniques&quot;: 2\r\n      },\r\n      {\r\n        &quot;timestamp&quot;: &quot;2018-12-25T00:00:00Z&quot;,\r\n        &quot;count&quot;: 12,\r\n        &quot;uniques&quot;: 5\r\n      },\r\n      {\r\n        &quot;timestamp&quot;: &quot;2018-12-25T00:00:00Z&quot;,\r\n        &quot;count&quot;: 15,\r\n        &quot;uniques&quot;: 9\r\n      }\r\n    ]\r\n\r\nThe resulting code should look at the timestamp, determine whether it is unique, and if not, keep the object containing the largest &quot;count&quot;. An example of the desired output is below:\r\n\r\n    [\r\n      {\r\n        &quot;timestamp&quot;: &quot;2018-12-24T00:00:00Z&quot;,\r\n        &quot;count&quot;: 3,\r\n        &quot;uniques&quot;: 2\r\n      },\r\n      {\r\n        &quot;timestamp&quot;: &quot;2018-12-25T00:00:00Z&quot;,\r\n        &quot;count&quot;: 15,\r\n        &quot;uniques&quot;: 9\r\n      }\r\n    ]\r\n\r\n&quot;jq&quot; seems to be a pretty useful tool and I&#39;ve managed to use it in a few other situations, but haven&#39;t been able to figure out if or how to utilize it in this sort of fashion. Any help (or direction) would be appreciated!",
        "link": "https://stackoverflow.com/questions/55109037/jq-how-to-choose-from-unique-keys-based-on-values",
        "title": "jq how to choose from unique keys based on values"
    },
    {
        "tags": [
            "json",
            "edit",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 102363,
                    "reputation": 4960,
                    "user_id": 274811,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/94807cb89f41f2a6dcc48ba70b95f839?s=256&d=identicon&r=PG",
                    "display_name": "webwurst",
                    "link": "https://stackoverflow.com/users/274811/webwurst"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1552347824,
                "post_id": 55111907,
                "comment_id": 96966545,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1552661279,
                "last_edit_date": 1552661279,
                "creation_date": 1552354462,
                "answer_id": 55112838,
                "question_id": 55111907,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s one of many possible solutions:\r\n\r\n    walk( if type == &quot;object&quot;\r\n            and .contact_type == &quot;email&quot;\r\n            and (.value | index(&quot;yahoo.com&quot;))\r\n          then .value |= sub(&quot;yahoo.com&quot;; &quot;hotmail.com&quot;)\r\n          else . end )\r\n\r\n\r\n## Direct approach\r\n\r\n    def update:\r\n      if .contact_type == &quot;email&quot;\r\n         and (.value | index(&quot;yahoo.com&quot;))\r\n      then .value |= sub(&quot;yahoo.com&quot;; &quot;hotmail.com&quot;)\r\n      else . \r\n      end ;\r\n    \r\n    map( if .contact_info \r\n         then .contact_info |= map(update)\r\n         else .\r\n         end )\r\n\r\n## `else .`\r\n\r\nAfter the release of jq 1.6, a change was made allowing the `else .` to be dropped.\r\n",
                "title": "jq: how to change array value conditionally"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1552661279,
        "creation_date": 1552346944,
        "last_edit_date": 1552359549,
        "question_id": 55111907,
        "body_markdown": "A am new at json and jq. I searched internet but could not find solution for my problem.\r\nI have a json file with each object containing array. I need to change some of array elements conditionally: if contact_type = email and value like &quot;yahoo.com&quot; replace &quot;yahoo.com&quot; with &quot;hotmail.com&quot;.\r\nMy file:\r\n\r\n    [  \r\n        {\r\n            &quot;name&quot;: &quot;fluffy&quot;,\r\n            &quot;type&quot;: &quot;cat&quot;,\r\n            &quot;contact_info&quot;: [\r\n                 {\r\n                     &quot;contact_type&quot;: &quot;phone&quot;,\r\n                     &quot;value&quot;: &quot;123-456-6789&quot;\r\n                 },\r\n                 {\r\n                     &quot;contact_type&quot;: &quot;email&quot;,\r\n                     &quot;value&quot;: &quot;fluffy_mean_cat@gmail.com&quot;\r\n                 }\r\n            ]\r\n        },\r\n        {\r\n             &quot;name&quot;: &quot;breeze&quot;,\r\n             &quot;type&quot;: &quot;dog&quot;,\r\n             &quot;contact_info&quot;: [\r\n                 {\r\n                      &quot;contact_type&quot;: &quot;phone&quot;,\r\n                      &quot;value&quot;: &quot;125-856-6789&quot;\r\n                 },\r\n                 {\r\n                      &quot;contact_type&quot;: &quot;email&quot;,\r\n                      &quot;value&quot;: &quot;breeze@yahoo.com&quot;\r\n                 }\r\n             ]\r\n        }\r\n    ]\r\n\r\nResulting file has to look like this:\r\n\r\n    [\r\n        {\r\n             &quot;name&quot;: &quot;fluffy&quot;,\r\n             &quot;type&quot;: &quot;cat&quot;,\r\n             &quot;contact_info&quot;: [\r\n                 {\r\n                      &quot;contact_type&quot;: &quot;phone&quot;,\r\n                      &quot;value&quot;: &quot;123-456-6789&quot;\r\n                 },\r\n                 {\r\n                      &quot;contact_type&quot;: &quot;email&quot;,\r\n                      &quot;value&quot;: &quot;fluffy_mean_cat@gmail.com&quot;\r\n                 }\r\n             ]\r\n        },\r\n        {\r\n             &quot;name&quot;: &quot;breeze&quot;,\r\n             &quot;type&quot;: &quot;dog&quot;,\r\n             &quot;contact_info&quot;: [\r\n                 {\r\n                      &quot;contact_type&quot;: &quot;phone&quot;,\r\n                      &quot;value&quot;: &quot;125-856-6789&quot;\r\n                 },\r\n                 {\r\n                      &quot;contact_type&quot;: &quot;email&quot;,\r\n                      &quot;value&quot;: &quot;breeze@hotmail.com&quot;\r\n                 }\r\n             ]\r\n        }\r\n    ]\r\n\r\nPlease help.\r\n",
        "link": "https://stackoverflow.com/questions/55111907/jq-how-to-change-array-value-conditionally",
        "title": "jq: how to change array value conditionally"
    },
    {
        "tags": [
            "json",
            "key",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1552386576,
                "creation_date": 1552386576,
                "answer_id": 55119271,
                "question_id": 55118422,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use [string interpolation](https://stedolan.github.io/jq/manual/#Stringinterpolation-\\\\\\(foo\\)), like this:\r\n\r\n```\r\njq -r &quot;.FileSystems[] | \\&quot;\\(.Name) \\(.SizeInBytes.Value)\\&quot;&quot;\r\n```",
                "title": "jq - Combine data from different keys"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1552396817,
        "creation_date": 1552384008,
        "last_edit_date": 1552396817,
        "question_id": 55118422,
        "body_markdown": "I have this json output\r\n\r\n    {\r\n    &quot;FileSystems&quot;: [\r\n        {\r\n            &quot;CreationToken&quot;: &quot;CreationToken1&quot;,\r\n            &quot;OwnerId&quot;: &quot;OwnerId1&quot;,\r\n            &quot;SizeInBytes&quot;: {\r\n                &quot;Timestamp&quot;: 1552377599.0,\r\n                &quot;Value&quot;: 1550721024\r\n            },\r\n            &quot;Name&quot;: &quot;Name1&quot;,\r\n            &quot;NumberOfMountTargets&quot;: 3,\r\n            &quot;FileSystemId&quot;: &quot;fs-1&quot;,\r\n            &quot;LifeCycleState&quot;: &quot;available&quot;,\r\n            &quot;CreationTime&quot;: 1550506468.0,\r\n            &quot;PerformanceMode&quot;: &quot;generalPurpose&quot;\r\n        },\r\n        {\r\n            &quot;CreationToken&quot;: &quot;CreationToken2&quot;,\r\n            &quot;OwnerId&quot;: &quot;OwnerId2&quot;,\r\n            &quot;SizeInBytes&quot;: {\r\n                &quot;Timestamp&quot;: 1552377599.0,\r\n                &quot;Value&quot;: 2390339584\r\n            },\r\n            &quot;Name&quot;: &quot;Name2&quot;,\r\n            &quot;NumberOfMountTargets&quot;: 3,\r\n            &quot;FileSystemId&quot;: &quot;fs-2&quot;,\r\n            &quot;LifeCycleState&quot;: &quot;available&quot;,\r\n            &quot;CreationTime&quot;: 1547663741.0,\r\n            &quot;PerformanceMode&quot;: &quot;generalPurpose&quot;\r\n        }\r\n    ]\r\n    }\r\n\r\nBy using this command\r\n\r\n    aws efs describe-file-systems | jq -r &quot;.FileSystems[] | .SizeInBytes.Value&quot;\r\n\r\nI can recieve the NFS sized values:\r\n\r\n    1550725120\r\n    2390339584\r\n\r\nBut I need to get an output with the filesystem Name, so it should be like that:\r\n\r\n    Name1: 1550725120\r\n    Name2: 2390339584\r\n\r\nHow can I do it?\r\n",
        "link": "https://stackoverflow.com/questions/55118422/jq-combine-data-from-different-keys",
        "title": "jq - Combine data from different keys"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 11381172,
                    "reputation": 26772,
                    "user_id": 8344060,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/1UbPk.png?s=256",
                    "display_name": "kvantour",
                    "link": "https://stackoverflow.com/users/8344060/kvantour"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1552397511,
                "post_id": 55122537,
                "comment_id": 96986896,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6871698,
                    "reputation": 172,
                    "user_id": 5281776,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f1807a82f684493d7f82b2ed6242cdd4?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "ankalal",
                    "link": "https://stackoverflow.com/users/5281776/ankalal"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1552397878,
                "post_id": 55122537,
                "comment_id": 96987131,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1552402522,
                "last_edit_date": 1552402522,
                "creation_date": 1552397844,
                "answer_id": 55122824,
                "question_id": 55122537,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "One of many possible solutions:\r\n\r\n    [.[] | .name]\r\n\r\nIf you want to ensure the values in the resultant array are distinct, you could add the `unique` filter.\r\n\r\n## Creating a bash array\r\n\r\nIf your bash has `readarray`, you can read the &quot;name&quot; values into a bash array, a, as follows:\r\n\r\n    readarray a &lt;&lt;&lt; $(jq &#39;.[] | .name&#39; so-to-bash-array.json)\r\n\r\nIf not, simply use a bash loop.\r\n\r\nDepending on your requirements, you might want to use the -r command-line option of `jq`.",
                "title": "Get an array of all value of a key"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1552704614,
        "creation_date": 1552397032,
        "last_edit_date": 1552397834,
        "question_id": 55122537,
        "body_markdown": "I am new to bash and jq. I want an array of all value of a key.\r\ni have tried something like this but it doesn&#39;t work\r\n\r\n    jobName=$(echo &quot;$jobResult&quot; | jq &#39;. | to_entries[] | .value.name&#39;)\r\n\r\nbut it gave a string to me like this string\r\n \r\n***&quot;Basement Parking Construction Site 1&quot; &quot;Basement Parking Construction Site 2&quot;***\r\n\r\nInput\r\n\r\n     {\r\n      &quot;1&quot;: {\r\n        &quot;_status_code&quot;: 202,\r\n        &quot;_status_message&quot;: &quot;Accepted&quot;,\r\n        &quot;id&quot;: 4120489,\r\n        &quot;parent_id&quot;: 0,\r\n        &quot;assigned_to_all&quot;: false,\r\n        &quot;billable&quot;: false,\r\n        &quot;active&quot;: true,\r\n        &quot;type&quot;: &quot;regular&quot;,\r\n        &quot;has_children&quot;: false,\r\n        &quot;billable_rate&quot;: 0,\r\n        &quot;short_code&quot;: &quot;&quot;,\r\n        &quot;name&quot;: &quot;Basement Parking Construction Site 1&quot;,\r\n        &quot;last_modified&quot;: &quot;2019-03-12T10:02:54+00:00&quot;,\r\n        &quot;created&quot;: &quot;2019-03-12T10:02:54+00:00&quot;,\r\n        &quot;filtered_customfielditems&quot;: &quot;&quot;,\r\n        &quot;required_customfields&quot;: [],\r\n        &quot;locations&quot;: [],\r\n        &quot;project_id&quot;: 0\r\n      },\r\n      &quot;2&quot;: {\r\n        &quot;_status_code&quot;: 202,\r\n        &quot;_status_message&quot;: &quot;Accepted&quot;,\r\n        &quot;id&quot;: 4120491,\r\n        &quot;parent_id&quot;: 0,\r\n        &quot;assigned_to_all&quot;: false,\r\n        &quot;billable&quot;: false,\r\n        &quot;active&quot;: true,\r\n        &quot;type&quot;: &quot;regular&quot;,\r\n        &quot;has_children&quot;: false,\r\n        &quot;billable_rate&quot;: 0,\r\n        &quot;short_code&quot;: &quot;&quot;,\r\n        &quot;name&quot;: &quot;Basement Parking Construction Site 2&quot;,\r\n        &quot;last_modified&quot;: &quot;2019-03-12T10:02:54+00:00&quot;,\r\n        &quot;created&quot;: &quot;I019-03-12T10:02:54+00:00&quot;,\r\n        &quot;filtered_customfielditems&quot;: &quot;&quot;,\r\n        &quot;required_customfields&quot;: [],\r\n        &quot;locations&quot;: [],\r\n        &quot;project_id&quot;: 0\r\n      }\r\n\r\nI want an array of all the value with key name\r\n\r\nresult\r\n\r\n    [&quot;Basement Parking Construction Site 1&quot;,&quot;Basement Parking Construction Site 2&quot;]\r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/55122537/get-an-array-of-all-value-of-a-key",
        "title": "Get an array of all value of a key"
    },
    {
        "tags": [
            "json",
            "jq",
            "remove-if"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1552440426,
                "creation_date": 1552440426,
                "answer_id": 55133029,
                "question_id": 55130802,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "A little shorter version using `inside` instead of `contains`:\r\n\r\n    .update.toRemove as $temp |\r\n     {items: [.source.items[] | select([.id] | inside($temp) | not)]}",
                "title": "Using jq to remove items from an array based on values elsewhere in the input"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1552449752,
                "last_edit_date": 1552449752,
                "creation_date": 1552448444,
                "answer_id": 55134023,
                "question_id": 55130802,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a concise and efficient solution:\r\n\r\n    .update.toRemove as $rm\r\n    | .source\r\n    | .items |= map( select(.id | IN($rm[]) | not))\r\n",
                "title": "Using jq to remove items from an array based on values elsewhere in the input"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1552701193,
        "creation_date": 1552425543,
        "last_edit_date": 1552495659,
        "question_id": 55130802,
        "body_markdown": "I&#39;m new to `jq` and trying to wrap my head around doing a few things that I thought were going to be straightforward. Any ideas on how to improve this would be greatly appreciated.\r\n\r\nGiven this input:\r\n\r\n```\r\n{\r\n    &quot;source&quot;: {\r\n        &quot;items&quot;: [\r\n            { &quot;id&quot;: &quot;aaa&quot;, &quot;name&quot;: &quot;this&quot; },\r\n            { &quot;id&quot;: &quot;bbb&quot;, &quot;name&quot;: &quot;that&quot; },\r\n            { &quot;id&quot;: &quot;ccc&quot;, &quot;name&quot;: &quot;the other&quot; }\r\n        ]\r\n    },\r\n    &quot;update&quot;: {\r\n        &quot;toRemove&quot;: [\r\n        \t&quot;aaa&quot;,\r\n        \t&quot;ccc&quot;\r\n    \t]\r\n    }\r\n}\r\n```\r\n\r\nI want this result:\r\n```\r\n{\r\n    &quot;items&quot;: [\r\n        { &quot;id&quot;: &quot;bbb&quot;, &quot;name&quot;: &quot;that&quot; }\r\n    ]\r\n}\r\n```\r\n\r\nThis filter does the job but the variables lead me to believe there is a cleaner way.\r\n\r\n```\r\n. as $root | .source + { items: [.source.items[] | select(.id as $id | $root.update.toRemove | contains([$id]) | not)]}\r\n```\r\n\r\nPlayground link if interested: https://jqplay.org/s/GpVJfbTO-Q",
        "link": "https://stackoverflow.com/questions/55130802/using-jq-to-remove-items-from-an-array-based-on-values-elsewhere-in-the-input",
        "title": "Using jq to remove items from an array based on values elsewhere in the input"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1552472277,
                "post_id": 55133286,
                "comment_id": 97019074,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1552446757,
                "creation_date": 1552446757,
                "answer_id": 55133781,
                "question_id": 55133286,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To eliminate the ports you don&#39;t want, you might find one of these equivalent alternatives that use the `map(select(...))` idiom intuitive:\r\n\r\n    .ports |= map( if (.type | . == &quot;blackhole&quot; or . == &quot;cpu-port&quot; or . == &quot;loopback&quot;) then empty else . end)\r\n\r\n    .ports |= map( if .type | IN(&quot;blackhole&quot;, &quot;cpu-port&quot;, &quot;loopback&quot;) then empty else . end)\r\n\r\n    .ports |= map( select( .type | IN(&quot;blackhole&quot;, &quot;cpu-port&quot;, &quot;loopback&quot;) | not ) )\r\n\r\nTo select the key-value pairs of interest, you can use the `{foo, bar}` shorthand for `{&quot;foo&quot;:.foo, &quot;bar&quot;:.bar}` ",
                "title": "Delete multiple objects matching a condition"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1552504314,
        "creation_date": 1552442715,
        "last_edit_date": 1552445994,
        "question_id": 55133286,
        "body_markdown": "I have this JSON file: \r\n\r\n    {\r\n    \t&quot;uuid&quot;: &quot;ce651ed3-78b9-49a0-9d00-9bfaf33bb12c&quot;,\r\n    \t&quot;mp_router_id&quot;: &quot;bbbf9a22-5fde-48e2-980f-a6c58d7f941a&quot;,\r\n    \t&quot;config_session_state&quot;: &quot;Down&quot;,\r\n    \t&quot;routing_status&quot;: &quot;Up&quot;,\r\n    \t&quot;routing_state_flag&quot;: 0,\r\n    \t&quot;vrf_id&quot;: 4,\r\n    \t&quot;routing_state&quot;: [],\r\n    \t&quot;type&quot;: &quot;TLR-SR&quot;,\r\n    \t&quot;ports&quot;: [{\r\n    \t\t\t&quot;uuid&quot;: &quot;cc4e8e98-0a22-4534-aa8c-c30c14b5c3a7&quot;,\r\n    \t\t\t&quot;urpf-mode&quot;: &quot;NONE&quot;,\r\n    \t\t\t&quot;ifuid&quot;: 284,\r\n    \t\t\t&quot;mac&quot;: &quot;02:50:56:56:44:01&quot;,\r\n    \t\t\t&quot;lrouter&quot;: &quot;ce651ed3-78b9-49a0-9d00-9bfaf33bb12c&quot;,\r\n    \t\t\t&quot;admin_up&quot;: true,\r\n    \t\t\t&quot;ips&quot;: [\r\n    \t\t\t\t&quot;127.0.0.1/8&quot;\r\n    \t\t\t],\r\n    \t\t\t&quot;op_state_up&quot;: true,\r\n    \t\t\t&quot;owner&quot;: &quot;system&quot;,\r\n    \t\t\t&quot;type&quot;: &quot;loopback&quot;,\r\n    \t\t\t&quot;name&quot;: &quot;system-loopback-port&quot;\r\n    \t\t},\r\n    \t\t{\r\n    \t\t\t&quot;uuid&quot;: &quot;ee55ef38-941d-5f2e-8ead-c8bf6b1df06d&quot;,\r\n    \t\t\t&quot;lrouter&quot;: &quot;ce651ed3-78b9-49a0-9d00-9bfaf33bb12c&quot;,\r\n    \t\t\t&quot;ifuid&quot;: 281,\r\n    \t\t\t&quot;admin_up&quot;: true,\r\n    \t\t\t&quot;ips&quot;: [],\r\n    \t\t\t&quot;op_state_up&quot;: true,\r\n    \t\t\t&quot;type&quot;: &quot;cpu-port&quot;,\r\n    \t\t\t&quot;name&quot;: &quot;&quot;\r\n    \t\t},\r\n    \t\t{\r\n    \t\t\t&quot;uuid&quot;: &quot;8fd5f7a5-5906-40b7-b8c4-877882896ca8&quot;,\r\n    \t\t\t&quot;urpf-mode&quot;: &quot;NONE&quot;,\r\n    \t\t\t&quot;ifuid&quot;: 285,\r\n    \t\t\t&quot;mac&quot;: &quot;02:50:56:56:53:00&quot;,\r\n    \t\t\t&quot;lrouter&quot;: &quot;ce651ed3-78b9-49a0-9d00-9bfaf33bb12c&quot;,\r\n    \t\t\t&quot;admin_up&quot;: false,\r\n    \t\t\t&quot;ips&quot;: [\r\n    \t\t\t\t&quot;169.254.0.2/28&quot;\r\n    \t\t\t],\r\n    \t\t\t&quot;op_state_up&quot;: false,\r\n    \t\t\t&quot;type&quot;: &quot;backplane&quot;,\r\n    \t\t\t&quot;name&quot;: &quot;bp-sr0-port&quot;\r\n    \t\t},\r\n    \t\t{\r\n    \t\t\t&quot;uuid&quot;: &quot;65f526d1-621c-4f5b-a7e6-7d06278e0226&quot;,\r\n    \t\t\t&quot;urpf-mode&quot;: &quot;NONE&quot;,\r\n    \t\t\t&quot;ifuid&quot;: 283,\r\n    \t\t\t&quot;mac&quot;: &quot;02:50:56:56:44:55&quot;,\r\n    \t\t\t&quot;lrouter&quot;: &quot;ce651ed3-78b9-49a0-9d00-9bfaf33bb12c&quot;,\r\n    \t\t\t&quot;admin_up&quot;: false,\r\n    \t\t\t&quot;ips&quot;: [\r\n    \t\t\t\t&quot;100.64.208.1/31&quot;\r\n    \t\t\t],\r\n    \t\t\t&quot;op_state_up&quot;: false,\r\n    \t\t\t&quot;type&quot;: &quot;uplink&quot;,\r\n    \t\t\t&quot;name&quot;: &quot;LinkedPort_t0-uplink&quot;\r\n    \t\t},\r\n    \t\t{\r\n    \t\t\t&quot;uuid&quot;: &quot;36ccfb0d-45ad-5242-9e0f-2898de2c82db&quot;,\r\n    \t\t\t&quot;lrouter&quot;: &quot;ce651ed3-78b9-49a0-9d00-9bfaf33bb12c&quot;,\r\n    \t\t\t&quot;ifuid&quot;: 282,\r\n    \t\t\t&quot;admin_up&quot;: false,\r\n    \t\t\t&quot;ips&quot;: [],\r\n    \t\t\t&quot;op_state_up&quot;: false,\r\n    \t\t\t&quot;type&quot;: &quot;blackhole&quot;,\r\n    \t\t\t&quot;name&quot;: &quot;&quot;\r\n    \t\t}\r\n    \t],\r\n    \t&quot;vdr_id&quot;: 16,\r\n    \t&quot;name&quot;: &quot;SR-t1&quot;\r\n    }\r\n\r\nThe output I need is:\r\n\r\n    {\r\n                &quot;uuid&quot;: &quot;ce651ed3-78b9-49a0-9d00-9bfaf33bb12c&quot;,\r\n                &quot;type&quot;: &quot;TLR-SR&quot;,\r\n                &quot;ports&quot;: [\r\n                    {\r\n                        &quot;uuid&quot;: &quot;8fd5f7a5-5906-40b7-b8c4-877882896ca8&quot;,\r\n                        &quot;admin_up&quot;: false,\r\n                        &quot;ips&quot;: [\r\n                            &quot;169.254.0.2/28&quot;\r\n                        ],\r\n                        &quot;op_state_up&quot;: false,\r\n                        &quot;type&quot;: &quot;backplane&quot;,\r\n                        &quot;name&quot;: &quot;bp-sr0-port&quot;\r\n                    },\r\n                    {\r\n                        &quot;uuid&quot;: &quot;65f526d1-621c-4f5b-a7e6-7d06278e0226&quot;,\r\n                        &quot;admin_up&quot;: false,\r\n                        &quot;ips&quot;: [\r\n                            &quot;100.64.208.1/31&quot;\r\n                        ],\r\n                        &quot;op_state_up&quot;: false,\r\n                        &quot;type&quot;: &quot;uplink&quot;,\r\n                        &quot;name&quot;: &quot;LinkedPort_t0-uplink&quot;\r\n                    },\r\n                ],\r\n                name&quot;: &quot;SR-t1&quot;\r\n            }\r\n\r\nI don&#39;t want to show the elements with the below types. \r\nIf `.ports[].type == &quot;blackhole&quot;` or `&quot;cpu-port&quot;` or `&quot;loopback&quot;`\r\n\r\nI am able to get everything in the ports array and cannot find a way to exclude the elements that I wish to exclude. Is this possible with JQ or am I missing something very fundamental?",
        "link": "https://stackoverflow.com/questions/55133286/delete-multiple-objects-matching-a-condition",
        "title": "Delete multiple objects matching a condition"
    },
    {
        "tags": [
            "bash",
            "elasticsearch",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2707332,
                    "reputation": 12105,
                    "user_id": 2336650,
                    "user_type": "registered",
                    "accept_rate": 78,
                    "profile_image": "https://i.sstatic.net/lpq4b.jpg?s=256",
                    "display_name": "Mostafa Hussein",
                    "link": "https://stackoverflow.com/users/2336650/mostafa-hussein"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1552470710,
                "post_id": 55137976,
                "comment_id": 97018074,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 14043738,
                    "reputation": 165,
                    "user_id": 10144541,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/4c6e6b893b41046e3495efa67849549d?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "datacruncher",
                    "link": "https://stackoverflow.com/users/10144541/datacruncher"
                },
                "reply_to_user": {
                    "account_id": 2707332,
                    "reputation": 12105,
                    "user_id": 2336650,
                    "user_type": "registered",
                    "accept_rate": 78,
                    "profile_image": "https://i.sstatic.net/lpq4b.jpg?s=256",
                    "display_name": "Mostafa Hussein",
                    "link": "https://stackoverflow.com/users/2336650/mostafa-hussein"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1552470792,
                "post_id": 55137976,
                "comment_id": 97018134,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2707332,
                    "reputation": 12105,
                    "user_id": 2336650,
                    "user_type": "registered",
                    "accept_rate": 78,
                    "profile_image": "https://i.sstatic.net/lpq4b.jpg?s=256",
                    "display_name": "Mostafa Hussein",
                    "link": "https://stackoverflow.com/users/2336650/mostafa-hussein"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1552470848,
                "post_id": 55137976,
                "comment_id": 97018161,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 14043738,
                    "reputation": 165,
                    "user_id": 10144541,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/4c6e6b893b41046e3495efa67849549d?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "datacruncher",
                    "link": "https://stackoverflow.com/users/10144541/datacruncher"
                },
                "reply_to_user": {
                    "account_id": 2707332,
                    "reputation": 12105,
                    "user_id": 2336650,
                    "user_type": "registered",
                    "accept_rate": 78,
                    "profile_image": "https://i.sstatic.net/lpq4b.jpg?s=256",
                    "display_name": "Mostafa Hussein",
                    "link": "https://stackoverflow.com/users/2336650/mostafa-hussein"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1552470939,
                "post_id": 55137976,
                "comment_id": 97018223,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2707332,
                    "reputation": 12105,
                    "user_id": 2336650,
                    "user_type": "registered",
                    "accept_rate": 78,
                    "profile_image": "https://i.sstatic.net/lpq4b.jpg?s=256",
                    "display_name": "Mostafa Hussein",
                    "link": "https://stackoverflow.com/users/2336650/mostafa-hussein"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1552471164,
                "post_id": 55137976,
                "comment_id": 97018359,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 14043738,
                    "reputation": 165,
                    "user_id": 10144541,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/4c6e6b893b41046e3495efa67849549d?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "datacruncher",
                    "link": "https://stackoverflow.com/users/10144541/datacruncher"
                },
                "reply_to_user": {
                    "account_id": 2707332,
                    "reputation": 12105,
                    "user_id": 2336650,
                    "user_type": "registered",
                    "accept_rate": 78,
                    "profile_image": "https://i.sstatic.net/lpq4b.jpg?s=256",
                    "display_name": "Mostafa Hussein",
                    "link": "https://stackoverflow.com/users/2336650/mostafa-hussein"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1552471561,
                "post_id": 55137976,
                "comment_id": 97018613,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1552476476,
                "creation_date": 1552476476,
                "answer_id": 55140829,
                "question_id": 55137976,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can &#39;extract&#39; paths using the following:\r\n\r\n    jq -c &#39;paths(scalars) as $p | [$p, getpath($p)]&#39; file.json | grep 432432sdxWWB\r\n\r\nand response is:\r\n\r\n    [[&quot;_source&quot;,&quot;statistics&quot;,&quot;example.com&quot;,&quot;template2&quot;,&quot;subdomain_id&quot;],&quot;432432sdxWWB&quot;]\r\n\r\nPossibly you can improve jq query to get only single value but I hope it helps you in determining final version :)",
                "title": "Get the key values using jq from json"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1552484242,
                "creation_date": 1552484242,
                "answer_id": 55143216,
                "question_id": 55137976,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It&#39;s best to avoid `grep` in cases like this.  To meet the exact requirements in the present case, one could write:\r\n\r\n    jq -c &#39;paths(scalars) as $p\r\n    | [$p, getpath($p)]\r\n    | select(.[1] == &quot;9i6O4ERWWB&quot;)&#39; input.json\r\n\r\nIf one really needs grep-like functionality, you can always use jq&#39;s `test/1`. ",
                "title": "Get the key values using jq from json"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1552484242,
        "creation_date": 1552468043,
        "last_edit_date": 1552470898,
        "question_id": 55137976,
        "body_markdown": "I am looking for a way to find the full key path for given value taken from the variable. My input comes from the elasticsearch query result. \r\n\r\nFor example I want a full path to the key value: **9i6O4ERWWB** \r\nThey key value is always unique and what only changes is the example.com and template1 keys (I cannot predict what will be the name). \r\n\r\nOnce knowing the key path: \r\n**_source.example.com.template1**  I want to increment the &quot;counter&quot; field and update the elasticsearch document.  \r\n\r\n\r\nMy input JSON: \r\n\r\n    {\r\n    \t&quot;_index&quot;: &quot;domains&quot;,\r\n    \t&quot;_type&quot;: &quot;doc&quot;,\r\n    \t&quot;_id&quot;: &quot;c66443eb1e6a0850b03a91fdb967f4d1&quot;,\r\n    \t&quot;_score&quot;: 2.4877305,\r\n    \t&quot;_source&quot;: {\r\n    \t\t&quot;user_id&quot;: &quot;c66443eb1e6a0850b03a91fdb967f4d1&quot;,\r\n    \t\t&quot;statistics&quot;: {\r\n    \t\t\t&quot;test_count&quot;: 0,\r\n    \t\t\t&quot;datasize&quot;: 0,\r\n    \t\t\t&quot;example.com&quot;: {\r\n    \t\t\t\t&quot;template1&quot;: {\r\n    \t\t\t\t\t&quot;image_id&quot;: &quot;iPpDWbaO3YTIEb0pBkW3.png&quot;,\r\n    \t\t\t\t\t&quot;link_id&quot;: &quot;4ybOOUJpaBpDaLxPkz1j.html&quot;,\r\n    \t\t\t\t\t&quot;counter&quot;: 0,\r\n    \t\t\t\t\t&quot;subdomain_id&quot;: &quot;9i6O4ERWWB&quot;\r\n    \t\t\t\t},\r\n    \t\t\t\t&quot;template2&quot;: {\r\n    \t\t\t\t\t&quot;image_id&quot;: &quot;iPpDWasdas322sdaW3.png&quot;,\r\n    \t\t\t\t\t&quot;link_id&quot;: &quot;4ybOOd3425sdfsz1j.html&quot;,\r\n    \t\t\t\t\t&quot;counter&quot;: 1,\r\n    \t\t\t\t\t&quot;subdomain_id&quot;: &quot;432432sdxWWB&quot;\r\n    \t\t\t\t}\r\n    \t\t\t},\r\n    \t\t\t&quot;example1.com&quot;: {\r\n    \t\t\t\t&quot;template1&quot;: {\r\n    \t\t\t\t\t&quot;image_id&quot;: &quot;iPpDWdasdasdasdas3.png&quot;,\r\n    \t\t\t\t\t&quot;link_id&quot;: &quot;4ybOOUadsasdadsasd1j.html&quot;,\r\n    \t\t\t\t\t&quot;subdomain_id&quot;: &quot;9i6O4ERWWB&quot;\r\n    \t\t\t\t}\r\n    \t\t\t}\r\n    \t\t}\r\n    \t}\r\n    }\r\n\r\nWhat I have tried was: \r\n\r\n    &lt;myfile jq -c &#39;paths | select(.[-1])\r\n    &lt;myfile jq -c &#39;paths | select(.[-1] == &quot;subdomain_id&quot;)&#39;\r\n\r\nbut this prints all apart the key values: \r\n\r\n    [&quot;_index&quot;]\r\n    [&quot;_type&quot;]\r\n    [&quot;_id&quot;]\r\n    [&quot;_score&quot;]\r\n    [&quot;_source&quot;]\r\n    [&quot;_source&quot;,&quot;user_id&quot;]\r\n    [&quot;_source&quot;,&quot;statistics&quot;]\r\n    [&quot;_source&quot;,&quot;statistics&quot;,&quot;test_count&quot;]\r\n    [&quot;_source&quot;,&quot;statistics&quot;,&quot;datasize&quot;]\r\n    [&quot;_source&quot;,&quot;statistics&quot;,&quot;example.com&quot;]\r\n    [&quot;_source&quot;,&quot;statistics&quot;,&quot;example.com&quot;,&quot;template1&quot;]\r\n    [&quot;_source&quot;,&quot;statistics&quot;,&quot;example.com&quot;,&quot;template1&quot;,&quot;image_id&quot;]\r\n    [&quot;_source&quot;,&quot;statistics&quot;,&quot;example.com&quot;,&quot;template1&quot;,&quot;link_id&quot;]\r\n    [&quot;_source&quot;,&quot;statistics&quot;,&quot;example.com&quot;,&quot;template1&quot;,&quot;subdomain_id&quot;]\r\n    [&quot;_source&quot;,&quot;statistics&quot;,&quot;template2&quot;]\r\n    [&quot;_source&quot;,&quot;statistics&quot;,&quot;template2&quot;,&quot;image_id&quot;]\r\n    [&quot;_source&quot;,&quot;statistics&quot;,&quot;template2&quot;,&quot;link_id&quot;]\r\n    [&quot;_source&quot;,&quot;statistics&quot;,&quot;template2&quot;,&quot;subdomain_id&quot;]\r\n    [&quot;_source&quot;,&quot;statistics&quot;,&quot;example1.com&quot;]\r\n    [&quot;_source&quot;,&quot;statistics&quot;,&quot;example1.com&quot;,&quot;template1&quot;]\r\n    [&quot;_source&quot;,&quot;statistics&quot;,&quot;example1.com&quot;,&quot;template1&quot;,&quot;image_id&quot;]\r\n    [&quot;_source&quot;,&quot;statistics&quot;,&quot;example1.com&quot;,&quot;template1&quot;,&quot;link_id&quot;]\r\n    [&quot;_source&quot;,&quot;statistics&quot;,&quot;example1.com&quot;,&quot;template1&quot;,&quot;subdomain_id&quot;]\r\n\r\nMy pseudocode I am trying to write:\r\n\r\n    seeked_key_value=&quot;432432sdxWWB&quot;\r\n    jq -n --arg seeked_key_value &quot;$seeked_key_value&quot; \\\r\n    &#39;paths | select(.[-1].$seeked_key_value&#39;\r\n\r\nExpected result:   `[&quot;_source&quot;,&quot;statistics&quot;,&quot;example.com&quot;,&quot;template1&quot;,&quot;subdomain_id&quot;:&quot;432432sdxWWB&quot;]`\r\n\r\nIs this doable with jq in bash? ",
        "link": "https://stackoverflow.com/questions/55137976/get-the-key-values-using-jq-from-json",
        "title": "Get the key values using jq from json"
    },
    {
        "tags": [
            "json",
            "transform",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1552499901,
                "creation_date": 1552499901,
                "answer_id": 55148441,
                "question_id": 55147669,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "    { parent_key: map_values( {value: .}) }",
                "title": "jq - add parent key and move values into sub key"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1561106280,
        "creation_date": 1552497086,
        "last_edit_date": 1552499936,
        "question_id": 55147669,
        "body_markdown": "I&#39;d like to add a parent key and move each value into a sub key.  For example, I want to convert the following json:\r\n\r\n    {                                                    \r\n      &quot;hello&quot;: &quot;world&quot;,                                \r\n      &quot;foo&quot;: &quot;bar&quot;        \r\n    }\r\n\r\nto\r\n\r\n    {\r\n    \t&quot;parent_key&quot;: {\r\n    \t\t&quot;hello&quot;: {\r\n    \t\t\t&quot;value&quot;: &quot;world&quot;\r\n    \t\t},\r\n    \t\t&quot;foo&quot;: {\r\n    \t\t\t&quot;value&quot;: &quot;bar&quot;\r\n    \t\t}\r\n    \t}\r\n    }",
        "link": "https://stackoverflow.com/questions/55147669/jq-add-parent-key-and-move-values-into-sub-key",
        "title": "jq - add parent key and move values into sub key"
    },
    {
        "tags": [
            "json",
            "jq",
            "jsonlines",
            "ndjson"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1552552998,
                "last_edit_date": 1552552998,
                "creation_date": 1552512662,
                "answer_id": 55151516,
                "question_id": 55150415,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The simplest would undoubtedly be to use the invocation:\r\n\r\n    jq -s add\r\n\r\nIf the input stream is extremely large, it might be better to use reduction, e.g.:\r\n\r\n    jq -n &#39;reduce inputs as $i ({}; . + $i)&#39;",
                "title": "jq filter to transform jsonlines into a single json map"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1552552998,
        "creation_date": 1552507740,
        "question_id": 55150415,
        "body_markdown": "Input:\r\n\r\n    {&quot;aa&quot;:[&quot;a1&quot;,&quot;a2&quot;]}\r\n    {&quot;bb&quot;:[&quot;a1&quot;,&quot;b2&quot;]}\r\n\r\nWanted output (no worries about potentially duplicate keys):\r\n\r\n    {\r\n      &quot;aa&quot;:[&quot;a1&quot;,&quot;a2&quot;],\r\n      &quot;bb&quot;:[&quot;b1&quot;,&quot;b2&quot;]\r\n    }\r\n\r\nMany thanks!",
        "link": "https://stackoverflow.com/questions/55150415/jq-filter-to-transform-jsonlines-into-a-single-json-map",
        "title": "jq filter to transform jsonlines into a single json map"
    },
    {
        "tags": [
            "json",
            "debugging",
            "bigdata",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6929975,
                    "reputation": 2562,
                    "user_id": 5319738,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/33be75bf8acd83e41411d134106c8811?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Kamal",
                    "link": "https://stackoverflow.com/users/5319738/kamal"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1552530295,
                "post_id": 55151711,
                "comment_id": 97048250,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1552573059,
                "creation_date": 1552573059,
                "answer_id": 55164839,
                "question_id": 55151711,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Since your input is large, you might consider adding assertions or equivalent.  Since your program evidently expects arrays at various points, you could instrument it with a function such as:\r\n\r\n    def q($n; $msg):\r\n      if type == &quot;array&quot; or type == &quot;object&quot; \r\n      then .\r\n      else error(&quot;\\($msg): composite expected @ \\($n) vs \\(.)&quot;)\r\n      end;\r\n    \r\nYour program could then be instrumented as follows:\r\n    \r\n    range(0;length) as $n\r\n      | .[$n]\r\n      | .&quot;lrouter/show&quot; | q($n; 2) | .[]\r\n      | del( . | select(.type == &quot;TUNNEL-VRF&quot;))\r\n      | del(.ports | q($n; 3) | .[] | select(.type == &quot;blackhole&quot; or .type == &quot;cpu-port&quot; or .type == &quot;loopback&quot;))\r\n      | &quot;Name: \\(.name)&quot; ,\r\n        &quot;UUID: \\(.uuid)&quot; ,\r\n       (.ports[] | {Port_Name: .name,\r\n                    Port_Type: .type, \r\n                    Port_Peer: .peer,\r\n                    Port_IPs: (.ips | q($n; 4) |.[]),\r\n                    Port_Admin_Up: .admin_up, \r\n                    Port_Op_State: .op_state_up } )\r\n\r\n\r\n",
                "title": "jq: error (at ec-state:1028): Cannot iterate over null (null)"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1552574585,
        "creation_date": 1552513799,
        "last_edit_date": 1552574585,
        "question_id": 55151711,
        "body_markdown": "I have a lengthy JSON file and I execute the command to get the output shown below: \r\n\r\n    jq -s &#39;.[]\r\n      | .&quot;lrouter/show&quot;[]\r\n      |  del( . | select(.type == &quot;TUNNEL-VRF&quot;))\r\n      | del(.ports[] | select(.type == &quot;blackhole&quot; or .type == &quot;cpu-port&quot; or .type == &quot;loopback&quot;))\r\n      | &quot;Name: \\(.name)&quot; ,\r\n        &quot;UUID: \\(.uuid)&quot; ,\r\n       (.ports[] | {Port_Name: .name,\r\n                    Port_Type: .type, \r\n                    Port_Peer: .peer,\r\n                    Port_IPs: .ips[],\r\n                    Port_Admin_Up: .admin_up, \r\n                    Port_Op_State: .op_state_up } )&#39; ec-state\r\n\r\n    &quot;Name: SR-t0-uplink&quot;\r\n    &quot;UUID: 23354d26-6994-46d9-b78c-bb565a1c13f2&quot;\r\n    {\r\n      &quot;Port_Name&quot;: &quot;uplink&quot;,\r\n      &quot;Port_Type&quot;: &quot;uplink&quot;,\r\n      &quot;Port_Peer&quot;: &quot;d78089f6-71b5-4c8e-a477-69ee01f17c5c&quot;,\r\n      &quot;Port_IPs&quot;: &quot;1.1.13.5/24&quot;,\r\n      &quot;Port_Admin_Up&quot;: true,\r\n      &quot;Port_Op_State&quot;: true\r\n    }\r\n    {\r\n      &quot;Port_Name&quot;: &quot;bp-sr0-port&quot;,\r\n      &quot;Port_Type&quot;: &quot;backplane&quot;,\r\n      &quot;Port_Peer&quot;: null,\r\n      &quot;Port_IPs&quot;: &quot;169.254.0.2/28&quot;,\r\n      &quot;Port_Admin_Up&quot;: false,\r\n      &quot;Port_Op_State&quot;: false\r\n    }\r\n    jq: error (at ec-state:1028): Cannot iterate over null (null)\r\n\r\nI get the desired result however, I also get the jq error at the end of the result. Just curious to know what am I doing incorrectly with the query. ",
        "link": "https://stackoverflow.com/questions/55151711/jq-error-at-ec-state1028-cannot-iterate-over-null-null",
        "title": "jq: error (at ec-state:1028): Cannot iterate over null (null)"
    },
    {
        "tags": [
            "json",
            "bash",
            "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": 1552651380,
                "post_id": 55177098,
                "comment_id": 97102225,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8430559,
                    "reputation": 9,
                    "user_id": 6326471,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/a071fca84b115a2128d36db8bd8fe686?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "amrutha",
                    "link": "https://stackoverflow.com/users/6326471/amrutha"
                },
                "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": 1552675330,
                "post_id": 55177098,
                "comment_id": 97115954,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1552676733,
                "post_id": 55177098,
                "comment_id": 97116576,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1552638792,
                "creation_date": 1552638792,
                "answer_id": 55178488,
                "question_id": 55177098,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It means - to take the first error message as example -, that the directory `-/nsxapi/api/v1/vpn/l2vpn/sessions` does not exist. You could verify this by doing a\r\n\r\n    ls -d -- -/nsxapi/api/v1/vpn/l2vpn/sessions\r\n\r\nin the working directory, where your script runs.\r\n\r\nNote that a redirection to some path does not automatically create intermittent directories.",
                "title": "split a single file to multiple files by key name"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1552638792,
        "creation_date": 1552632689,
        "last_edit_date": 1552638206,
        "question_id": 55177098,
        "body_markdown": "I have a huge json file which has its keys starting with a &quot;/&quot;. I wanted to create multiple json file based on the key name. \r\n\r\n----\r\n\r\n    /upgrade-coordinator/api/v1/upgrade/eula/acceptance\r\n    /upgrade-coordinator/api/v1/upgrade/history\r\n    /upgrade-coordinator/api/v1/upgrade/nodes\r\n    /upgrade-coordinator/api/v1/upgrade/nodes-summary\r\n    /upgrade-coordinator/api/v1/upgrade/status-summary\r\n    /upgrade-coordinator/api/v1/upgrade/summary\r\n    /upgrade-coordinator/api/v1/upgrade/upgrade-unit-groups\r\n    /upgrade-coordinator/api/v1/upgrade/upgrade-unit-groups-status\r\n\r\n--- \r\n\r\nFollowing some note in the site, I came across: \r\n\r\n    for f in `cat input.json | jq -r &#39;keys[]&#39;` ; do\r\n      cat input.json | jq &quot;.$f&quot; &gt; $f.json\r\n    done\r\n    or when you insist on more bashy syntax like some seem to prefer:\r\n    \r\n    for f in $(jq -r &#39;keys[]&#39;) ; do\r\n      jq &quot;.[\\&quot;$f\\&quot;]&quot; &lt; input.json &gt; &quot;$f.json&quot;\r\n    done &lt; input.json\r\n\r\nWhen I tried the above, I get the error: \r\n\r\n    -bash: -/nsxapi/api/v1/vpn/l2vpn/sessions/summary.json: No such file or directory\r\n    -bash: -/upgrade-coordinator/api/v1/upgrade/eula/acceptance.json: No such file or directory\r\n    -bash: -/upgrade-coordinator/api/v1/upgrade/history.json: No such file or directory\r\n    -bash: -/upgrade-coordinator/api/v1/upgrade/nodes.json: No such file or directory\r\n    -bash: -/upgrade-coordinator/api/v1/upgrade/nodes-summary.json: No such file or directory\r\n    -bash: -/upgrade-coordinator/api/v1/upgrade/status-summary.json: No such file or directory\r\n    -bash: -/upgrade-coordinator/api/v1/upgrade/summary.json: No such file or directory\r\n    -bash: -/upgrade-coordinator/api/v1/upgrade/upgrade-unit-groups.json: No such file or directory\r\n    -bash: -/upgrade-coordinator/api/v1/upgrade/upgrade-unit-groups-status.json: No such file or directory\r\n    -bash: -/upgrade-coordinator/api/v1/upgrade/upgrade-unit-groups/aggregate-info.json: No such file or directory\r\n    -bash: -/upgrade-coordinator/api/v1/upgrade/upgrade-units.json: No such file or directory\r\n    -bash: -/upgrade-coordinator/api/v1/upgrade/upgrade-units-stats.json: No such file or directory\r\n    -bash: -/upgrade-coordinator/api/v1/upgrade/upgrade-units/aggregate-info.json: No such file or directory\r\n\r\nI think its probably bcos, its looking to create aggregate-info.json in the path -/upgrade-coordinator/api/v1/upgrade/upgrade-units/ -- If this is correct, how do I replace the first string &quot;/&quot; in every key to a blank space? Can I get some help, please? \r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/55177098/split-a-single-file-to-multiple-files-by-key-name",
        "title": "split a single file to multiple files by key name"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1552638980,
                "last_edit_date": 1552638980,
                "creation_date": 1552638016,
                "answer_id": 55178298,
                "question_id": 55178069,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You obviously don&#39;t have do that many invocations of `jq`. Just do it once to dump all the key/value pairs and read them out in separate shell variables\r\n\r\n    #!/usr/bin/env bash\r\n\r\n    while IFS= read -r line; do\r\n        declare &quot;$line&quot;\r\n    done&lt; &lt;(jq -r &#39;to_entries[] | [.key,.value] | join(&quot;=&quot;)&#39; json)\r\n\r\nNow you can print the variable from the command line having the same name as the one from the JSON key. To handle even more robust JSON strings that can contain literal newlines, emit the JSON output with a null-delimiter (`&quot;\\u0000&quot;`) and `read` it back.",
                "title": "Merge multiple jq invocations to one"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1552672471,
                "creation_date": 1552672471,
                "answer_id": 55188287,
                "question_id": 55178069,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Assuming the specified bash variable names are valid, the most robust method would be along these lines:\r\n\r\n    while IFS= read -d $&#39;\\0&#39; -r line; do\r\n        declare &quot;$line&quot;\r\n    done&lt; &lt;(data | jq -j -r &#39;to_entries[] | [.key, (.value | @sh)] | join(&quot;=&quot;) + &quot;\\u0000&quot;&#39; )\r\n\r\nNotice the use of the jq filter `@sh`.\r\n\r\n",
                "title": "Merge multiple jq invocations to one"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 3,
        "last_activity_date": 1552672471,
        "creation_date": 1552637085,
        "last_edit_date": 1552639224,
        "question_id": 55178069,
        "body_markdown": "I am parsing a JSON file as follows and assigning it to the shell variables that I later test if it is not empty and taking according actions on top of it. \r\n\r\nI am doing this using following jq commands:\r\n\r\n     proxy_host=`jq -r .proxy_host &lt;&lt;&lt; $line`\r\n     proxy_port=`jq -r .proxy_port &lt;&lt;&lt; $line`\r\n     query_string=`jq -r .query_string &lt;&lt;&lt; $line`\r\n     realip_remote_addr=`jq -r .realip_remote_addr &lt;&lt;&lt; $line`\r\n     realpath_root=`jq -r .realpath_root &lt;&lt;&lt; $line`\r\n     request_body=`jq -r .request_body &lt;&lt;&lt; $line`\r\n     request_id=`jq -r .request_id &lt;&lt;&lt; $line`\r\n     request_method=`jq -r .request_method &lt;&lt;&lt; $line`\r\n     request_uri=`jq -r .request_uri &lt;&lt;&lt; $line`\r\n     scheme=`jq -r .scheme &lt;&lt;&lt; $line`\r\n     ssl_protocol=`jq -r .ssl_protocol &lt;&lt;&lt; $line`\r\n     ssl_ciphers=`jq -r .ssl_ciphers &lt;&lt;&lt; $line`\r\n     ssl_client_cert=`jq -r .ssl_client_cert &lt;&lt;&lt; $line`\r\n     ssl_client_fingerprint=`jq -r .ssl_client_fingerprint &lt;&lt;&lt; $line`\r\n     ssl_client_i_dn=`jq -r .ssl_client_i_dn &lt;&lt;&lt; $line`\r\n     ssl_client_raw_cert=`jq -r .ssl_client_raw_cert &lt;&lt;&lt; $line`\r\n     ssl_client_s_dn=`jq -r .ssl_client_s_dn &lt;&lt;&lt; $line`\r\n     ssl_client_serial=`jq -r .ssl_client_serial &lt;&lt;&lt; $line`\r\n     ssl_client_v_end=`jq -r .ssl_client_v_end &lt;&lt;&lt; $line`\r\n     ssl_client_v_remain=`jq -r .ssl_client_v_remain &lt;&lt;&lt; $line`\r\n     ssl_client_v_start=`jq -r .ssl_client_v_start &lt;&lt;&lt; $line`\r\n     ssl_client_verify=`jq -r .ssl_client_verify &lt;&lt;&lt; $line`\r\n     ssl_session_id=`jq -r .ssl_session_id &lt;&lt;&lt; $line`\r\n     tcpinfo_rtt=`jq -r .tcpinfo_rtt &lt;&lt;&lt; $line`\r\n     uri=`jq -r .uri &lt;&lt;&lt; $line`\r\n\r\nMy json: \r\n\r\n    {\r\n      &quot;host&quot;: &quot;www.example.com&quot;,\r\n      &quot;hostname&quot;: &quot;localhost&quot;,\r\n      &quot;proxy_add_x_forwarded_for&quot;: &quot;127.0.0.1&quot;,\r\n      &quot;proxy_host&quot;: &quot;&quot;,\r\n      &quot;proxy_port&quot;: &quot;&quot;,\r\n      &quot;query_string&quot;: &quot;&quot;,\r\n      &quot;realip_remote_addr&quot;: &quot;8.1.2.3&quot;,\r\n      &quot;realpath_root&quot;: &quot;/var/www/&quot;,\r\n      &quot;request_body&quot;: &quot;&quot;,\r\n      &quot;request_id&quot;: &quot;78e7cc17c207fc683992bae956150c4d&quot;,\r\n      &quot;request_method&quot;: &quot;GET&quot;,\r\n      &quot;request_uri&quot;: &quot;/&quot;,\r\n      &quot;scheme&quot;: &quot;https&quot;,\r\n      &quot;server_name&quot;: &quot;www.localhost.com&quot;,\r\n      &quot;ssl_protocol&quot;: &quot;TLSv1.2&quot;,\r\n      &quot;ssl_ciphers&quot;: &quot;AES128-GCM-SHA256:AES128-SHA:AES256-SHA:ECDHE-RSA-AES128-GCM-SHA256:ECDHE-RSA-AES256-SHA:ECDHE-RSA-AES128-SHA:0x000a:0x00ff&quot;,\r\n      &quot;ssl_client_cert&quot;: &quot;&quot;,\r\n      &quot;ssl_client_fingerprint&quot;: &quot;&quot;,\r\n      &quot;ssl_client_i_dn&quot;: &quot;&quot;,\r\n      &quot;ssl_client_raw_cert&quot;: &quot;&quot;,\r\n      &quot;ssl_client_s_dn&quot;: &quot;&quot;,\r\n      &quot;ssl_client_serial&quot;: &quot;&quot;,\r\n      &quot;ssl_client_v_end&quot;: &quot;&quot;,\r\n      &quot;ssl_client_v_remain&quot;: &quot;&quot;,\r\n      &quot;ssl_client_v_start&quot;: &quot;&quot;,\r\n      &quot;ssl_client_verify&quot;: &quot;NONE&quot;,\r\n      &quot;ssl_session_id&quot;: &quot;3e10c1253816aa4b3ea80df403e752fadaa1c6e532febd25e288acb4f5735617&quot;,\r\n      &quot;tcpinfo_rtt&quot;: &quot;11142&quot;,\r\n      &quot;uri&quot;: &quot;/index.html&quot;\r\n    }\r\n\r\nI do not want to use shell tools like awk to access the fields. \r\nIs there a way to simplify this using jq and bash not to have 30 independent jq invocations to get this done?",
        "link": "https://stackoverflow.com/questions/55178069/merge-multiple-jq-invocations-to-one",
        "title": "Merge multiple jq invocations to one"
    },
    {
        "tags": [
            "json",
            "linux",
            "csv",
            "command",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1552706029,
                "creation_date": 1552706029,
                "answer_id": 55193085,
                "question_id": 55192047,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I&#39;d suggest using a program such as `awk` to do the partitioning, e.g. like so:\r\n\r\n    jq -rc &#39;[.id, .value] | @csv&#39; |\r\n      awk -v NUM 100000 &#39;{n++; print &gt; &quot;out.&quot; int((n+NUM)/NUM) &quot;.csv&quot;}&#39;",
                "title": "separate the saved output of command that process a very large compressed JSON file"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1553038094,
                "last_edit_date": 1553038094,
                "creation_date": 1553036066,
                "answer_id": 55251133,
                "question_id": 55192047,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use the `split` command, see [man-page][1]\r\n\r\n  [1]: http://man7.org/linux/man-pages/man1/split.1.html\r\n\r\nSimple example (10MB to STDOUT):\r\n\r\n`# dd if=/dev/zero bs=1M count=10 | split - --bytes=1M -d -a3 out`\r\n\r\nOutput files (10 files with size of 1MB read from STDIN):\r\n```\r\n# stat -c &quot;%s %n&quot; out00*\r\n1048576 out000\r\n1048576 out001\r\n1048576 out002\r\n1048576 out003\r\n1048576 out004\r\n1048576 out005\r\n1048576 out006\r\n1048576 out007\r\n1048576 out008\r\n1048576 out009\r\n```\r\n\r\nOr split the saved file with `split --bytes=1M -d -a3 out out`\r\n\r\nOutput:\r\n```\r\n# stat -c &quot;%s %n&quot; out*\r\n10485760 out\r\n1048576 out000\r\n1048576 out001\r\n1048576 out002\r\n1048576 out003\r\n1048576 out004\r\n1048576 out005\r\n1048576 out006\r\n1048576 out007\r\n1048576 out008\r\n1048576 out009\r\n```",
                "title": "separate the saved output of command that process a very large compressed JSON file"
            },
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1553540078,
                "last_edit_date": 1553540078,
                "creation_date": 1553446261,
                "answer_id": 55326175,
                "question_id": 55192047,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "save space with GNU `split --filter`\r\n----\r\n\r\nPOSIX `split` creates output files from its input and so requires a lot of free space to store them (the size of the entire uncompressed input plus some overhead).\r\n \r\nHowever, the GNU version of `split` has an extra `--filter` option which allows processing individual chunks of data in much less space as it does not need to create any temporary files:\r\n\r\n````\r\n| split -l $NUMLINES --filter=&#39;shell_command&#39;\r\n````\r\nYou can think of it like `xargs -n $NUMLINES command` except passing data to stdin instead of as commandline arguments.\r\n\r\nFor example, to output the md5sum of each set of (up to) 7 lines of /etc/passwd and then output the number of chunks processed:\r\n```\r\n&lt;/etc/passwd split -l7 --filter=&#39;md5sum|tee /dev/tty&#39; |\\\r\n{ echo Processed $(wc -l) chunks; }\r\n```\r\nTo modify your command to work on 10000 lines at a time, you could do something like:\r\n```\r\ncurl -L --silent &quot;$URL&quot; |\\\r\npigz -dc |\\\r\njq -r &#39;[.name, .value] | @csv&#39; |\\\r\nsplit -l 10000 --filter=&#39;save2db.php&#39;\r\n```\r\nYour filter command `save2db.php` should read from stdin.\r\n\r\nIf you prefer to make it read from an actual file, you can do something like:\r\n```\r\n... |\\\r\nsplit -l 10000 --filter=&#39;cat &gt;TMPFILE; save2db.php TMPFILE&#39;;\r\nrm TMPFILE\r\n```\r\n----\r\n\r\n**Warning:** You&#39;ll need to ensure that it is safe to split your csv file on line boundaries. Some csv files contain fields with embedded literal newlines; they may become malformed if split mid-field.",
                "title": "separate the saved output of command that process a very large compressed JSON file"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 2,
        "last_activity_date": 1554323672,
        "creation_date": 1552693874,
        "last_edit_date": 1554323672,
        "question_id": 55192047,
        "body_markdown": "Ok, let&#39;s start with the command line that i&#39;m using:\r\n\r\n    curl --silent http://example.com/json.gz | pigz -dc | jq -r &#39;[.name, .value] | @csv&#39; &gt; data.csv\r\n\r\nCURL will download a compressed of 11.6 GB of JSON file, `pigz` will decompress it and write all processed output to stdout, `jq` will read JSON and save the output as csv file.\r\n\r\nThe problem is, the output that saved as data.csv is extremely large and after all i still need to analyze this data by using a PHP script and insert it to MYSQL in special format (the data will have very small size then)\r\n\r\nBut, i only have less than 60 GB free space left in my server, even i&#39;m not able to decompress the full data and save it to the CSV file.\r\n\r\nSo, i got an idea, if i&#39;m able to save the output to separated files that have different names (let&#39;s say the names are the current date or timestamp) then i can run the PHP script to process every .csv file of them and save data to db and then delete the file to free the space, not sure if this is the best way, but at least i&#39;m trying to make it work.\r\n\r\nSo, i modified my command line to:\r\n\r\n    curl --silent http://example.com/json.gz | pigz -dc | jq -r &#39;[.name, .value] | @csv&#39; &gt; `date +&quot;%S-%M-%d-%m-%Y&quot;`_data.csv\r\n\r\nBut, it saved it all in one file only, i thought it will save it as multi files that everyone of them have different name since the date will keep changing while the output is written.\r\n\r\nAlso, any other working solutions are welcome, thanks!",
        "link": "https://stackoverflow.com/questions/55192047/separate-the-saved-output-of-command-that-process-a-very-large-compressed-json-f",
        "title": "separate the saved output of command that process a very large compressed JSON file"
    },
    {
        "tags": [
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1552719871,
                "post_id": 55194124,
                "comment_id": 97126389,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 14297963,
                    "reputation": 141,
                    "user_id": 10722076,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/6cfa78bbb145e19b68d1cf6700e4edeb?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "sam",
                    "link": "https://stackoverflow.com/users/10722076/sam"
                },
                "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": 1552721898,
                "post_id": 55194124,
                "comment_id": 97126772,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2347746,
                    "reputation": 13489,
                    "user_id": 2057509,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/0bKBt.jpg?s=256",
                    "display_name": "gregory",
                    "link": "https://stackoverflow.com/users/2057509/gregory"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1552724758,
                "post_id": 55194124,
                "comment_id": 97127346,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1552724534,
                "creation_date": 1552724534,
                "answer_id": 55194837,
                "question_id": 55194124,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use map:  \r\n\r\n`$jq -r &#39;.[] | map(.Title), map(.brand), map(.size), map(.date) | @csv&#39; yourfile.json &gt; sample.csv` ",
                "title": "Parsing JSON file and converting into csv file using jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1552836582,
                "last_edit_date": 1552836582,
                "creation_date": 1552751902,
                "answer_id": 55198687,
                "question_id": 55194124,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "\r\nFor simplicity, it might be best to handle each set of data in a separate invocation of jq.\r\nThis seems reasonable here given that each invocation of jq is quite fast, and it seems you will only need a small number of such invocations.\r\n \r\nThe Temperature and certifications data are uniform in the JSON input and so can be handled in a loop such as:\r\n\r\n    for field in Temperature certifications ; do\r\n        echo $field ::\r\n        jq --arg field &quot;$field&quot; -r &#39;\r\n          .content[].details | .[$field][]\r\n          | [.value, .characteristics] | @csv&#39; input.json &gt; output.$field.csv\r\n    done    \r\n\r\n(This assumes of course that the JSON is valid, and that &quot;certifications&quot; has been spelled correctly.)\r\n\r\n## Adding &quot;content&quot;-specific columns\r\n\r\n    for field in Temperature certifications ; do\r\n        echo $field ::\r\n        jq --arg field &quot;$field&quot; -r &#39;.content[]\r\n          | [.Title, .brand] as $columns\r\n          | .details | .[$field][]\r\n          | ($columns + [.value, .characteristics]) | @csv\r\n        &#39; so-multiple-csv-files.json &gt; tmp.output.$field.csv\r\n    done    \r\n\r\n",
                "title": "Parsing JSON file and converting into csv file using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": -1,
        "last_activity_date": 1552836582,
        "creation_date": 1552718195,
        "last_edit_date": 1552795474,
        "question_id": 55194124,
        "body_markdown": "I am trying to parse my data and convert them into multiple **csv** files, according to the section. \r\n\r\n\r\n### Sample JSON\r\n\r\n    {\r\n        &quot;content&quot;: [\r\n        {\r\n            &quot;Title&quot;: &quot;abc&quot;,\r\n            &quot;brand&quot;: &quot;xyz&quot;,\r\n            &quot;size&quot;: &quot;5 g&quot;,\r\n            &quot;date&quot;: &quot;2019-01-01&quot;,\r\n            &quot;details&quot;: {\r\n                &quot;Temperature&quot;: [\r\n                {\r\n                    &quot;value&quot;: &quot;90&quot;,\r\n                    &quot;chracterstics&quot;:&quot;Normal&quot;\r\n                },\r\n                {\r\n                    &quot;value&quot;:&quot;100&quot;,\r\n                    &quot;chracterstics&quot;:&quot;high&quot;\r\n                },\r\n                \r\n                {\r\n                    &quot;value&quot;:&quot;80&quot;,\r\n                    &quot;chracterstics&quot;:&quot;low&quot;\r\n                }\r\n                ],\r\n                \r\n                &quot;certifications&quot;: [\r\n                {\r\n                    &quot;value&quot;: &quot;based&quot;,\r\n                    &quot;chracterstics&quot;:&quot;pass&quot;\r\n                },\r\n                \r\n                {\r\n                    &quot;value&quot;: &quot;50&quot;,\r\n                    &quot;chracterstics&quot;:&quot;failed&quot;\r\n                }\r\n                ]\r\n            },\r\n            \r\n             &quot;formats&quot;: {\r\n                &quot;city&quot;: &quot;NYC&quot;,\r\n                &quot;id&quot;: &quot;007&quot;,\r\n                &quot;manufacture&quot;:&quot;&quot;\r\n                },\r\n            &quot;innerDetails&quot;: [\r\n            {\r\n                &quot;contains&quot;: &quot;abc&quot;,\r\n                &quot;panel&quot;:&quot;xyz&quot;,\r\n                &quot;values&quot;:[\r\n                    {\r\n                        &quot;name&quot;:&quot;abc&quot;,\r\n                        &quot;value&quot;:&quot;10&quot;\r\n                    },\r\n                    {\r\n                        &quot;name&quot;:&quot;xyz&quot;,\r\n                        &quot;value&quot;:&quot;20&quot;\r\n                    }\r\n                    ]\r\n                }\r\n            ]\r\n    }\r\n    ]\r\n    }\r\n    \r\nI am trying to put the content data into one **csv** file, Temperature data into second **csv** file, certifications into third, formats and inner details data in other separate file.\r\n\r\nI have tried the below approach, but getting &quot;Cannot index array with string &quot;brand&quot;&quot; error.\r\n\r\n    jq -r &#39;.[]|[.Title,.brand,.size,.date]|@csv&#39; $jsonfile &gt; sample.csv.\r\n\r\nI was trying on the same line with other sections, but getting the same error.\r\n\r\nHow do I solve this issue?\r\n\r\n",
        "link": "https://stackoverflow.com/questions/55194124/parsing-json-file-and-converting-into-csv-file-using-jq",
        "title": "Parsing JSON file and converting into csv file using jq"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1552760191,
                "creation_date": 1552760191,
                "answer_id": 55200035,
                "question_id": 55198806,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "**jq** solution:\r\n\r\n    jq &#39;def print(o): &quot;The \\(o.ordinal) word is \\(o.word)&quot;;\r\n        .numbers | (reduce map(select(.numeral))[] as $o ({}; .[&quot;\\($o.numeral)&quot;] = $o)) as $o\r\n        | [range(0; ($o | [keys[] | tonumber] | max)) \r\n           | &quot;\\(.+1)&quot; as $i\r\n           | if ($o[$i]) then print($o[$i]) else &quot;Wot no number \\($i)?&quot; end\r\n        ]&#39; input.json\r\n\r\nThe output:\r\n\r\n    [\r\n      &quot;The 1st word is One&quot;,\r\n      &quot;The 2nd word is Two&quot;,\r\n      &quot;Wot no number 3?&quot;,\r\n      &quot;Wot no number 4?&quot;,\r\n      &quot;The 5th word is Five&quot;\r\n    ]",
                "title": "Generate new array from sparse array of objects in JQ"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1552765966,
                "creation_date": 1552765966,
                "answer_id": 55200875,
                "question_id": 55198806,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Another solution ! \r\n\r\n    jq  &#39;[ \r\n           range(1; ( .numbers | max_by(.numeral)|.numeral ) +1 ) as $range_do_diplay  | \r\n           .numbers as $thedata | $range_do_diplay |\r\n           . as $i | \r\n                if ([$thedata[]|contains( { numeral: $i })]|any ) \r\n                then \r\n                   ($thedata|map(select( .numeral == $i )))|.[0]| &quot;The \\(.ordinal) word is \\(.word) &quot; \r\n                else \r\n                   &quot;Wot no number \\($i)?&quot; \r\n                end  \r\n         ] &#39; numbers.json\r\n\r\nThis solution use \r\n \r\n  - **max_by** to find the max value of *numeral*\r\n  - **range** to generate a list o values\r\n  - use variables to store intermediate value  ",
                "title": "Generate new array from sparse array of objects in JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1552765966,
        "creation_date": 1552752721,
        "question_id": 55198806,
        "body_markdown": "I have a JSON file that I want to process with JQ. It has an array of objects inside another object, with a key that I want to use to populate a new array.\r\n\r\nIn my real use-case this is nested in with a lot of other fluff and there lots more arrays but take this as a simpler but representative example of the kind of thing:\r\n\r\n    {\r\n      &quot;numbers&quot;: [\r\n        {\r\n          &quot;numeral&quot;: 1,\r\n          &quot;ordinal&quot;: &quot;1st&quot;,\r\n          &quot;word&quot;: &quot;One&quot;\r\n        },\r\n        {\r\n          &quot;numeral&quot;: 2,\r\n          &quot;ordinal&quot;: &quot;2nd&quot;,\r\n          &quot;word&quot;: &quot;Two&quot;\r\n        },\r\n        {\r\n          &quot;numeral&quot;: 5,\r\n          &quot;ordinal&quot;: &quot;5th&quot;,\r\n          &quot;word&quot;: &quot;Five&quot;\r\n        },\r\n        {\r\n          &quot;some-other-fluff-i-want-to-ignore&quot;: true\r\n        }\r\n      ]\r\n    }\r\n\r\nI&#39;d like to use JQ to get a new array based on the elements, ignoring some elements and handling the missing ones. e.g.\r\n\r\n    [\r\n      &quot;The 1st word is One&quot;,\r\n      &quot;The 2nd word is Two&quot;,\r\n      &quot;Wot no number 3?&quot;,\r\n      &quot;Wot no number 4?&quot;,\r\n      &quot;The 5th word is Five&quot;\r\n    ]\r\n\r\nDoing this in a loop for the elements that are there is simple, terse and elegant enough:\r\n\r\n    .numbers | map( . | select( .numeral) | [ &quot;The&quot;, .ordinal, &quot;word is&quot;, .word ] | join (&quot; &quot;))\r\n\r\nBut I can&#39;t find a way to cope with the missing entries. I have some code that sort-of works:\r\n\r\n    .numbers | [\r\n      ( .[] | select(.numeral == 1) | ( [ &quot;The&quot;, .ordinal, &quot;word is&quot;, .word ] | join (&quot; &quot;)) ) // &quot;Wot no number 1?&quot;,\r\n      ( .[] | select(.numeral == 2) | ( [ &quot;The&quot;, .ordinal, &quot;word is&quot;, .word ] | join (&quot; &quot;)) ) // &quot;Wot no number 2?&quot;,\r\n      ( .[] | select(.numeral == 3) | ( [ &quot;The&quot;, .ordinal, &quot;word is&quot;, .word ] | join (&quot; &quot;)) ) // &quot;Wot no number 3?&quot;,\r\n      ( .[] | select(.numeral == 4) | ( [ &quot;The&quot;, .ordinal, &quot;word is&quot;, .word ] | join (&quot; &quot;)) ) // &quot;Wot no number 4?&quot;,\r\n      ( .[] | select(.numeral == 5) | ( [ &quot;The&quot;, .ordinal, &quot;word is&quot;, .word ] | join (&quot; &quot;)) ) // &quot;Wot no number 5?&quot;\r\n    ]\r\n\r\nIt produces usable output, after a fashion:\r\n\r\n    richard@sophia:~$ jq -f make-array.jq &lt; numbers.json\r\n    [\r\n      &quot;The 1st word is One&quot;,\r\n      &quot;The 2nd word is Two&quot;,\r\n      &quot;Wot no number 3?&quot;,\r\n      &quot;Wot no number 4?&quot;,\r\n      &quot;The 5th word is Five&quot;\r\n    ]\r\n    richard@sophia:~$ \r\n\r\nHowever, whilst it produces the output, handles the missing elements and ignores the bits I don&#39;t want, it&#39;s obviously extremely naff code that cries out for a for-loop or something similar but I can&#39;t see a way in JQ to do this. Any ideas?\r\n",
        "link": "https://stackoverflow.com/questions/55198806/generate-new-array-from-sparse-array-of-objects-in-jq",
        "title": "Generate new array from sparse array of objects in JQ"
    },
    {
        "tags": [
            "jq",
            "module-search-path"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1552757076,
                "creation_date": 1552757076,
                "answer_id": 55199519,
                "question_id": 55199250,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; How can I have a startup script and a include search path without specifying -L on the command line?\r\n\r\nUse the module metadata feature, e.g.:\r\n\r\n    include &quot;mytest&quot; {&quot;search&quot;: &quot;/usr/local/lib/jq&quot;}; \r\n\r\n## Illustration\r\n   \r\n    $ cat /usr/local/lib/jq/mytest.jq\r\n    def go: &quot;hello&quot;;\r\n\r\n    $ jq -n &#39;include &quot;mytest&quot; {&quot;search&quot;: &quot;/usr/local/lib/jq&quot;}; go&#39;\r\n    &quot;hello&quot;\r\n\r\n## Postscript\r\nIf you believe there is a mismatch between the current version of jq (1.6) and the corresponding documentation at https://stedolan.github.io/jq/manual/v1.6/\r\nplease file a report at https://github.com/stedolan/jq/issues",
                "title": "jq include default search path"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1552788818,
        "creation_date": 1552755310,
        "last_edit_date": 1552788818,
        "question_id": 55199250,
        "body_markdown": "I would like to put a function definition in /usr/lib/jq/mytest.jq to be included in my jq script.\r\n\r\nFrom the [manual][1]  :\r\n\r\n&gt; The default search path is the search path given to the -L\r\n&gt; command-line option, else [&quot;~/.jq&quot;, &quot;$ORIGIN/../lib/jq&quot;,\r\n&gt; &quot;$ORIGIN/../lib&quot;].\r\n\r\nSince jq is in /usr/bin shouldn&#39;t /usr/bin/../lib/jq be in the search path? I can&#39;t get this command to work:\r\n\r\n    jq -n &#39;include &quot;mytest&quot;;&#39;\r\n\r\nAdding -L /usr/lib/jq to the command works, or I can create a ~/.jq/mytest.jq and that works as well.  However, I&#39;d like to use the ~/.jq file for startup.  How can I have a startup script *and* a include search path without specifying -L on the command line??\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/#Modules\r\n",
        "link": "https://stackoverflow.com/questions/55199250/jq-include-default-search-path",
        "title": "jq include default search path"
    },
    {
        "tags": [
            "json",
            "csv",
            "padding",
            "jq",
            "missing-data"
        ],
        "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": 1552936598,
                "post_id": 55226242,
                "comment_id": 97191668,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9733076,
                    "reputation": 1007,
                    "user_id": 7475879,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/979de485b7e47a73df5a7b9ef4412d24?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Tytire Recubans",
                    "link": "https://stackoverflow.com/users/7475879/tytire-recubans"
                },
                "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": 1552942583,
                "post_id": 55226242,
                "comment_id": 97194266,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1552939371,
                "creation_date": 1552939371,
                "answer_id": 55229216,
                "question_id": 55226242,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is an approach based on programmatically determining the headers.  To illustrate it, we confine attention to a single object.\r\n\r\nSince jq&#39;s `paths` builtin ignores paths to null, and since one of the requirements here is NOT to ignore such paths, we start by defining some filters that are analogous to `paths/0` and `paths/1`:\r\n\r\n    # Generate a stream of all paths, including paths to null\r\n    def allpaths:\r\n      def conditional_recurse(f):  def r: ., (select(.!=null) | f | r); r;\r\n      path(conditional_recurse(.[]?)) | select(length &gt; 0);\r\n    \r\n    def allpaths(filter):\r\n      allpaths as $p | getpath($p) as $v | select($v | filter) | $p;\r\n\r\nNext, we define a function for abbreviating long paths. You may wish to tailor this to your needs.\r\n\r\n    # Input: an array denoting a path; output: a string\r\n    def abbreviate: if .[-1]|type == &quot;number&quot; then &quot;\\(.[-2]):\\(.[-1])&quot; else &quot;\\(.[-1])&quot; end;\r\n\r\nFinally, we pull everything together for the single-object case by generating a row of headers, followed by a row of the corresponding values:\r\n\r\n    [allpaths(scalars)] as $p\r\n    | ($p | map(abbreviate) | @csv),\r\n      ([getpath($p[])] | @csv)\r\n\r\n## Output\r\n\r\nFor the JSON object in the question, the output produced by the above (using the -r command-line option) would be the following CSV:\r\n\r\n    &quot;company_number&quot;,&quot;address_line_1&quot;,&quot;country&quot;,&quot;locality&quot;,&quot;postal_code&quot;,&quot;premises&quot;,&quot;region&quot;,&quot;country_of_residence&quot;,&quot;month&quot;,&quot;year&quot;,&quot;etag&quot;,&quot;kind&quot;,&quot;self&quot;,&quot;name&quot;,&quot;forename&quot;,&quot;middle_name&quot;,&quot;surname&quot;,&quot;title&quot;,&quot;nationality&quot;,&quot;natures_of_control:0&quot;,&quot;notified_on&quot;\r\n    &quot;09626947&quot;,&quot;Troak Close&quot;,&quot;England&quot;,&quot;Christchurch&quot;,&quot;BH23 3SR&quot;,&quot;9&quot;,&quot;Dorset&quot;,&quot;United Kingdom&quot;,11,1979,&quot;7123fb76e4ad7ee7542da210a368baa4c89d5a06&quot;,&quot;individual-person-with-significant-control&quot;,&quot;/company/09626947/persons-with-significant-control/individual/FFeqke7T3LvGvX6xmuGqi5SJXAk&quot;,&quot;Ms Angela Lynette Miller&quot;,&quot;Angela&quot;,&quot;Lynette&quot;,&quot;Miller&quot;,&quot;Ms&quot;,&quot;British&quot;,&quot;significant-influence-or-control&quot;,&quot;2016-06-06&quot;\r\n\r\n",
                "title": "JSON -&gt; csv creating header line and padding header if found empty field"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1552958492,
                "last_edit_date": 1552958492,
                "creation_date": 1552944829,
                "answer_id": 55230356,
                "question_id": 55226242,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is a solution which handles arrays in the input JSON by converting them to &quot;colon-separated values&quot;:\r\n\r\n    def atos: map(tostring) | join(&quot;:&quot;);\r\n\r\nThe same generic `allpaths` filters as used elsewhere on this page are also used:\r\n\r\n    # Generate a stream of all paths, including paths to null\r\n    def allpaths:\r\n      def conditional_recurse(f):  def r: ., (select(.!=null) | f | r); r;\r\n      path(conditional_recurse(.[]?)) | select(length &gt; 0);\r\n    \r\n    def allpaths(filter):\r\n      allpaths as $p | getpath($p) as $v | select($v | filter) | $p;\r\n\r\nAgain for the single-object case, a solution can be obtained as follows:\r\n\r\n    walk( if type == &quot;array&quot; then atos else . end )\r\n    | [allpaths(scalars)] as $p\r\n    | ($p | map(last) | @csv),\r\n      ([getpath($p[])] | @csv)\r\n  \r\n\r\n## Output\r\nFor the given input, the output would be:\r\n\r\n    &quot;company_number&quot;,&quot;address_line_1&quot;,&quot;country&quot;,&quot;locality&quot;,&quot;postal_code&quot;,&quot;premises&quot;,&quot;region&quot;,&quot;country_of_residence&quot;,&quot;month&quot;,&quot;year&quot;,&quot;etag&quot;,&quot;kind&quot;,&quot;self&quot;,&quot;name&quot;,&quot;forename&quot;,&quot;middle_name&quot;,&quot;surname&quot;,&quot;title&quot;,&quot;nationality&quot;,&quot;natures_of_control&quot;,&quot;notified_on&quot;\r\n    &quot;09626947&quot;,&quot;Troak Close&quot;,&quot;England&quot;,&quot;Christchurch&quot;,&quot;BH23 3SR&quot;,&quot;9&quot;,&quot;Dorset&quot;,&quot;United Kingdom&quot;,11,1979,&quot;7123fb76e4ad7ee7542da210a368baa4c89d5a06&quot;,&quot;individual-person-with-significant-control&quot;,&quot;/company/09626947/persons-with-significant-control/individual/FFeqke7T3LvGvX6xmuGqi5SJXAk&quot;,&quot;Ms Angela Lynette Miller&quot;,&quot;Angela&quot;,&quot;Lynette&quot;,&quot;Miller&quot;,&quot;Ms&quot;,&quot;British&quot;,&quot;significant-influence-or-control&quot;,&quot;2016-06-06&quot;\r\n\r\n\r\n## Caveat\r\nThe solution presented here is intended only for use when the arrays in the input are all scalar-valued.\r\n\r\n## Handling a stream of isomorphic objects efficiently\r\n\r\nIn the following, the stream of objects is assumed to be isomorphic in the sense that the ordering of keys within a JSON object is irrelevant.\r\n\r\n### Infrastructure\r\n\r\nThe `allpaths` and `atos` infrastructure is as above and so won&#39;t be repeated here.\r\n\r\n### Helper functions\r\n\r\n    # input: an object\r\n    def paths:\r\n      walk( if type == &quot;array&quot; then atos else . end )\r\n      | [allpaths(scalars)] ;\r\n    \r\n    # input: an array of paths\r\n    def headers:\r\n      map(last) | @csv ; \r\n    \r\n    # input: an object\r\n    def row($paths):\r\n      walk( if type == &quot;array&quot; then atos else . end )\r\n      | [getpath($paths[])]\r\n      | @csv ;\r\n      \r\n### Processing the input stream\r\n\r\nThe following uses `input` to read the first object, and `inputs` to read the rest, so it is essential to invoke jq with the -n command-line option:\r\n\r\n    input as $first\r\n    | ($first|paths) as $paths\r\n    | ($paths | headers),\r\n      ($first | row($paths)),\r\n      (inputs | row($paths))\r\n\r\n",
                "title": "JSON -&gt; csv creating header line and padding header if found empty field"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1552958492,
        "creation_date": 1552927670,
        "question_id": 55226242,
        "body_markdown": "I have a programme in bash that get JSONline files with several million of these object per line (See [source][1])\r\n\r\n    {\r\n      &quot;company_number&quot;: &quot;09626947&quot;,\r\n      &quot;data&quot;: {\r\n        &quot;address&quot;: {\r\n          &quot;address_line_1&quot;: &quot;Troak Close&quot;,\r\n          &quot;country&quot;: &quot;England&quot;,\r\n          &quot;locality&quot;: &quot;Christchurch&quot;,\r\n          &quot;postal_code&quot;: &quot;BH23 3SR&quot;,\r\n          &quot;premises&quot;: &quot;9&quot;,\r\n          &quot;region&quot;: &quot;Dorset&quot;\r\n        },\r\n        &quot;country_of_residence&quot;: &quot;United Kingdom&quot;,\r\n        &quot;date_of_birth&quot;: {\r\n          &quot;month&quot;: 11,\r\n          &quot;year&quot;: 1979\r\n        },\r\n        &quot;etag&quot;: &quot;7123fb76e4ad7ee7542da210a368baa4c89d5a06&quot;,\r\n        &quot;kind&quot;: &quot;individual-person-with-significant-control&quot;,\r\n        &quot;links&quot;: {\r\n          &quot;self&quot;: &quot;/company/09626947/persons-with-significant-control/individual/FFeqke7T3LvGvX6xmuGqi5SJXAk&quot;\r\n        },\r\n        &quot;name&quot;: &quot;Ms Angela Lynette Miller&quot;,\r\n        &quot;name_elements&quot;: {\r\n          &quot;forename&quot;: &quot;Angela&quot;,\r\n          &quot;middle_name&quot;: &quot;Lynette&quot;,\r\n          &quot;surname&quot;: &quot;Miller&quot;,\r\n          &quot;title&quot;: &quot;Ms&quot;\r\n        },\r\n        &quot;nationality&quot;: &quot;British&quot;,\r\n        &quot;natures_of_control&quot;: [\r\n          &quot;significant-influence-or-control&quot;\r\n        ],\r\n        &quot;notified_on&quot;: &quot;2016-06-06&quot;\r\n      }\r\n    }\r\n\r\nI have my JQ query that looks like this: \r\n\r\n    for file in psc_chunk_*; do\r\n    jq --slurp --raw-output &#39;def pad($n): range(0;$n) as $i | \r\n    .[$i]; ([.[] | .data.natures_of_control | length] | max) as $mx |\r\n    .[] | \r\n    select(.data) |\r\n    [.company_number, .data.kind, .data.address.address_line_1, .data.address.country, .data.address.locality, .data.address.postal_code, .data.address.premises, .data.identification.country_registered, .data.identification.legal_authority, .data.identification.legal_form, .data.identification.place_registered, .data.identification.registration_number, .data.ceased_on, .data.country_of_residence, &quot;\\(.data.date_of_birth.year)-\\(.data.date_of_birth.month)&quot;, .data.etag, .data.links.self, .data.name, .data.name_elements.title, .data.name_elements.forename, .data.name_elements.middle_name, .data.name_elements.surname, .data.nationality, .data.notified_on, (.data.natures_of_control | pad($mx))] |\r\n    @csv&#39; $file &gt; $file.csv;\r\n    done\r\n\r\nWhich is probably hurting the eyes of many JQ pros  out there - it is not efficient in extracting key:value pairs and if the provider happens to change name of a key my code wouldn&#39;t work anymore. \r\n\r\nIs there a way to just flatten all the json into a csv **keeping the keys as headers** - with the extra difficulty that **there is a list `natures_of_control` which has a varying number of entries** (for which i used the pad function to get a rectangular result). \r\n\r\n\r\n\r\n  [1]: http://download.companieshouse.gov.uk/en_pscdata.html\r\n",
        "link": "https://stackoverflow.com/questions/55226242/json-csv-creating-header-line-and-padding-header-if-found-empty-field",
        "title": "JSON -&gt; csv creating header line and padding header if found empty field"
    }
]