[
    {
        "tags": [
            "jq",
            "set-difference"
        ],
        "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": 8,
                "creation_date": 1427910006,
                "post_id": 29396154,
                "comment_id": 46970636,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 22,
                "is_accepted": true,
                "score": 22,
                "last_activity_date": 1427991412,
                "creation_date": 1427991412,
                "answer_id": 29417648,
                "question_id": 29396154,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "@Jeff Mercado blew my mind! I didn&#39;t know array subtraction was allowed...\r\n\r\n    echo -n &#39;{&quot;all&quot;:[&quot;A&quot;,&quot;B&quot;,&quot;C&quot;,&quot;ABC&quot;],&quot;some&quot;:[&quot;B&quot;,&quot;C&quot;]}&#39; | jq &#39;.all-.some&#39;\r\n\r\nyields\r\n\r\n    [\r\n      &quot;A&quot;,\r\n      &quot;ABC&quot;\r\n    ]",
                "title": "JQ: setdiff of two arrays"
            },
            {
                "up_vote_count": 5,
                "is_accepted": false,
                "score": 5,
                "last_activity_date": 1504104492,
                "creation_date": 1504104492,
                "answer_id": 45963518,
                "question_id": 29396154,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "I was looking for a similar solution but with the requirement that the arrays were being generated dynamically. Below solution just does the expected\r\n\r\n    array1=$(jq -e &#39;&#39;)  // jq expression goes here\r\n    array2=$(jq -e &#39;&#39;)  // jq expression goes here\r\n\r\n    array_diff=$(jq -n --argjson array1 &quot;$array1&quot; --argjson array2 &quot;$array2&quot; \r\n    &#39;{&quot;all&quot;: $array1,&quot;some&quot;:$array2} | .all-.some&#39; )",
                "title": "JQ: setdiff of two arrays"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1504109979,
                "creation_date": 1504109979,
                "answer_id": 45965370,
                "question_id": 29396154,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "While [- Array Subtraction](https://stedolan.github.io/jq/manual/#Subtraction:-) is the best approach for this, here is another solution using [del](https://stedolan.github.io/jq/manual/#del\\(path_expression\\)) and [indices](https://stedolan.github.io/jq/manual/#indices\\(s\\)):\r\n\r\n    . as $d | .all | del(.[ indices($d.some[])[] ])\r\n\r\nIt may be of help when you want to know which elements were removed.  For example with the sample data and the `-c` (compact output) option, the following filter\r\n\r\n      . as $d\r\n    | .all\r\n    | [indices($d.some[])[]] as $found\r\n    | del(.[ $found[] ])\r\n    | &quot;all&quot;, $d.all, &quot;some&quot;, $d.some, &quot;removing indices&quot;, $found, &quot;result&quot;, .\r\n     \r\nproduces \r\n\r\n    &quot;all&quot;\r\n    [&quot;A&quot;,&quot;B&quot;,&quot;C&quot;,&quot;ABC&quot;]\r\n    &quot;some&quot;\r\n    [&quot;B&quot;,&quot;C&quot;]\r\n    &quot;removing indices&quot;\r\n    [1,2]\r\n    &quot;result&quot;\r\n    [&quot;A&quot;,&quot;ABC&quot;]",
                "title": "JQ: setdiff of two arrays"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 12,
        "last_activity_date": 1504109979,
        "creation_date": 1427906079,
        "question_id": 29396154,
        "body_markdown": "If I have an object with two arrays containing unique values in it\r\n\r\n    {&quot;all&quot;:[&quot;A&quot;,&quot;B&quot;,&quot;C&quot;,&quot;ABC&quot;],&quot;some&quot;:[&quot;B&quot;,&quot;C&quot;]}\r\n\r\nHow can I find `.all - .some`?\r\n\r\nIn this case I am looking for `[&quot;A&quot;,&quot;ABC&quot;]`",
        "link": "https://stackoverflow.com/questions/29396154/jq-setdiff-of-two-arrays",
        "title": "JQ: setdiff of two arrays"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 50,
                "is_accepted": true,
                "score": 50,
                "last_activity_date": 1486420534,
                "last_edit_date": 1486420534,
                "creation_date": 1427946117,
                "answer_id": 29404613,
                "question_id": 29404575,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Slurp it up with the `-s` option.\r\n\r\n    $ jq -s &#39;.&#39; &lt;&lt;&lt; &#39;{ &quot;a&quot;: 1 } { &quot;b&quot;: 2 }&#39;\r\n    [\r\n      {\r\n        &quot;a&quot;: 1\r\n      },\r\n      {\r\n        &quot;b&quot;: 2\r\n      }\r\n    ]\r\n\r\nAs another option, reading the values using `inputs` is a much more flexible alternative.  You&#39;ll usually want to use this in conjunction with the `-n` option to prevent the first value from being consumed prematurely.\r\n\r\n    $ jq -n &#39;[inputs]&#39; &lt;&lt;&lt; &#39;{ &quot;a&quot;: 1 } { &quot;b&quot;: 2 }&#39;",
                "title": "How to convert a JSON object stream into an array with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 44,
        "last_activity_date": 1630918577,
        "creation_date": 1427945871,
        "last_edit_date": 1495231709,
        "question_id": 29404575,
        "body_markdown": "I want to use `jq` to put a stream of json objects into a json array, for example, from \r\n\r\n    {&quot;a&quot;:1}\r\n    {&quot;b&quot;:2}\r\n\r\nto\r\n\r\n    [{&quot;a&quot;:1},\r\n    {&quot;b&quot;:2}]\r\n\r\nBut this would not work \r\n\r\n    echo &#39;\r\n    {&quot;a&quot;:1}\r\n    {&quot;b&quot;:2}\r\n    &#39;|jq &#39;[.]&#39;\r\n\r\nsince I got\r\n\r\n    [\r\n      {\r\n        &quot;a&quot;: 1\r\n      }\r\n    ]\r\n    [\r\n      {\r\n        &quot;b&quot;: 2\r\n      }\r\n    ]\r\n\r\n",
        "link": "https://stackoverflow.com/questions/29404575/how-to-convert-a-json-object-stream-into-an-array-with-jq",
        "title": "How to convert a JSON object stream into an array with jq"
    },
    {
        "tags": [
            "arrays",
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1428072605,
                "creation_date": 1428072605,
                "answer_id": 29434456,
                "question_id": 29429107,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You can use this filter:\r\n\r\n    select(\r\n        (map(.name == &quot;first_source&quot;) | any) and\r\n        (map(.name != &quot;second_source&quot;) | all)\r\n    )\r\n\r\nYou need to test all the elements of an array for an existence of the names.  You can do that by mapping each object to your condition and use the `any` or `all` filter appropriately.\r\n\r\nHere, you want to see if any item is named `&quot;first_source&quot;` and all items are not named `&quot;second_source&quot;`.",
                "title": "jq: select only an array which contains element A but not element B"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 5,
        "last_activity_date": 1428072605,
        "creation_date": 1428051321,
        "question_id": 29429107,
        "body_markdown": "My data is a series of JSON arrays. Each array has one or more elements with name and id keys:\r\n\r\n    [\r\n      {\r\n        &quot;name&quot;: &quot;first_source&quot;,\r\n        &quot;id&quot;: &quot;abcdef&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;second_source&quot;,\r\n        &quot;id&quot;: &quot;ghijkl&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;third_source&quot;,\r\n        &quot;id&quot;: &quot;opqrst&quot;\r\n      }\r\n    ]\r\n\r\nHow, using jq, do I select only the arrays which contain an element with &quot;first source&quot; as the name value, but which don&#39;t contain &quot;second_source&quot; as the name value of any element?\r\n\r\nThis only returns an _element_ for further processing:\r\n\r\n    jq &#39;.[] | select (.name == &quot;first_source&quot;) \r\n\r\nBut I clearly need to return the entire array for my scenario to work.",
        "link": "https://stackoverflow.com/questions/29429107/jq-select-only-an-array-which-contains-element-a-but-not-element-b",
        "title": "jq: select only an array which contains element A but not element B"
    },
    {
        "tags": [
            "json",
            "select",
            "key",
            "subset",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1983820,
                    "reputation": 2173,
                    "user_id": 1779702,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/W1SuZ.png?s=256",
                    "display_name": "Jon",
                    "link": "https://stackoverflow.com/users/1779702/jon"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1434343166,
                "post_id": 29518137,
                "comment_id": 49719153,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 12,
                "is_accepted": false,
                "score": 11,
                "last_activity_date": 1534884510,
                "last_edit_date": 1534884510,
                "creation_date": 1428505425,
                "answer_id": 29518397,
                "question_id": 29518137,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use this filter:\r\n\r\n    with_entries(\r\n        select(\r\n            .key as $k | any($keys | fromjson[]; . == $k)\r\n        )\r\n    )\r\n",
                "title": "jq: selecting a subset of keys from an object"
            },
            {
                "up_vote_count": 8,
                "is_accepted": false,
                "score": 7,
                "last_activity_date": 1491937343,
                "creation_date": 1491937343,
                "answer_id": 43354218,
                "question_id": 29518137,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is some additional clarification\r\n\r\nFor the input object `{&quot;key1&quot;:1, &quot;key2&quot;:2, &quot;key3&quot;:3}` I would like to drop all keys that are not in the set of desired keys `[&quot;key1&quot;,&quot;key3&quot;,&quot;key4&quot;]`\r\n\r\n     jq -n --argjson desired_keys &#39;[&quot;key1&quot;,&quot;key3&quot;,&quot;key4&quot;]&#39;  \\\r\n           --argjson input &#39;{&quot;key1&quot;:1, &quot;key2&quot;:2, &quot;key3&quot;:3}&#39; \\\r\n        &#39; $input\r\n        | with_entries(\r\n              select(\r\n                  .key == ($desired_keys[])\r\n              )\r\n           )&#39;\r\n`with_entries` converts `{&quot;key1&quot;:1, &quot;key2&quot;:2, &quot;key3&quot;:3}` into the following array of key value pairs and maps the select statement on the array and then turns the resulting array back into an object.\r\n\r\nHere is the inner object in the `with_entries` statement.\r\n\r\n    [\r\n      {\r\n        &quot;key&quot;: &quot;key1&quot;,\r\n        &quot;value&quot;: 1\r\n      },\r\n      {\r\n        &quot;key&quot;: &quot;key2&quot;,\r\n        &quot;value&quot;: 2\r\n      },\r\n      {\r\n        &quot;key&quot;: &quot;key3&quot;,\r\n        &quot;value&quot;: 3\r\n      }\r\n    ]\r\n\r\nwe can then select the keys from this array that meet our criteria.\r\n\r\nThis is where the magic happens... here is a look at whats going on in the middle of this command. The following command takes the expanded array of values and turns them into a list of objects that we can select from.\r\n\r\n    jq -cn &#39;{&quot;key&quot;:&quot;key1&quot;,&quot;value&quot;:1}, {&quot;key&quot;:&quot;key2&quot;,&quot;value&quot;:2}, {&quot;key&quot;:&quot;key3&quot;,&quot;value&quot;:3}\r\n          | select(.key == (&quot;key1&quot;, &quot;key3&quot;, &quot;key4&quot;))&#39;\r\n\r\nThis will yield the following result\r\n\r\n    {&quot;key&quot;:&quot;key1&quot;,&quot;value&quot;:1}\r\n    {&quot;key&quot;:&quot;key3&quot;,&quot;value&quot;:3}\r\n\r\nThe with entries command can be a little tricky but its easy to remember that it takes a filter and is defined as follows\r\n\r\n    def with_entries(f): to_entries|map(f)|from_entries;\r\n\r\nThis is the same as \r\n\r\n    def with_entries(f): [to_entries[] | f] | from_entries;\r\n\r\nThe other part of the question that confuses people is the multiple matches on the right hand side of the `==`\r\n\r\nConsider the following command. We see the output is an outer production of all the left hand lists and the right hand lists.\r\n\r\n    jq -cn &#39;1,2,3| . == (1,1,3)&#39;\r\n    true\r\n    true\r\n    false\r\n    false\r\n    false\r\n    false\r\n    false\r\n    false\r\n    true\r\n\r\nIf that predicate is in a select statement, we keep the input when the predicate is true. Note you can duplicate the inputs here too.\r\n\r\n    jq -cn &#39;1,2,3| select(. == (1,1,3))&#39;\r\n    1\r\n    1\r\n    3",
                "title": "jq: selecting a subset of keys from an object"
            },
            {
                "up_vote_count": 7,
                "is_accepted": false,
                "score": 7,
                "last_activity_date": 1669226738,
                "last_edit_date": 1669226738,
                "creation_date": 1491938447,
                "answer_id": 43354516,
                "question_id": 29518137,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Jeff&#39;s answer has a couple of unnecessary inefficiencies, both of which are addressed by the following, on the assumption that `--argjson keys` is used instead of `--arg keys`:\r\n\r\n    with_entries( select( .key as $k | $keys | index($k) ) )\r\n\r\nEven better, if your jq has `IN`:\r\n\r\n    with_entries(select(.key | IN($keys[])))",
                "title": "jq: selecting a subset of keys from an object"
            },
            {
                "up_vote_count": 46,
                "is_accepted": false,
                "score": 43,
                "last_activity_date": 1505801397,
                "creation_date": 1505801397,
                "answer_id": 46293052,
                "question_id": 29518137,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "solution with inside check:\r\n\r\n    jq &#39;with_entries(select([.key] | inside([&quot;key1&quot;, &quot;key2&quot;])))&#39;",
                "title": "jq: selecting a subset of keys from an object"
            },
            {
                "up_vote_count": 15,
                "is_accepted": true,
                "score": 14,
                "last_activity_date": 1505802287,
                "creation_date": 1505802287,
                "answer_id": 46293301,
                "question_id": 29518137,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "the inside operator works for most of time; however, I just found the inside operator has side effect, sometimes it selected keys not desired, suppose input is `{ &quot;key1&quot;: val1, &quot;key2&quot;: val2, &quot;key12&quot;: val12 }` and select by `inside([&quot;key12&quot;])` it will select both `&quot;key1&quot;` and `&quot;key12&quot;`\r\n\r\nuse the in operator if need an exact match: like this will select `.key2` and `.key12` only\r\n\r\n    jq &#39;with_entries(select(.key | in({&quot;key2&quot;:1, &quot;key12&quot;:1})))&#39;\r\n\r\nbecause the in operator checks key from an object only (or index `exists?` from an array), here it has to be written in an object syntax, with desired keys as keys, but values do not matter; the use of in operator is not a perfect one for this purpose, I would like to see the Javascript ES6 includes API&#39;s reverse version to be implemented as jq builtin\r\n\r\nhttps://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/includes\r\n\r\n    jq &#39;with_entries(select(.key | included([&quot;key2&quot;, &quot;key12&quot;])))&#39;\r\n\r\nto check an item `.key` is `included?` from an array",
                "title": "jq: selecting a subset of keys from an object"
            },
            {
                "up_vote_count": 21,
                "is_accepted": false,
                "score": 21,
                "last_activity_date": 1710839889,
                "last_edit_date": 1710839889,
                "creation_date": 1667561017,
                "answer_id": 74316272,
                "question_id": 29518137,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you are sure that all keys in the input array are present in the original object, you can use the [object construction][1] shortcut.\r\n\r\n```sh\r\n$ echo &#39;{&quot;1&quot;:&quot;a&quot;,&quot;2&quot;:&quot;b&quot;,&quot;3&quot;:&quot;c&quot;}&#39; | jq &#39;{&quot;1&quot;, &quot;3&quot;}&#39;\r\n{\r\n  &quot;1&quot;: &quot;a&quot;,\r\n  &quot;3&quot;: &quot;c&quot;\r\n}\r\n```\r\n\r\nNumbers should be quoted to force `jq` to interpret them as keys instead of literals. In the case of keys not resembling a number, quotes are not needed:\r\n\r\n```sh\r\n$ echo &#39;{&quot;key1&quot;:&quot;a&quot;,&quot;key2&quot;:&quot;b&quot;,&quot;key3&quot;:&quot;c&quot;}&#39; | jq &#39;{key1, key3}&#39;\r\n{\r\n  &quot;key1&quot;: &quot;a&quot;,\r\n  &quot;key3&quot;: &quot;c&quot;\r\n}\r\n```\r\n\r\nAdding a non-existent key will yield a null value, unlikely what OP wanted:\r\n\r\n```sh\r\n$ echo &#39;{&quot;1&quot;:&quot;a&quot;,&quot;2&quot;:&quot;b&quot;,&quot;3&quot;:&quot;c&quot;}&#39; | jq &#39;{&quot;1&quot;, &quot;3&quot;, &quot;4&quot;}&#39;\r\n{\r\n  &quot;1&quot;: &quot;a&quot;,\r\n  &quot;3&quot;: &quot;c&quot;,\r\n  &quot;4&quot;: null\r\n}\r\n```\r\n\r\nbut those can be filtered out:\r\n\r\n```sh\r\n$ echo &#39;{&quot;1&quot;:&quot;a&quot;,&quot;2&quot;:&quot;b&quot;,&quot;3&quot;:&quot;c&quot;}&#39; | jq &#39;{&quot;1&quot;, &quot;3&quot;, &quot;4&quot;} | with_entries(select(.value != null))&#39;\r\n{\r\n  &quot;1&quot;: &quot;a&quot;,\r\n  &quot;3&quot;: &quot;c&quot;\r\n}\r\n```\r\n\r\nAlthough this answer doesn&#39;t receive a valid input json array as OP asked, I find it useful for just filtering some keys you know are present.\r\n\r\nAn example use case: get `aud` and `iss` from a JWT. The following is very succinct:\r\n\r\n```sh\r\necho &quot;jwt-as-json&quot; | jq &#39;{aud, iss}&#39;\r\n```\r\n\r\n\r\n[1]: https://jqlang.github.io/jq/manual/#object-construction",
                "title": "jq: selecting a subset of keys from an object"
            }
        ],
        "is_answered": true,
        "answer_count": 6,
        "score": 50,
        "last_activity_date": 1710839889,
        "creation_date": 1428504740,
        "last_edit_date": 1495539994,
        "question_id": 29518137,
        "body_markdown": "Given an input json string of keys from an array, return an object with only the entries that had keys in the original object and in the input array.\r\n\r\nI have a solution but I think that it isn&#39;t elegant (`{($k):$input[$k]}` feels especially clunky...) and that this is a chance for me to learn.\r\n\r\n    jq -n &#39;{&quot;1&quot;:&quot;a&quot;,&quot;2&quot;:&quot;b&quot;,&quot;3&quot;:&quot;c&quot;}&#39;   \\\r\n        | jq --arg keys &#39;[&quot;1&quot;,&quot;3&quot;,&quot;4&quot;]&#39; \\\r\n        &#39;. as $input \r\n         | ( $keys | fromjson )\r\n         | map( . as $k\r\n              | $input\r\n              | select(has($k))\r\n              | {($k):$input[$k]}\r\n              )\r\n         | add&#39;\r\n\r\nAny ideas how to clean this up?\r\n\r\nI feel like [Extracting selected properties from a nested JSON object with jq](https://stackoverflow.com/questions/29259249/extracting-selected-properties-from-a-nested-json-object-with-jq) is a good starting place but i cannot get it to work.",
        "link": "https://stackoverflow.com/questions/29518137/jq-selecting-a-subset-of-keys-from-an-object",
        "title": "jq: selecting a subset of keys from an object"
    },
    {
        "tags": [
            "bash",
            "ubuntu",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 182974,
                    "reputation": 6375,
                    "user_id": 418066,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/38yuw.png?s=256",
                    "display_name": "Biffen",
                    "link": "https://stackoverflow.com/users/418066/biffen"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1428670458,
                "post_id": 29561830,
                "comment_id": 47273688,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 3676284,
                    "reputation": 3635,
                    "user_id": 3062311,
                    "user_type": "registered",
                    "accept_rate": 96,
                    "profile_image": "https://www.gravatar.com/avatar/a958e397e193cb2a53ee1b6862c72e1b?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "sop",
                    "link": "https://stackoverflow.com/users/3062311/sop"
                },
                "reply_to_user": {
                    "account_id": 182974,
                    "reputation": 6375,
                    "user_id": 418066,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/38yuw.png?s=256",
                    "display_name": "Biffen",
                    "link": "https://stackoverflow.com/users/418066/biffen"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1428670685,
                "post_id": 29561830,
                "comment_id": 47273829,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1428673734,
                "creation_date": 1428673734,
                "answer_id": 29563176,
                "question_id": 29561830,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "I found it:\r\n\r\n     echo $(echo $MESSAGE | jq .photo.folder -r)$&#39;/&#39;$(echo $MESSAGE | jq .photo.file -r)",
                "title": "how to echo a slash in ubuntu"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1428692313,
                "last_edit_date": 1428692313,
                "creation_date": 1428678897,
                "answer_id": 29564980,
                "question_id": 29561830,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You only need a single call to `jq`: use the `add` function for string concatenation:\r\n\r\n    jq -r &#39;[.photo.folder, &quot;/&quot;, .photo.file] | add&#39; &lt;&lt; END\r\n    {&quot;photo&quot;: {&quot;folder&quot;:&quot;blah&quot;, &quot;file&quot;:&quot;halb&quot;}}\r\n    END\r\n\r\n&lt;!-- --&gt;\r\n\r\n    blah/halb\r\n\r\n---\r\nSimpler: `jq -r &#39;.photo.folder+ &quot;/&quot;+ .photo.file&#39;`",
                "title": "how to echo a slash in ubuntu"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1428692313,
        "creation_date": 1428669949,
        "last_edit_date": 1428679414,
        "question_id": 29561830,
        "body_markdown": "I have a string that is a json (that is stored in `MESSAGE`):\r\n\r\n    {&quot;folder&quot;:&quot;blah&quot;, &quot;file&quot;:&quot;halb&quot;}\r\n\r\nand I want to print in echo `blah/halb`.\r\n\r\nI have tried:\r\n \r\n - `echo $MESSAGE | jq .photo.folder -r &quot;/&quot; echo $MESSAGE | jq .photo.file -r` and it seems that it stays hanged\r\n - `echo $MESSAGE | jq .photo.folder -r &quot;\\/&quot; echo $MESSAGE | jq .photo.file -r` and it seems that it says `jq: \\/: No such file or directory\r\njq: echo: No such file or directory`\r\n\r\nHow do I print the slash?",
        "link": "https://stackoverflow.com/questions/29561830/how-to-echo-a-slash-in-ubuntu",
        "title": "how to echo a slash in ubuntu"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 16,
                "is_accepted": true,
                "score": 16,
                "last_activity_date": 1428675765,
                "creation_date": 1428675765,
                "answer_id": 29563912,
                "question_id": 29563145,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "I&#39;d do the whole thing in a `jq` filter:\r\n\r\n    echo &quot;$MESSAGE&quot; | jq -r &#39;[ .folder, .file ] | join(&quot;/&quot;)&#39;\r\n\r\nIn the event that you want to do it with bash (or to learn how to do this sort of thing in bash), two points:\r\n\r\n* Shell variables should almost always be quoted when they are used (i.e., `&quot;$MESSAGE&quot;` instead of `$MESSAGE`). You will run into funny problems if one of the strings in your JSON ever contains a shell metacharacter (such as `*`) and you forgot to do that; the string will be subject to shell expansion (and that `*` will be expanded into a list of files in the current working directory).\r\n* A shell `if` accepts as condition a command, and the decision where to branch is made depending on the exit status of that command (true if the exit status is `0`, false otherwise). The `[` you attempted to use is just a command (an alias for `test`, see `man test`) and not special in any way.\r\n\r\nSo, the goal is to construct a command that exits with `0` if the JSON object has a `folder` property, non-zero otherwise. `jq` has a `-e` option that makes it return `0` if the last output value was not `false` or `null` and non-zero otherwise, so we can write\r\n\r\n    if echo &quot;$MESSAGE&quot; | jq -e &#39;has(&quot;folder&quot;)&#39; &gt; /dev/null; then\r\n        echo &quot;$MESSAGE&quot; | jq -r &#39;.folder + &quot;/&quot; + .file&#39;\r\n    else\r\n        echo &quot;$MESSAGE&quot; | jq -r .file\r\n    fi\r\n\r\nThe `&gt; /dev/null` bit redirects the output from `jq` to `/dev/null` (where it is ignored) so that we don&#39;t see it on the console.",
                "title": "verify that a json field exists with jq and bash?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 10,
        "last_activity_date": 1428676095,
        "creation_date": 1428673639,
        "last_edit_date": 1428676095,
        "question_id": 29563145,
        "body_markdown": "I have a script that uses jq for parsing a json string `MESSAGE` (that is read from another application). Meanwhile the json has changed and a field is split in 2 fields: `file_path` is now split into `folder` and `file`. The script was reading the `file_path`, now the `folder` may not be present, so for creating the path of the file I have to verify if the field is there. I have search for a while on the internet, and manage to do:\r\n\r\n    echo $(echo $MESSAGE | jq .folder -r)$&#39;/&#39;$(echo $MESSAGE | jq .file -r)\r\n    \r\n    if [ $MESSAGE | jq &#39;has(&quot;.folder&quot;)&#39; -r  ]\r\n    then\r\n            echo $(echo $MESSAGE | jq .folder -r)$&#39;/&#39;$(echo $MESSAGE | jq .file -r)\r\n    else\r\n            echo $(echo $MESSAGE | jq .file -r)\r\n    fi\r\n\r\nwhere `MESSAGE=&#39;{&quot;folder&quot;:&quot;FLDR&quot;,&quot;file&quot;:&quot;fl&quot;}&#39;` or `MESSAGE=&#39;{&quot;file&quot;:&quot;fl&quot;}&#39;`\r\n\r\nThe first line is printing `FLDR/fl` or `null/fl` if the folder field is not present. So I have thought to create an if that is verifying if the folder field is present or not, but it seems that I am doing it wrong and cannot figure out what is wrong. The output is\r\n\r\n    bash: [: missing `]&#39;\r\n    jq: ]: No such file or directory\r\n    null/fl\r\n",
        "link": "https://stackoverflow.com/questions/29563145/verify-that-a-json-field-exists-with-jq-and-bash",
        "title": "verify that a json field exists with jq and bash?"
    },
    {
        "tags": [
            "json",
            "linux",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1428853095,
                "creation_date": 1428853095,
                "answer_id": 29591233,
                "question_id": 29590304,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "What you are looking for is:\r\n\r\n    jq &#39;[.[] | {name:.foo, value:.bar}]&#39;",
                "title": "convert a json file"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1428853775,
                "creation_date": 1428853775,
                "answer_id": 29591338,
                "question_id": 29590304,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Use [`map`](http://stedolan.github.io/jq/manual/#mapx) instead.\r\n\r\n    map({ name: .foo, value: .bar })",
                "title": "convert a json file"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1428853775,
        "creation_date": 1428847591,
        "last_edit_date": 1428851191,
        "question_id": 29590304,
        "body_markdown": "I have a json file like below :\r\n\r\n    [   \r\n        {&quot;foo&quot;: 42, &quot;bar&quot;: &quot;less interesting data&quot;},\r\n        {&quot;foo&quot;: 50, &quot;bar&quot;: &quot;big data&quot;}\r\n    ]\r\n\r\nI&#39;d like to use jq to convert its content to the following :\r\n\r\n    [   \r\n        {&quot;name&quot;: 42, &quot;value&quot;: &quot;less interesting data&quot;},\r\n        {&quot;name&quot;: 50, &quot;value&quot;: &quot;big data&quot;}\r\n    ]\r\n\r\nI tried the command: \r\n\r\n    jq &#39; .[] | {name:.foo, value:.bar}&#39;,\r\n\r\nbut there&#39;s no comma between {...} sections :\r\n\r\n    {   \r\n      &quot;name&quot;: 42, \r\n      &quot;value&quot;: &quot;less interesting data&quot;\r\n    }   \r\n    {   \r\n      &quot;name&quot;: 50, \r\n      &quot;value&quot;: &quot;big data&quot;\r\n    }\r\n\r\nCan someone help me? \r\n",
        "link": "https://stackoverflow.com/questions/29590304/convert-a-json-file",
        "title": "convert a json file"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 8,
                "is_accepted": false,
                "score": 8,
                "last_activity_date": 1428866902,
                "creation_date": 1428866902,
                "answer_id": 29593688,
                "question_id": 29592224,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You can make use of the `//` operator to mimic (IMHO) nicer if-else trees in conjunction with various filtering filters.  Makes it rather easy to follow, compared to a large if-else tree.\r\n\r\n&lt;!-- language: lang-none --&gt;\r\n\r\n    .Actions |= map(\r\n        (select(.Number == 1015) |\r\n            .RollbackPoint = &quot;1012&quot;\r\n        ) //\r\n        (select(.Number == 1012) |\r\n            .Parameters |= map((select(.Name == &quot;accountType&quot;) | .Value = &quot;AWS&quot;) // .)\r\n        ) //\r\n        .\r\n    )\r\n\r\n",
                "title": "Having trouble searching and replacing in my JSON using jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1503606640,
                "creation_date": 1503606640,
                "answer_id": 45870396,
                "question_id": 29592224,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is another jq solution\r\n\r\n     .Actions[] |= (\r\n          if .Number == 1015 then .RollbackPoint = &quot;1012&quot; else . end\r\n        | if .Number == 1012 then .Parameters[] |= (\r\n             if .Name == &quot;accountType&quot; then .Value = &quot;AWS&quot; else . end\r\n          ) else . end\r\n     )\r\n",
                "title": "Having trouble searching and replacing in my JSON using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 5,
        "last_activity_date": 1503606640,
        "creation_date": 1428859010,
        "question_id": 29592224,
        "body_markdown": "I have been looking at trying to get this to work for a number of days but I am stuck.\r\n\r\nI have a json data structure with values in it that I want to update, essentially using my json as a database to store configuration values.  Here is my JSON:\r\n\r\n    {\r\n      &quot;Actions&quot;: [\r\n        {\r\n          &quot;Number&quot;: 1012,\r\n          &quot;RollbackPoint&quot;: &quot;xxx_1012_RollbackPoint_xxx&quot;,\r\n          &quot;Parameters&quot;: [\r\n            {\r\n              &quot;Name&quot;: &quot;accountType&quot;,\r\n              &quot;Value&quot;: &quot;xxx_1012_accountType_xxx&quot;\r\n            },\r\n            {\r\n              &quot;Name&quot;: &quot;userPassword&quot;,\r\n              &quot;Value&quot;: &quot;xxx_1012_userPassword_xxx&quot;\r\n            }\r\n          ]\r\n        },\r\n        {\r\n          &quot;Number&quot;: 1015,\r\n          &quot;RollbackPoint&quot;: &quot;xxx_1015_RollbackPoint_xxx&quot;,\r\n          &quot;Parameters&quot;: [\r\n            {\r\n              &quot;Name&quot;: &quot;accountType&quot;,\r\n              &quot;Value&quot;: &quot;xxx_1015_accountType_xxx&quot;\r\n            },\r\n            {\r\n              &quot;Name&quot;: &quot;skipExport&quot;,\r\n              &quot;Value&quot;: &quot;xxx_1015_skipExport_xxx&quot;\r\n            }\r\n          ]\r\n        }\r\n      ]\r\n    }\r\n\r\nI want to perform two updates\r\n\r\n1.  Update RollbackPoint to &quot;1012&quot; where Number = 1015\r\n2.  Update value to &quot;AWS&quot; where name = &quot;accountType&quot; under Parameters, where Number = 1012\r\n\r\nSo far the closest I have got to is using this:\r\n\r\n    cat json.txt | jq  &#39;.[] | map(. + {RollbackPoint:(if (.&quot;Number&quot;) == 1015 then &quot;1015&quot; else .RollbackPoint end)})&#39;\r\n\r\n \r\n\r\nBut this strips off the Actions[] element so its no good for me, I don&#39;t know where to even start on update 2...\r\n\r\nAny help would be greatly appreciated, over 5 hours on google and I am still nowhere near.\r\n\r\nMany thanks\r\nMatt",
        "link": "https://stackoverflow.com/questions/29592224/having-trouble-searching-and-replacing-in-my-json-using-jq",
        "title": "Having trouble searching and replacing in my JSON using jq"
    },
    {
        "tags": [
            "json",
            "bash",
            "curl",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 94756,
                    "reputation": 81440,
                    "user_id": 258523,
                    "user_type": "registered",
                    "accept_rate": 83,
                    "profile_image": "https://www.gravatar.com/avatar/f2c517550a86045c885bc36eca722b9d?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Etan Reisner",
                    "link": "https://stackoverflow.com/users/258523/etan-reisner"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1429017695,
                "post_id": 29628089,
                "comment_id": 47399824,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 4413369,
                    "reputation": 21,
                    "user_id": 3595644,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d83956bff23ec7cb76ef68d36e88f03b?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Lewis",
                    "link": "https://stackoverflow.com/users/3595644/lewis"
                },
                "reply_to_user": {
                    "account_id": 94756,
                    "reputation": 81440,
                    "user_id": 258523,
                    "user_type": "registered",
                    "accept_rate": 83,
                    "profile_image": "https://www.gravatar.com/avatar/f2c517550a86045c885bc36eca722b9d?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Etan Reisner",
                    "link": "https://stackoverflow.com/users/258523/etan-reisner"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1429025150,
                "post_id": 29628089,
                "comment_id": 47405267,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1429018579,
                "creation_date": 1429018579,
                "answer_id": 29628849,
                "question_id": 29628089,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "My [Xidel](http://videlibri.sourceforge.net/xidel.html) can do it all at once by selecting the JSON with a XPath-like query:\r\n\r\nE.g. return all ids where the `WebsiteName` contains &quot;site2&quot; from an array of objects:\r\n\r\n    xidel /tmp/x.json -e &#39;$json()[contains((.).WebsiteName, &quot;site2&quot;)]/TestID&#39;\r\n\r\nOr e.g. to download the original JSON and then make the HTTP request with the ids:\r\n\r\n    xidel http://statuscake.com/your-url... -f &#39;$json()[contains((.).WebsiteName, &quot;site2&quot;)]/TestID!x&quot;/your-delete-url{.}...&quot;&#39;\r\n",
                "title": "Bash script traversing a multi-line JSON object using jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1429018787,
                "creation_date": 1429018787,
                "answer_id": 29628943,
                "question_id": 29628089,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Assuming you have a bash 4+ and assuming the json is valid (does not contain newlines in strings, etc.) this works:\r\n\r\n    $ echo &quot;$data&quot;\r\n    [{&quot;TestID&quot;: 123, &quot;WebsiteName&quot;: &quot;SomeSite1&quot;}, {&quot;TestID&quot;: 1234, &quot;WebsiteName&quot;:\r\n    &quot;SomeSite2&quot;}, {&quot;TestID&quot;: 555, &quot;WebsiteName&quot;: &quot;foo*ba@r blah[54]quux{4,5,6}&quot;}]\r\n    $ declare -A arr\r\n    $ while IFS= read -r line; do\r\n        eval &quot;$line&quot;\r\n    done &lt; &lt;(jq -M -r &#39;.[] | @sh &quot;arr[\\(.WebsiteName)]+=\\(.TestID)&quot;&#39; &lt;&lt;&lt;&quot;$data&quot;)\r\n    $ declare -p arr\r\n    declare -A arr=&#39;([&quot;foo*ba@r blah[54]quux{4,5,6}&quot;]=&quot;555&quot; [SomeSite2]=&quot;1234&quot; [SomeSite1]=&quot;123&quot; )&#39;",
                "title": "Bash script traversing a multi-line JSON object using jq"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1429126493,
                "creation_date": 1429126493,
                "answer_id": 29659250,
                "question_id": 29628089,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "If I&#39;m getting your question right, it sounds like what you want is to, for each element, select those where `.WebsiteName == &quot;needle&quot;`, and then get `.TestID` from it. You can do just that:\r\n\r\n`.[] | select(.WebsiteName == &quot;needle&quot;) | .TestID`\r\n\r\nIf you want an array as the result, you can wrap the above script in square brackets.\r\n\r\nThe jq filters `startswith` and `endswith` may be of interest to you. If you&#39;re going to pass the result back to cURL, you may also be interested in the `@sh` formatting filter and the `-r` command-line flag.",
                "title": "Bash script traversing a multi-line JSON object using jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1503676360,
                "creation_date": 1503676360,
                "answer_id": 45885211,
                "question_id": 29628089,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a solution using only jq primitives.\r\n\r\n      .[]\r\n    | if .WebsiteName == &quot;SomeSite1&quot; then .TestID else empty end\r\n\r\n\r\nThis is essentially the same as [Santiago](https://stackoverflow.com/users/3899165/santiago-lapresta)&#39;s answer but if you are new to jq it may be informative because [select/1](https://github.com/stedolan/jq/blob/master/src/builtin.jq#L4) is defined as\r\n\r\n     def select(f): if f then . else empty end;\r\n",
                "title": "Bash script traversing a multi-line JSON object using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": 2,
        "last_activity_date": 1503676360,
        "creation_date": 1429016591,
        "last_edit_date": 1429016776,
        "question_id": 29628089,
        "body_markdown": "I have to curl to a site (statuscake.com) that sends multiple items back in a JSON, each line of which contains multiple items. I want to extract from each line two of them, WebsiteName and TestID, so I can check if WebsiteName matches the one I&#39;m interested in, get the TestID out and pass this to a second curl statement to delete the test.\r\n\r\nAlthough it&#39;s more complex, the JSON that comes back is essentially of the form\r\n\r\n    [{&quot;TestID&quot;: 123, &quot;WebsiteName&quot;: &quot;SomeSite1&quot;}, {&quot;TestID&quot;: 1234, &quot;WebsiteName&quot;: &quot;SomeSite2&quot;}]\r\n\r\nI can&#39;t seem to find a magic jq command to do it all in one - if there is one, I&#39;d be really happy to see it.\r\n\r\nI&#39;ve got \r\n\r\n    cat $data | jq &#39;[.[] | .WebsiteName]&#39; \r\n\r\nto get an array of the website names (and a very similar one for the TestIDs, but I think I&#39;ve done something daft. data is the information coming back from the curl to get the JSON and that&#39;s populated OK. \r\n\r\nI want to be able to assign these to two arrays, names and ids, then search names for the index of the relevant name, grab the id from ids and pass that to the curl. Unless there&#39;s a better way.\r\n\r\nAny advice please?",
        "link": "https://stackoverflow.com/questions/29628089/bash-script-traversing-a-multi-line-json-object-using-jq",
        "title": "Bash script traversing a multi-line JSON object using jq"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1429130607,
                "creation_date": 1429130607,
                "answer_id": 29660534,
                "question_id": 29659436,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Move everything into the `select` condition.  You don&#39;t need to do two separate calls to jq.\r\n\r\n    $ echo &#39;[&quot;a&quot;,&quot;b&quot;,&quot;c&quot;,&quot;d&quot;,&quot;e&quot;]&#39; | jq --arg names &#39;a c&#39;\r\n        &#39;map(select(. == ($names | split(&quot; &quot;)[])) | { name: ., foo: &quot;bar&quot; })&#39;\r\n    [\r\n      {\r\n        &quot;name&quot;: &quot;a&quot;,\r\n        &quot;foo&quot;: &quot;bar&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;c&quot;,\r\n        &quot;foo&quot;: &quot;bar&quot;\r\n      }\r\n    ]",
                "title": "JQ: Select objects with key&#39;s value in set of values"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1503677788,
                "creation_date": 1503677788,
                "answer_id": 45885617,
                "question_id": 29659436,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "To [ThorSummoner](https://stackoverflow.com/users/1695680/thorsummoner)&#39;s point,\r\nhere is a less perl-esqe solution that uses **--argjson** and **inside** with\r\ncomments on separate lines that takes advantage of shell `&#39;` behavior:\r\n\r\n    $ echo &#39;[&quot;a&quot;,&quot;b&quot;,&quot;c&quot;,&quot;d&quot;,&quot;e&quot;]&#39; | jq --argjson wanted &#39;[&quot;a&quot;,&quot;c&quot;]&#39; &#39;\r\n      .[]                          # break array into elements\r\n    | if ([.]|inside($wanted))     # if element is in wanted\r\n      then {name: ., foo:&quot;bar&quot;}    # generate desired output\r\n      else empty                   # otherwise generate nothing\r\n      end\r\n    &#39;\r\n",
                "title": "JQ: Select objects with key&#39;s value in set of values"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 3,
        "last_activity_date": 1503677788,
        "creation_date": 1429127090,
        "question_id": 29659436,
        "body_markdown": "I have an array of json objects and I would like to extract a subset of the array such that the `.name` field matches a set of input strings.\r\n\r\nfor example I would like to accomplish the following.\r\n\r\n    jq -n &#39;[&quot;a&quot;,&quot;b&quot;,&quot;c&quot;,&quot;d&quot;,&quot;e&quot;] | map({name:.,foo:&quot;bar&quot;})&#39; \\\r\n      | jq &#39;map(select(.name==&quot;a&quot; or .name==&quot;c&quot;))&#39;\r\n\r\nI&#39;ve come up with the following solution, but my usage of `[...]` and `add` seems like I am missing something clever. \r\n\r\n    jq -n &#39;[&quot;a&quot;,&quot;b&quot;,&quot;c&quot;,&quot;d&quot;,&quot;e&quot;] | map({name:.,foo:&quot;bar&quot;})&#39; \\\r\n      | jq --arg name &#39;a c&#39; &#39;\r\n          [\r\n            ( $name | split(&quot; &quot;) )[] as $name\r\n            | map( select( .name == $name ) )\r\n            | add\r\n          ]&#39;\r\n\r\nAlso, this solution forces me to iterate over the input array multiple times instead of a single pass. Any other ideas how I could solve this?",
        "link": "https://stackoverflow.com/questions/29659436/jq-select-objects-with-keys-value-in-set-of-values",
        "title": "JQ: Select objects with key&#39;s value in set of values"
    },
    {
        "tags": [
            "json",
            "csv",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 166270,
                    "reputation": 135171,
                    "user_id": 390278,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/84715fec547362389d02f5be0ed12814?s=256&d=identicon&r=PG",
                    "display_name": "Jeff Mercado",
                    "link": "https://stackoverflow.com/users/390278/jeff-mercado"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1429393979,
                "post_id": 29663187,
                "comment_id": 47580836,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 4624068,
                    "reputation": 54457,
                    "user_id": 3748349,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/ArUlH.png?s=256",
                    "display_name": "Hans Z.",
                    "link": "https://stackoverflow.com/users/3748349/hans-z"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1429478574,
                "post_id": 29663187,
                "comment_id": 47605222,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 22475,
                    "reputation": 4560,
                    "user_id": 55478,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/623e20ca82873cf721c7ab7cc9d53cd8?s=256&d=identicon&r=PG",
                    "display_name": "Noah Sussman",
                    "link": "https://stackoverflow.com/users/55478/noah-sussman"
                },
                "edited": false,
                "score": 5,
                "creation_date": 1444838267,
                "post_id": 29663187,
                "comment_id": 54072041,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 10,
                "is_accepted": false,
                "score": 10,
                "last_activity_date": 1517049993,
                "last_edit_date": 1517049993,
                "creation_date": 1429372024,
                "answer_id": 29719472,
                "question_id": 29663187,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "I had a little play and came up with this. But *it may not be the best way*, and I&#39;d be interested to see *what your attempts were like*, because after all if we both came at a solution I&#39;m sure it&#39;d be twice as good!\r\n\r\nBut I would start from something like:\r\n\r\n    true as $doHeaders\r\n    | . / &quot;\\n&quot;\r\n    | map(. / &quot;, &quot;)\r\n    | (if $doHeaders then .[0] else [range(0; (.[0] | length)) | tostring] end) as $headers\r\n    | .[if $doHeaders then 1 else 0 end:][]\r\n    | . as $values\r\n    | keys\r\n    | map({($headers[.]): $values[.]})\r\n\r\n[**Working Example**][1]\r\n\r\nThe variable `$doHeaders` controls whether to read the top line as a header line. In your case you want it as true, but I added it for future SO users and because, well, I had an excellent breakfast today and the weather is lovely, so why not?\r\n\r\nLittle explanation:\r\n\r\n1) `. / &quot;\\n&quot;` Split by line...\r\n\r\n2) `map(. / &quot;, &quot;)` ... and comma (**Big gotcha:** In your version, you&#39;ll want to use a regex based split because like this you&#39;ll split on commas inside quotation marks too. I just used this because it&#39;s terse, and that makes my solution look cool right?)\r\n\r\n3) `if $doHeaders then...` Here we create an array of strings keys or numbers depending on the number of elements in the first row and whether the first row is a header row\r\n\r\n4) `.[if $doHeaders then 1 else 0 end:]` Ok, so trim off the top line if it&#39;s a header\r\n\r\n5) `map({($headers[.]): $values[.]})` Above we go over each row in the former csv, and put the `$values` into a variable and the keys into a pipe. Then we construct your desired object.\r\n\r\nOf course you&#39;ll want to use a few regexes to fill in the gotchas, but I hope that starts you on the way.\r\n\r\n\r\n  [1]: https://jqplay.org/jq?q=true%20as%20%24doHeaders%20%7C%20.%20%2F%20%22%5Cn%22%20%7C%20map%28.%20%2F%20%22%2C%20%22%29%20%7C%20%28if%20%24doHeaders%20then%20.%5B0%5D%20else%20%5Brange%280%3B%20%28.%5B0%5D%20%7C%20length%29%29%20%7C%20tostring%5D%20end%29%20as%20%24headers%20%7C%20.%5Bif%20%24doHeaders%20then%201%20else%200%20end%3A%5D%20%7C%20.%5B%5D%20%7C%20.%20as%20%24values%20%7C%20keys%20%7C%20map%28%7B%28%24headers%5B.%5D%29%3A%20%24values%5B.%5D%7D%29&amp;j=%22name%2C%20age%2C%20gender%0D%0Ajohn%2C%2020%2C%20male%0D%0Ajane%2C%2030%2C%20female%0D%0Abob%2C%2025%2C%20male%22",
                "title": "CSV to JSON using jq"
            },
            {
                "up_vote_count": 45,
                "is_accepted": false,
                "score": 45,
                "last_activity_date": 1567162049,
                "last_edit_date": 1567162049,
                "creation_date": 1439524964,
                "answer_id": 32002086,
                "question_id": 29663187,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "In short - yes, except maybe for the one-liner bit.\r\n    \r\njq is often well-suited to text wrangling, and this is especially true of versions with regex support.  With regex support, for example, the trimming required by the given problem statement is trivial.\r\n    \r\nSince jq 1.5rc1 includes regex support and has been available since Jan 1, 2015, the following program assumes a version of jq 1.5; if you wish to make it work with jq 1.4, then see the two &quot;For jq 1.4&quot; comments.  \r\n    \r\nPlease also note that this program does not handle CSV in all its generality and complexity. (For a similar approach that does handle CSV more generally, see https://github.com/stedolan/jq/wiki/Cookbook#convert-a-csv-file-with-headers-to-json)\r\n    \r\n    # objectify/1 takes an array of string values as inputs, converts\r\n    # numeric values to numbers, and packages the results into an object\r\n    # with keys specified by the &quot;headers&quot; array\r\n    def objectify(headers):\r\n      # For jq 1.4, replace the following line by: def tonumberq: .;\r\n      def tonumberq: tonumber? // .;\r\n      . as $in\r\n      | reduce range(0; headers|length) as $i ({}; .[headers[$i]] = ($in[$i] | tonumberq) );\r\n    \r\n    def csv2table:\r\n      # For jq 1.4, replace the following line by:  def trim: .;\r\n      def trim: sub(&quot;^ +&quot;;&quot;&quot;) |  sub(&quot; +$&quot;;&quot;&quot;);\r\n      split(&quot;\\n&quot;) | map( split(&quot;,&quot;) | map(trim) );\r\n    \r\n    def csv2json:\r\n      csv2table\r\n      | .[0] as $headers\r\n      | reduce (.[1:][] | select(length &gt; 0) ) as $row\r\n          ( []; . + [ $row|objectify($headers) ]);\r\n    \r\n    csv2json\r\n\r\nExample (assuming csv.csv is the given CSV text file):\r\n\r\n    $ jq -R -s -f csv2json.jq csv.csv\r\n    [\r\n      {\r\n        &quot;name&quot;: &quot;john&quot;,\r\n        &quot;age&quot;: 20,\r\n        &quot;gender&quot;: &quot;male&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;jane&quot;,\r\n        &quot;age&quot;: 30,\r\n        &quot;gender&quot;: &quot;female&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;bob&quot;,\r\n        &quot;age&quot;: 25,\r\n        &quot;gender&quot;: &quot;male&quot;\r\n      }\r\n    ]\r\n",
                "title": "CSV to JSON using jq"
            },
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1718629137,
                "last_edit_date": 1718629137,
                "creation_date": 1503692841,
                "answer_id": 45888945,
                "question_id": 29663187,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is a solution that assumes you run jq with `-s` and `-R` options.\r\n\r\n    [\r\n      [                                               \r\n        split(&quot;\\n&quot;)[]                  # transform csv input into array\r\n      | split(&quot;, &quot;)                    # where first element has key names\r\n      | select(length==3)              # and other elements have values\r\n      ]                                \r\n      | {h:.[0], v:.[1:][]}            # {h:[keys], v:[values]}\r\n      | [.h, (.v|map(tonumber?//.))]   # [ [keys], [values] ]\r\n      | [ transpose[]                  # [ [key,value], [key,value], ... ]\r\n          | {key:.[0], value:.[1]}     # [ {&quot;key&quot;:key, &quot;value&quot;:value}, ... ]\r\n        ]\r\n      | from_entries                   # { key:value, key:value, ... }\r\n    ]\r\n\r\nSample run:\r\n\r\n&lt;!-- language: shell --&gt;\r\n    jq -s -R -f filter.jq data.csv\r\n\r\nSample output\r\n\r\n    [\r\n      {\r\n        &quot;name&quot;: &quot;john&quot;,\r\n        &quot;age&quot;: 20,\r\n        &quot;gender&quot;: &quot;male&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;jane&quot;,\r\n        &quot;age&quot;: 30,\r\n        &quot;gender&quot;: &quot;female&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;bob&quot;,\r\n        &quot;age&quot;: 25,\r\n        &quot;gender&quot;: &quot;male&quot;\r\n      }\r\n    ]\r\n    ",
                "title": "CSV to JSON using jq"
            },
            {
                "up_vote_count": 19,
                "is_accepted": false,
                "score": 19,
                "last_activity_date": 1542633374,
                "creation_date": 1542633374,
                "answer_id": 53375468,
                "question_id": 29663187,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "As of 2018, a modern no code solution would be to use Python tool `csvkit` has `csvjson data.csv &gt; data.json`.\r\n\r\nSee their documentation https://csvkit.readthedocs.io/en/1.0.2/\r\n\r\nThe toolkit is also very handy and complementary to `jq` if your script has to debug both `csv` and `json` formats.\r\n\r\n\r\nYou might also want to check a powerful tool called [visidata][1]. Here is a [screencast case study][2] that is similar to the original poster&#39;s. You can also generate script from `visidata`\r\n\r\n\r\n  [1]: https://visidata.org\r\n  [2]: https://www.youtube.com/watch?time_continue=293&amp;v=j0qn8OIiV-w",
                "title": "CSV to JSON using jq"
            },
            {
                "up_vote_count": 41,
                "is_accepted": false,
                "score": 41,
                "last_activity_date": 1718629019,
                "last_edit_date": 1718629019,
                "creation_date": 1546440512,
                "answer_id": 54008382,
                "question_id": 29663187,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "with Miller (http://johnkerl.org/miller/doc/) is very simple. Using this input.csv file\r\n\r\n&lt;!-- language: none --&gt;\r\n    name,age,gender\r\n    john,20,male\r\n    jane,30,female\r\n    bob,25,male\r\n\r\nand running\r\n\r\n&lt;!-- language: shell --&gt;\r\n    mlr --c2j --jlistwrap cat input.csv\r\n\r\nYou will have\r\n\r\n    [\r\n    { &quot;name&quot;: &quot;john&quot;, &quot;age&quot;: 20, &quot;gender&quot;: &quot;male&quot; }\r\n    ,{ &quot;name&quot;: &quot;jane&quot;, &quot;age&quot;: 30, &quot;gender&quot;: &quot;female&quot; }\r\n    ,{ &quot;name&quot;: &quot;bob&quot;, &quot;age&quot;: 25, &quot;gender&quot;: &quot;male&quot; }\r\n    ]\r\n\r\n---\r\n**EDIT**\r\n\r\nThis is an old question: the new doc page is https://miller.readthedocs.io/en/latest/",
                "title": "CSV to JSON using jq"
            },
            {
                "up_vote_count": 6,
                "is_accepted": false,
                "score": 6,
                "last_activity_date": 1718629106,
                "last_edit_date": 1718629106,
                "creation_date": 1619976464,
                "answer_id": 67359273,
                "question_id": 29663187,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is a fairly simple &quot;one-liner&quot; version for jq that will work for &quot;reasonably&quot; sized files, for very large files you would need a version that doesn&#39;t use slurp. I&#39;m fairly new to jq and I&#39;m sure there are even better ways to do this (maybe just incr an index value instead of storing in the data). You can replace &quot;split&quot; with ./&quot;\\n&quot; and ./&quot;,&quot; if you want to make it even shorter and harder to read. NOTE: if you really need the space after the comma can split on &quot;, &quot; or add **|map(gsub(&quot;^\\\\s+|\\\\s+$&quot;;&quot;&quot;))** after the split on comma to trim leading &amp; trailing white space.\r\n\r\n&lt;!-- language: shell --&gt;\r\n    jq -Rs &#39;split(&quot;\\n&quot;)|map(split(&quot;,&quot;)|to_entries)|.[0] as $header|.[1:]|map(reduce .[] as $item ({};.[$header[$item.key].value]=$item.value))&#39;\r\n\r\nHere is a commented version:\r\n\r\n    # jq -Rs\r\n    split(&quot;\\n&quot;) | map( split(&quot;,&quot;) | to_entries ) # split lines, split comma &amp; number\r\n      | .[0] as $header # save [0]\r\n      | .[1:] # and then drop it\r\n      | map( reduce .[] as $item ( {}; .[$header[$item.key].value] = $item.value ) )\r\n\r\nThe top portion is pretty straight-forward: split the data on newline, then for each of those elements split on comma and then to_entries will turn each of those into key/value entries with a numbering of the keys (0..N): {key:#, value:string}\r\n\r\nThen it uses map/reduce to take each element and replace it with an object of key/value pairs using the numbered key to index back into the headers to get the label.  For those new to reduce (like me) the first element up to the semi-colon is to initialize the &#39;accumulator&#39; (the thing you modify each pass over the elements) so .[...] is modifying the accumulator and $item is the object we&#39;re operating on.\r\n\r\nUpdate: I got a better version working now that doesn&#39;t use slurp, and we do NOT use -n option because it will treat first line specially:\r\n\r\n&lt;!-- language: shell --&gt;\r\n    jq -R &#39;split(&quot;,&quot;) as $h|reduce inputs as $in ([]; . += [$in|split(&quot;,&quot;)|. as $a|reduce range(0,length) as $i ({};.[$h[$i]]=$a[$i])])&#39;",
                "title": "CSV to JSON using jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1740683898,
                "last_edit_date": 1740683898,
                "creation_date": 1632341614,
                "answer_id": 69290724,
                "question_id": 29663187,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It can also be done without reduce syntax:&lt;br/&gt;\r\n```\r\n$ printf &quot;name, age, gender\\njohn, 20, male\\njane, 30, female\\nbob, 25, male\\n&quot; |\\\r\njq -nR &#39;[inputs]|map(select(test(&quot;^[\\\\s]*$&quot;;&quot;&quot;)|not)|split(&quot;,&quot;)|map(sub(&quot;^\\\\ +&quot;;&quot;&quot;)))|.[0] as $headers|.[1:][]|map(fromjson? //.)|with_entries(.key=$headers[.key])&#39;\r\n{\r\n  &quot;name&quot;: &quot;john&quot;,\r\n  &quot;age&quot;: 20,\r\n  &quot;gender&quot;: &quot;male&quot;\r\n}\r\n{\r\n  &quot;name&quot;: &quot;jane&quot;,\r\n  &quot;age&quot;: 30,\r\n  &quot;gender&quot;: &quot;female&quot;\r\n}\r\n{\r\n  &quot;name&quot;: &quot;bob&quot;,\r\n  &quot;age&quot;: 25,\r\n  &quot;gender&quot;: &quot;male&quot;\r\n}\r\n```\r\n```\r\n#!/usr/bin/env -S jq --from-file --raw-input --null-input\r\n[inputs]                            # used with --null-input to get full input as an array of strings\r\n|map(\r\n    select(test(&quot;^[\\\\s]*$&quot;;&quot;&quot;)|not) # ignore lines containing only whitespace characters\r\n    |split(&quot;,&quot;)                     # transform each line to an array of strings\r\n    |map(sub(&quot;^\\\\ +&quot;;&quot;&quot;))           # remove leading spaces from strings\r\n)\r\n|.[0] as $headers                   # first line contains column names\r\n|.[1:][]                            # get data (each line was transformed to an array of strings)\r\n|map(fromjson? //.)                 # transform strings to numbers where it is possible\r\n                                    # (formjson is used to transform also json embedded in csv)\r\n|with_entries(.key=$headers[.key])  # transform arrays to objects using names from the first line\r\n```\r\nThe last line: ```with_entries(.key=$headers[.key])``` is crucial.\\\r\n[it is equivalent to](https://github.com/jqlang/jq/blob/8ba03f788f28cadeab7de7111d13add88b400d0b/src/builtin.jq#L44): ```to_entries|map(.key=$headers[.key])|from_entries```.\\\r\nThis is how it works on the first input line:\r\n```\r\n$ jq -n &#39;\r\n  [&quot;name&quot;,&quot;age&quot;,&quot;gender&quot;] as $headers\r\n  |[&quot;john&quot;,20,&quot;male&quot;]|debug\r\n  |to_entries|debug\r\n  |map(.key=$headers[.key])|debug\r\n  |from_entries|debug\r\n&#39;\r\n[&quot;DEBUG:&quot;,[&quot;john&quot;,20,&quot;male&quot;]]\r\n[&quot;DEBUG:&quot;,[{&quot;key&quot;:0,&quot;value&quot;:&quot;john&quot;},{&quot;key&quot;:1,&quot;value&quot;:20},{&quot;key&quot;:2,&quot;value&quot;:&quot;male&quot;}]]\r\n[&quot;DEBUG:&quot;,[{&quot;key&quot;:&quot;name&quot;,&quot;value&quot;:&quot;john&quot;},{&quot;key&quot;:&quot;age&quot;,&quot;value&quot;:20},{&quot;key&quot;:&quot;gender&quot;,&quot;value&quot;:&quot;male&quot;}]]\r\n[&quot;DEBUG:&quot;,{&quot;name&quot;:&quot;john&quot;,&quot;age&quot;:20,&quot;gender&quot;:&quot;male&quot;}]\r\n{\r\n  &quot;name&quot;: &quot;john&quot;,\r\n  &quot;age&quot;: 20,\r\n  &quot;gender&quot;: &quot;male&quot;\r\n}\r\n```",
                "title": "CSV to JSON using jq"
            },
            {
                "up_vote_count": 31,
                "is_accepted": false,
                "score": 31,
                "last_activity_date": 1730994686,
                "last_edit_date": 1730994686,
                "creation_date": 1659607975,
                "answer_id": 73234098,
                "question_id": 29663187,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "[yq](https://github.com/mikefarah/yq) (disclaimer I wrote it) supports this out of the box:\r\n\r\n```bash\r\nyq file.csv -p=csv -o=json\r\n```\r\nyields:\r\n\r\n```json\r\n[\r\n  {\r\n    &quot;name&quot;: &quot;john&quot;,\r\n    &quot; age&quot;: 20,\r\n    &quot; gender&quot;: &quot;male&quot;\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;jane&quot;,\r\n    &quot; age&quot;: 30,\r\n    &quot; gender&quot;: &quot;female&quot;\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;bob&quot;,\r\n    &quot; age&quot;: 25,\r\n    &quot; gender&quot;: &quot;male&quot;\r\n  }\r\n]\r\n```\r\n\r\nThe original CSV has leading spaces on columns 2 and 3 - not sure if that&#39;s a mistake or not. You can trim them by add an expression:\r\n\r\n```bash\r\nyq &#39;(... | select(tag == &quot;!!str&quot;)) |= trim&#39;  file.csv -p=csv -o=json\r\n```\r\n\r\nThis will match all strings and trim leading spaces, yielding:\r\n\r\n\r\n```json\r\n[\r\n  {\r\n    &quot;name&quot;: &quot;john&quot;,\r\n    &quot;age&quot;: 20,\r\n    &quot;gender&quot;: &quot;male&quot;\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;jane&quot;,\r\n    &quot;age&quot;: 30,\r\n    &quot;gender&quot;: &quot;female&quot;\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;bob&quot;,\r\n    &quot;age&quot;: 25,\r\n    &quot;gender&quot;: &quot;male&quot;\r\n  }\r\n]\r\n```",
                "title": "CSV to JSON using jq"
            },
            {
                "up_vote_count": 5,
                "is_accepted": false,
                "score": 5,
                "last_activity_date": 1672735970,
                "creation_date": 1672735970,
                "answer_id": 74991024,
                "question_id": 29663187,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Having done something similar recently, here&#39;s another `jq` one-liner to transform the CSV into a JSON array.\r\n```jq\r\njq --null-input --raw-input &#39;[input|scan(&quot;\\\\w+&quot;)] as $header |[inputs as $data |[$header,[$data|scan(&quot;\\\\w+&quot;)|tonumber? // .]] |transpose |map({(.[0]):.[1]}) |add]&#39; input.csv\r\n```\r\nOutput, given the example input:\r\n```json\r\n[\r\n  {\r\n    &quot;name&quot;: &quot;john&quot;,\r\n    &quot;age&quot;: 20,\r\n    &quot;gender&quot;: &quot;male&quot;\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;jane&quot;,\r\n    &quot;age&quot;: 30,\r\n    &quot;gender&quot;: &quot;female&quot;\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;bob&quot;,\r\n    &quot;age&quot;: 25,\r\n    &quot;gender&quot;: &quot;male&quot;\r\n  }\r\n]\r\n```\r\nTry it on [jqplay.org](https://jqplay.org/s/_87z2hjDRvS &quot;click me!&quot;).",
                "title": "CSV to JSON using jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1709188817,
                "creation_date": 1709188817,
                "answer_id": 78079318,
                "question_id": 29663187,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This is a one-liner using NPM library [any-json](https://www.npmjs.com/package/any-json):\r\n\r\n```bash\r\n# CSV file needs header row\r\nany-json convert data.csv data.json\r\n```\r\n\r\n\r\nYou can install it with:\r\n\r\n```bash\r\nnpm install -g any-json\r\n```\r\n\r\nIf you need node.js, [download it](https://nodejs.org/en/download).",
                "title": "CSV to JSON using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 10,
        "score": 49,
        "last_activity_date": 1740683898,
        "creation_date": 1429143298,
        "last_edit_date": 1610395345,
        "question_id": 29663187,
        "body_markdown": "If you have a csv dataset like this:\r\n\r\n    name, age, gender\r\n    john, 20, male\r\n    jane, 30, female\r\n    bob, 25, male\r\n\r\nCan you get to this:\r\n\r\n    [ {&quot;name&quot;: &quot;john&quot;, &quot;age&quot;: 20, &quot;gender&quot;: &quot;male&quot;},\r\n      {&quot;name&quot;: &quot;jane&quot;, &quot;age&quot;: 30, &quot;gender&quot;: &quot;female&quot;},\r\n      {&quot;name&quot;: &quot;bob&quot;, &quot;age&quot;: 25, &quot;gender&quot;: &quot;male&quot;} ]\r\n\r\nusing only jq?\r\n\r\nI found [this][1] article which shows what I&#39;m trying to do, but it uses a &#39;manual&#39; mapping of the header fields to the values.  I don&#39;t need/want to rename the header fields and have quite a few of them.  I would also not want to have to change a script/command every time the layout changes.\r\n\r\nIs it possible to dynamically extract the headers and then combine them with the values with a jq one-liner?\r\n\r\n  [1]: http://infiniteundo.com/post/99336704013/convert-csv-to-json-with-jq",
        "link": "https://stackoverflow.com/questions/29663187/csv-to-json-using-jq",
        "title": "CSV to JSON using jq"
    },
    {
        "tags": [
            "json",
            "sqlite",
            "underscore.js",
            "export-to-csv",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1429282692,
                "creation_date": 1429282692,
                "answer_id": 29702750,
                "question_id": 29702210,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Using `jq`, you could do this.\r\n\r\nGroup the items by the key `bid` (and maybe `title`) and aggregate the authors and tags.\r\n\r\n    group_by(.bid) |\r\n        map({\r\n            bid:     .[0].bid,\r\n            title:   .[0].title,\r\n            authors: map(.aid),\r\n            tags:    map(.tags)\r\n        })",
                "title": "How to automatically process sqlite export to get JSON that reflect relations DB?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1429290330,
                "creation_date": 1429290330,
                "answer_id": 29705404,
                "question_id": 29702210,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Using your data and this code in node seems to do the trick. It uses lodash (a better underscore.js), I hope it qualifies for what you call javascript based tools :)\r\n\r\n&lt;!-- language: lang-js --&gt;\r\n\r\n    var _ = require(&#39;lodash&#39;);\r\n\r\n    var arrayFields = [\r\n      &#39;aid&#39;\r\n    ];\r\n    \r\n    var keysMap = {\r\n      id: &#39;bid&#39;,\r\n      authors: &#39;aid&#39;,\r\n      tags: &#39;tags&#39;,\r\n      title: &#39;title&#39;\r\n    };\r\n\r\n    var result = _(rows)\r\n      .groupBy(&#39;bid&#39;) // group the rows by id\r\n      .map(function(rows) {\r\n        // for each group, take the first instance of the row as a basis\r\n        var row = _.clone(_.first(rows));\r\n        // and collect all grouped row values for the interesting fields\r\n        _.forEach(arrayFields, function(key) {\r\n          row[key] = _.pluck(rows, key);\r\n        })\r\n        return row;\r\n      })\r\n      .map(function(row) {\r\n        var obj = {};\r\n        // build a row object with translated keys\r\n        _.forEach(keysMap, function(originalKey, targetKey) {\r\n          obj[targetKey] = row[originalKey];\r\n        });\r\n        return obj;\r\n      })\r\n      .value();\r\n\r\n    console.log(result);\r\n\r\nHere is the output :\r\n\r\n&lt;!-- language: lang-json --&gt;\r\n\r\n    [ \r\n      { \r\n        id: 5,\r\n        authors: [ 4, 23 ],\r\n        tags: 3,\r\n        title: &#39;Jacques le fataliste et son ma&#238;tre&#39; \r\n      } \r\n    ]\r\n",
                "title": "How to automatically process sqlite export to get JSON that reflect relations DB?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1429290330,
        "creation_date": 1429281399,
        "question_id": 29702210,
        "body_markdown": "I&#39;m exporting data from a [sqlite database][1] (no choice here) to generate a JSON for an AngulaJS app.\r\n\r\n## JSON export from SQLite\r\n\r\n`sqlite3` CSV export **flatten the relational structure and add duplication**:\r\n\r\n&lt;!-- language: lang-json --&gt;\r\n\r\n    [\r\n      {\r\n        &quot;bid&quot;: 5, // book id\r\n        &quot;aid&quot;: 4,  // author&#39;s id\r\n        &quot;tags&quot;: 3,\r\n        &quot;title&quot;: &quot;Jacques le fataliste et son ma&#238;tre&quot;,\r\n      },\r\n      {\r\n        &quot;bid&quot;: 5,\r\n        &quot;aid&quot;: 23, // same book another author\r\n        &quot;tags&quot;: 8, // same book another tag\r\n        &quot;title&quot;: &quot;Jacques le fataliste et son ma&#238;tre&quot;,\r\n      }\r\n      …\r\n    ]\r\n\r\n### SQLite to JSON command \r\n\r\nThe [sqlite database][1] is available on the github and the command I use to export/convert is:\r\n\r\n&lt;!-- language: lang-shell --&gt;\r\n\r\n    sqlite3 -csv -header app/data/data.sqlite3 \\\r\n    &quot;SELECT b.id as bid, title, b.sort as sort_book, a.id as aid, a.sort as sort_author, path, name FROM books as b inner join books_authors_link as b_a ON b.id = b_a.book INNER JOIN authors as a ON a.id = b_a.author&quot; \\\r\n    | ./node_modules/csvtojson/bin/csvtojson \\\r\n    &gt; authors-books.json\r\n\r\n## JSON Goal \r\n\r\nI designed the final JSON with my customer in a document-oriented approach:\r\n\r\n* all I need in an object ;\r\n* references to other resources as\r\n  * an _id_/_primary key_ for forein key ;\r\n  * a list of _id_s/_primary keys_ for many-to-many relations.\r\n\r\nHere is an example: of **my goal**:\r\n\r\n&lt;!-- language: lang-json --&gt;\r\n\r\n    [\r\n        {\r\n            &quot;id&quot;: 2,\r\n            &quot;authors&quot;: [4, 23],\r\n            &quot;tags&quot;: [3,8,29,69],\r\n            &quot;title&quot;: &quot;Jacques le fataliste et son ma&#238;tre&quot;,\r\n            …\r\n        }\r\n        …\r\n    ]\r\n\r\nIf you speak French, here is the [github issue from the project][2]\r\n\r\n## Question\r\n\r\nSo how can I get this result using a command line pipe or javascript-based tool?\r\n\r\n  [1]: https://github.com/Labx/LibraryBox-app/blob/7c612c65d60846d801154a8eefcfb18e10c3a833/app/data/data.sqlite3?raw=true\r\n  [2]: https://github.com/Labx/LibraryBox-app/issues/8",
        "link": "https://stackoverflow.com/questions/29702210/how-to-automatically-process-sqlite-export-to-get-json-that-reflect-relations-db",
        "title": "How to automatically process sqlite export to get JSON that reflect relations DB?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1429537045,
                "last_edit_date": 1429537045,
                "creation_date": 1429534095,
                "answer_id": 29748348,
                "question_id": 29745740,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Use brackets around the second part of the expression, and shorthand key filter syntax as in:\r\n\r\n    jq &quot;.name, (.employees|map(select(.division==\\&quot;HR\\&quot;))[0].name)&quot; JSON.txt ",
                "title": "How to use pipe (|) and comma (,) together in JQ 1.4?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1429537045,
        "creation_date": 1429526803,
        "question_id": 29745740,
        "body_markdown": "I using JQ 1.4 on Windows 64 bit machine.\r\n\r\nBelow are the contents input file (`JSON.txt`)\r\n\r\n        {\r\n            &quot;name&quot;: &quot;Google&quot;,\r\n            &quot;location&quot;:\r\n                    {\r\n                            &quot;street&quot;: &quot;1600 Amphitheatre Parkway&quot;,\r\n                            &quot;city&quot;: &quot;Mountain View&quot;,\r\n                            &quot;state&quot;: &quot;California&quot;,\r\n                            &quot;country&quot;: &quot;US&quot;\r\n                    },\r\n            &quot;employees&quot;:\r\n                    [\r\n                            {\r\n                                    &quot;name&quot;: &quot;Michael&quot;,\r\n                                    &quot;division&quot;: &quot;Engineering&quot;\r\n                            },\r\n                            {\r\n                                    &quot;name&quot;: &quot;Laura&quot;,\r\n                                    &quot;division&quot;: &quot;HR&quot;\r\n                            },\r\n                            {\r\n                                    &quot;name&quot;: &quot;Elise&quot;,\r\n                                    &quot;division&quot;: &quot;Marketing&quot;\r\n                            }\r\n                    ]\r\n    }\r\n\r\nAt the output I exect to see two results `&quot;Google&quot;` and `&quot;Laura&quot;`\r\nI am able to get them with idividual filters.\r\n\r\n    1) jq .&quot;name&quot; JSON.txt\r\n    &quot;Google&quot;\r\n\r\n    2) jq .&quot;employees|map(select(.division==\\&quot;HR\\&quot;))&quot;[0].name JSON.txt\r\n    &quot;Laura&quot;\r\n\r\nWhen I combine these two filters using comma `,`, I receive below error:\r\n\r\n    3) jq .&quot;name&quot;,.&quot;employees|map(select(.division==\\&quot;HR\\&quot;))&quot;[0].name JSON.txt\r\n    jq: error: Cannot iterate over string\r\n    null\r\n    &quot;Laura&quot;\r\nCan someone please help to me to get below result:\r\n\r\n    &quot;Google&quot;\r\n    &quot;Laura&quot;\r\n",
        "link": "https://stackoverflow.com/questions/29745740/how-to-use-pipe-and-comma-together-in-jq-1-4",
        "title": "How to use pipe (|) and comma (,) together in JQ 1.4?"
    },
    {
        "tags": [
            "json",
            "shell",
            "sed",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 94756,
                    "reputation": 81440,
                    "user_id": 258523,
                    "user_type": "registered",
                    "accept_rate": 83,
                    "profile_image": "https://www.gravatar.com/avatar/f2c517550a86045c885bc36eca722b9d?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Etan Reisner",
                    "link": "https://stackoverflow.com/users/258523/etan-reisner"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1429588721,
                "post_id": 29761327,
                "comment_id": 47656940,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 1723702,
                    "reputation": 9178,
                    "user_id": 1578872,
                    "user_type": "registered",
                    "accept_rate": 69,
                    "profile_image": "https://www.gravatar.com/avatar/80b9c8f75d350cccb189ca77db412590?s=256&d=identicon&r=PG",
                    "display_name": "user1578872",
                    "link": "https://stackoverflow.com/users/1578872/user1578872"
                },
                "reply_to_user": {
                    "account_id": 94756,
                    "reputation": 81440,
                    "user_id": 258523,
                    "user_type": "registered",
                    "accept_rate": 83,
                    "profile_image": "https://www.gravatar.com/avatar/f2c517550a86045c885bc36eca722b9d?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Etan Reisner",
                    "link": "https://stackoverflow.com/users/258523/etan-reisner"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1429649307,
                "post_id": 29761327,
                "comment_id": 47695553,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 94756,
                    "reputation": 81440,
                    "user_id": 258523,
                    "user_type": "registered",
                    "accept_rate": 83,
                    "profile_image": "https://www.gravatar.com/avatar/f2c517550a86045c885bc36eca722b9d?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Etan Reisner",
                    "link": "https://stackoverflow.com/users/258523/etan-reisner"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1429657553,
                "post_id": 29761327,
                "comment_id": 47699330,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 1723702,
                    "reputation": 9178,
                    "user_id": 1578872,
                    "user_type": "registered",
                    "accept_rate": 69,
                    "profile_image": "https://www.gravatar.com/avatar/80b9c8f75d350cccb189ca77db412590?s=256&d=identicon&r=PG",
                    "display_name": "user1578872",
                    "link": "https://stackoverflow.com/users/1578872/user1578872"
                },
                "reply_to_user": {
                    "account_id": 94756,
                    "reputation": 81440,
                    "user_id": 258523,
                    "user_type": "registered",
                    "accept_rate": 83,
                    "profile_image": "https://www.gravatar.com/avatar/f2c517550a86045c885bc36eca722b9d?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Etan Reisner",
                    "link": "https://stackoverflow.com/users/258523/etan-reisner"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1429667556,
                "post_id": 29761327,
                "comment_id": 47702399,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 4879,
                    "reputation": 248190,
                    "user_id": 7552,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/b60298053f87465641c1b1192338c8cd?s=256&d=identicon&r=PG",
                    "display_name": "glenn jackman",
                    "link": "https://stackoverflow.com/users/7552/glenn-jackman"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1429735513,
                "post_id": 29761327,
                "comment_id": 47744980,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 1723702,
                    "reputation": 9178,
                    "user_id": 1578872,
                    "user_type": "registered",
                    "accept_rate": 69,
                    "profile_image": "https://www.gravatar.com/avatar/80b9c8f75d350cccb189ca77db412590?s=256&d=identicon&r=PG",
                    "display_name": "user1578872",
                    "link": "https://stackoverflow.com/users/1578872/user1578872"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1429752749,
                "post_id": 29761327,
                "comment_id": 47751877,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1446068492,
                "post_id": 29761327,
                "comment_id": 54595459,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1446066044,
                "last_edit_date": 1446066044,
                "creation_date": 1446065654,
                "answer_id": 33401429,
                "question_id": 29761327,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "    jq --arg key first_name \\\r\n       --arg value mike1 \\\r\n       &#39;select(.message.response.resultsList.result[]?[$key]==$value) | .message&#39; \\\r\n       &lt;in.json\r\n\r\n...returns only message content where the result list contains at least one `first_name` of `mike1`.",
                "title": "jq - extracting a subset of matching documents from a stream"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1446066044,
        "creation_date": 1429579978,
        "last_edit_date": 1446065999,
        "question_id": 29761327,
        "body_markdown": "I have the following JSON message. This is a single complete message. There are so many messages like this in a single file. This json message was generated from a unformated json message using jq.\r\n\r\n    {\r\n      &quot;header&quot;: {\r\n        &quot;user&quot;: &quot;baskar&quot;\r\n      },\r\n      &quot;requests&quot;: [\r\n        {\r\n          &quot;first_name&quot;: &quot;mike&quot;,\r\n          &quot;last_name&quot;: &quot;mat&quot;\r\n        },\r\n        {\r\n          &quot;first_name&quot;: &quot;mike&quot;,\r\n          &quot;last_name&quot;: &quot;mat&quot;\r\n        }\r\n      ],\r\n      &quot;check&quot;: [\r\n        &quot;Y&quot;\r\n      ]\r\n    }\r\n    {\r\n      &quot;header&quot;: {\r\n        &quot;user&quot;: &quot;baskar&quot;\r\n      },\r\n      &quot;message&quot;: {\r\n        &quot;header&quot;: {\r\n          &quot;user&quot;: &quot;baskar&quot;\r\n        },\r\n        &quot;response&quot;: {\r\n          &quot;resultsList&quot;: {\r\n            &quot;result&quot;: [\r\n              {\r\n                &quot;first_name&quot;: &quot;mike1&quot;,\r\n                &quot;last_name&quot;: &quot;mat&quot;\r\n              }\r\n            ]\r\n          },\r\n          &quot;errorMsg&quot;: null\r\n        }\r\n      }\r\n    }\r\n\r\n\r\nI would like to do some filtering on this. For example, when i search for first_name, mike1, I should get the header and the matching request inside request. Also the matching result inside the Response message. So, the output is expected as follows for the search string mike1.\r\n\r\n    {\r\n      &quot;header&quot;: {\r\n        &quot;user&quot;: &quot;baskar&quot;\r\n      },\r\n      &quot;requests&quot;: [\r\n        {\r\n          &quot;first_name&quot;: &quot;mike1&quot;,\r\n          &quot;last_name&quot;: &quot;mat&quot;\r\n        }\r\n      ],\r\n      &quot;check&quot;: [\r\n        &quot;Y&quot;\r\n      ]\r\n    }\r\n    {\r\n      &quot;header&quot;: {\r\n        &quot;user&quot;: &quot;baskar&quot;\r\n      },\r\n      &quot;message&quot;: {\r\n        &quot;header&quot;: {\r\n          &quot;user&quot;: &quot;baskar&quot;\r\n        },\r\n        &quot;response&quot;: {\r\n          &quot;resultsList&quot;: {\r\n            &quot;result&quot;: [\r\n              {\r\n                &quot;first_name&quot;: &quot;mike1&quot;,\r\n                &quot;last_name&quot;: &quot;mat&quot;\r\n              }\r\n            ]\r\n          },\r\n          &quot;errorMsg&quot;: null\r\n        }\r\n      }\r\n    }\r\n\r\nBasically, i want to filter out unmatched request inside the requests array and unmatched result inside the result array.\r\n\r\n\r\nCurrently, I use the following script to get the formatted json message from the unformatted json message log file.\r\n\r\n     sed -n &quot;/&lt;SEARCH_STRING&gt;/ s/.*Service - //p&quot; $1/test.log* | jq . &gt; ~/result.log\r\n\r\nThanks,\r\nBaskar.S",
        "link": "https://stackoverflow.com/questions/29761327/jq-extracting-a-subset-of-matching-documents-from-a-stream",
        "title": "jq - extracting a subset of matching documents from a stream"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1429600598,
                "creation_date": 1429600598,
                "answer_id": 29765406,
                "question_id": 29764836,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You need to flatten down the results first to rows of company and employee names.  Then with that, you can convert to csv rows.\r\n\r\n    map(.results | map({ cn: .name, en: .employees[].name } | [ .cn, .en ])) | add[] | @csv\r\n\r\nSince you have a stream of inputs, you&#39;ll have to slurp (`-s`) it in.  Since you want to output csv, you&#39;ll want to use raw output (`-r`).",
                "title": "How to convert complex JSON to CSV using JQ 1.4"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1429600598,
        "creation_date": 1429598830,
        "last_edit_date": 1429599011,
        "question_id": 29764836,
        "body_markdown": "I am using JQ 1.4 on Windows 64 bit machine.\r\n\r\nBelow are the contents of input file `IP.txt`\r\n\r\n    {\r\n      &quot;results&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;Google&quot;,\r\n          &quot;employees&quot;: [\r\n            {\r\n              &quot;name&quot;: &quot;Michael&quot;,\r\n              &quot;division&quot;: &quot;Engineering&quot;\r\n            },\r\n            {\r\n              &quot;name&quot;: &quot;Laura&quot;,\r\n              &quot;division&quot;: &quot;HR&quot;\r\n            },\r\n            {\r\n              &quot;name&quot;: &quot;Elise&quot;,\r\n              &quot;division&quot;: &quot;Marketing&quot;\r\n            }\r\n          ]\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;Microsoft&quot;,\r\n          &quot;employees&quot;: [\r\n            {\r\n              &quot;name&quot;: &quot;Brett&quot;,\r\n              &quot;division&quot;: &quot;Engineering&quot;\r\n            },\r\n            {\r\n              &quot;name&quot;: &quot;David&quot;,\r\n              &quot;division&quot;: &quot;HR&quot;\r\n            }\r\n          ]\r\n        }\r\n      ]\r\n    }\r\n    \r\n    {\r\n      &quot;results&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;Amazon&quot;,\r\n          &quot;employees&quot;: [\r\n            {\r\n              &quot;name&quot;: &quot;Watson&quot;,\r\n              &quot;division&quot;: &quot;Marketing&quot;\r\n            }\r\n          ]\r\n        }\r\n      ]\r\n    }\r\n\r\nFile contains two `&quot;results&quot;`. 1st result containts information for 2 companies: `Google` and `Microsoft`. 2nd result contains information for `Amazon`.\r\nI want to convert this JSON into csv file with company name and employee name.\r\n\r\n    &quot;Google&quot;,&quot;Michael&quot;\r\n    &quot;Google&quot;,&quot;Laura&quot;\r\n    &quot;Google&quot;,&quot;Elise&quot;\r\n    &quot;Microsoft&quot;,&quot;Brett&quot;\r\n    &quot;Microsoft&quot;,&quot;David&quot;\r\n    &quot;Amazon&quot;,&quot;Watson&quot;\r\n\r\nI am able to write below script:\r\n\r\n    jq -r &quot;[.results[0].name,.results[0].employees[0].name]|@csv&quot; IP.txt\r\n\r\n    &quot;Google&quot;,&quot;Michael&quot;\r\n    \r\n    &quot;Amazon&quot;,&quot;Watson&quot;\r\n\r\nCan someone guide me to write the script without hardcoding the index values?\r\n\r\nScript should be able generate output for any number `results` and each cotaining information of any number of companies.\r\n\r\nI tried using below script which didn&#39;t generate expected output:\r\n\r\n    jq -r &quot;[.results[].name,.results[].employees[].name]|@csv&quot; IP.txt\r\n    &quot;Google&quot;,&quot;Microsoft&quot;,&quot;Michael&quot;,&quot;Laura&quot;,&quot;Elise&quot;,&quot;Brett&quot;,&quot;David&quot;\r\n    &quot;Amazon&quot;,&quot;Watson&quot;",
        "link": "https://stackoverflow.com/questions/29764836/how-to-convert-complex-json-to-csv-using-jq-1-4",
        "title": "How to convert complex JSON to CSV using JQ 1.4"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 45,
                "is_accepted": true,
                "score": 45,
                "last_activity_date": 1429629581,
                "last_edit_date": 1429629581,
                "creation_date": 1429621839,
                "answer_id": 29773197,
                "question_id": 29772676,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "A complex assignment is what you&#39;re looking for:\r\n\r\n    jq &#39;(.[] | select(.id == &quot;baz&quot;) | .format) |= &quot;csv&quot;&#39; my.json\r\n\r\nPerhaps not shorter but it is more elegant, as requested. See the last section of the docs at: http://stedolan.github.io/jq/manual/#Assignment\r\n\r\nEdit: using `map`:\r\n\r\n    jq &#39;map((select(.id == &quot;baz&quot;) | .format) |= &quot;csv&quot;)&#39; my.json ",
                "title": "Update one value in array of dicts, using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 32,
        "last_activity_date": 1478885406,
        "creation_date": 1429620490,
        "last_edit_date": 1429621272,
        "question_id": 29772676,
        "body_markdown": "I want to update a value in a dict, which I can only identify by another value in the dict. That is, given this input:\r\n\r\n    [\r\n      {\r\n        &quot;format&quot;: &quot;geojson&quot;,\r\n        &quot;id&quot;: &quot;foo&quot;\r\n      },\r\n      {\r\n        &quot;format&quot;: &quot;geojson&quot;,\r\n        &quot;id&quot;: &quot;bar&quot;\r\n      },\r\n      {\r\n        &quot;format&quot;: &quot;zip&quot;,\r\n        &quot;id&quot;: &quot;baz&quot;\r\n      }\r\n    ]\r\n\r\nI want to change `baz`&#39;s accompanying format to &#39;csv&#39;:\r\n\r\n    [\r\n      {\r\n        &quot;format&quot;: &quot;geojson&quot;,\r\n        &quot;id&quot;: &quot;foo&quot;\r\n      },\r\n      {\r\n        &quot;format&quot;: &quot;geojson&quot;,\r\n        &quot;id&quot;: &quot;bar&quot;\r\n      },\r\n      {\r\n        &quot;format&quot;: &quot;csv&quot;,\r\n        &quot;id&quot;: &quot;baz&quot;\r\n      }\r\n    ]\r\n\r\nI have found that this works:\r\n\r\n    jq &#39;map(if .id==&quot;baz&quot; then .format=&quot;csv&quot; else . end)&#39; my.json\r\n\r\nBut this seems rather verbose, so I wonder if there is a more elegant way to express this. jq seems to be missing some kind of expression selector, the equivalent of might be `[@id=&#39;baz&#39;]` in xpath.\r\n\r\n(When I started this question, I had `[.[] |...]`, then I discovered `map`, so it&#39;s not quite as bad as I thought.)",
        "link": "https://stackoverflow.com/questions/29772676/update-one-value-in-array-of-dicts-using-jq",
        "title": "Update one value in array of dicts, using jq"
    },
    {
        "tags": [
            "javascript",
            "porting",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 435935,
                    "reputation": 57380,
                    "user_id": 1723893,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/dpcFl.jpg?s=256",
                    "display_name": "NullPoiиteя",
                    "link": "https://stackoverflow.com/users/1723893/nullpoi%d0%b8te%d1%8f"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1429772492,
                "post_id": 29815940,
                "comment_id": 47759172,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 2682405,
                    "reputation": 16756,
                    "user_id": 2317490,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Ypoen.png?s=256",
                    "display_name": "dandavis",
                    "link": "https://stackoverflow.com/users/2317490/dandavis"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1429772530,
                "post_id": 29815940,
                "comment_id": 47759202,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 96955,
                    "reputation": 128646,
                    "user_id": 263268,
                    "user_type": "registered",
                    "accept_rate": 82,
                    "profile_image": "https://i.sstatic.net/vV6JS.jpg?s=256",
                    "display_name": "Steve Bennett",
                    "link": "https://stackoverflow.com/users/263268/steve-bennett"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1429772795,
                "post_id": 29815940,
                "comment_id": 47759358,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 8,
                "is_accepted": false,
                "score": 8,
                "last_activity_date": 1430138881,
                "creation_date": 1430138881,
                "answer_id": 29896256,
                "question_id": 29815940,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You may be interested in checking out [JMESPath][1], a query language for JSON. It has implementations on many languages, including Javascript.\r\n\r\n\r\n  [1]: http://jmespath.org",
                "title": "JavaScript implementation of jq?"
            },
            {
                "up_vote_count": 10,
                "is_accepted": true,
                "score": 9,
                "last_activity_date": 1568771297,
                "last_edit_date": 1568771297,
                "creation_date": 1503614484,
                "answer_id": 45871967,
                "question_id": 29815940,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "There is [fiatjaf/jq-web](https://github.com/fiatjaf/jq-web)\r\n\r\n&gt; This is a build of jq, the command-line JSON processor in Javascript using Emscripten along with a wrapper for making it usable as a library.  \r\n\r\nDemo here [https://jq.alhur.es/jiq/](https://jq.alhur.es/jiq/)\r\n",
                "title": "JavaScript implementation of jq?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1553005413,
                "creation_date": 1553005413,
                "answer_id": 55243234,
                "question_id": 29815940,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You might also want to check out **my** take on this: https://github.com/kantord/emuto\r\n\r\nI specifically implemented it to create a jq alternative that can be used in a browser. As an extra, it can also _compile_ to JavaScript, so in some situation you might not even need to bundle in the compiler itself. (Although it&#39;s quite small anyway)",
                "title": "JavaScript implementation of jq?"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1602267933,
                "creation_date": 1602267933,
                "answer_id": 64285428,
                "question_id": 29815940,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "jq.node looks pretty interesting and seems to be getting popular. \r\n Features include a mash of jq and javascript, claim is that &quot;jq.node is JavaScript and Lodash in your shell&quot; and &quot;some features of jq are not currently implemented in jq.node&quot;.  Not sure if it can be used in the browser.  But it can be installed with npm:\r\n\r\n https://github.com/fgribreau/jq.node",
                "title": "JavaScript implementation of jq?"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1604408413,
                "creation_date": 1604408413,
                "answer_id": 64663330,
                "question_id": 29815940,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I implemented [micro-jq](https://github.com/elastic/micro-jq) specifically so I could evaluate JQ expressions in the browser. It implements a subset that should allow most basic uses for selecting fields.",
                "title": "JavaScript implementation of jq?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1625663292,
                "creation_date": 1625663292,
                "answer_id": 68286677,
                "question_id": 29815940,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "What about [fx][1]? It&#39;s a command-line JSON processing tool.\r\n\r\n\r\n  [1]: https://github.com/antonmedv/fx",
                "title": "JavaScript implementation of jq?"
            },
            {
                "up_vote_count": 6,
                "is_accepted": false,
                "score": 6,
                "last_activity_date": 1660385364,
                "creation_date": 1660385364,
                "answer_id": 73343334,
                "question_id": 29815940,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I implemented a jq parser, interpreter, and (basic) formatter in TypeScript:\r\n\r\n[@jq-tools/jq][1]\r\n\r\nSo far, all of jq&#39;s syntax is supported (with the exception of the modules). And although a good portion of built-in filters and formats still needs to be implemented, a few are already there. Most of the functionality is properly tested (there are over a thousand test cases).\r\n\r\nHere, I attach a basic usage example:\r\n\r\n```ts\r\nimport { jq } from &#39;@jq-tools/jq&#39;;\r\n\r\nconst transform = jq&lt;number, number&gt;`.[] | . * 2`;\r\nArray.from(transform([1, 2, 3]));\r\n// Output: [2, 4, 6]\r\n```\r\n\r\nI do not really have any solid benchmarks, but so far it seemed to be faster than [jq-web][2] (at least on small data).\r\n\r\n\r\n  [1]: https://www.npmjs.com/package/@jq-tools/jq\r\n  [2]: https://www.npmjs.com/package/jq-web",
                "title": "JavaScript implementation of jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 7,
        "score": 12,
        "last_activity_date": 1660385364,
        "creation_date": 1429772337,
        "last_edit_date": 1429772785,
        "question_id": 29815940,
        "body_markdown": "The only implementation of jq seems to be in C. Is there anything comparable in (browser-side) JavaScript?\r\n\r\nThe reason I&#39;m asking is basically to work out how much it&#39;s worth investing in jq - I generally prefer toolkits that JS-based, since they can be installed via NPM, can be used in the browser et. And those are two environments likely to encounter JSON...",
        "link": "https://stackoverflow.com/questions/29815940/javascript-implementation-of-jq",
        "title": "JavaScript implementation of jq?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 39,
                "is_accepted": true,
                "score": 39,
                "last_activity_date": 1554700731,
                "last_edit_date": 1554700731,
                "creation_date": 1429805637,
                "answer_id": 29829035,
                "question_id": 29822622,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Of course.\r\n\r\n    $ jq -n &#39;[inputs | keys[]] | unique | sort&#39; input.json\r\n    [\r\n      &quot;a&quot;,\r\n      &quot;b&quot;,\r\n      &quot;c&quot;,\r\n      &quot;d&quot;\r\n    ]\r\n\r\nHere&#39;s another option that may perform better as it doesn&#39;t require collecting the keys into an array.\r\n\r\n    $ jq -n &#39;reduce (inputs | keys[]) as $k ({}; .[$k] = null) | keys&#39; input.json\r\n\r\nOr perhaps, even better:\r\n\r\n    $ jq -n &#39;foreach (inputs | keys[]) as $k ({}; .[$k]+=1; if .[$k]==1 then $k else empty end)&#39; input.json\r\n\r\nAnd for larger files, you will want to stream them in anyway so use this variation:\r\n\r\n    $ jq --stream -n &#39;foreach inputs[0][-1] as $k ({}; .[$k]+=1; if .[$k]==1 then $k else empty end)&#39; input.json",
                "title": "Get all unique JSON key names with JQ"
            },
            {
                "up_vote_count": 6,
                "is_accepted": false,
                "score": 6,
                "last_activity_date": 1554481292,
                "last_edit_date": 1554481292,
                "creation_date": 1430708863,
                "answer_id": 30022028,
                "question_id": 29822622,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Two points:\r\n\r\n1. The original solution invoking jq and then sort is efficient, especially  with respect to memory usage.  (The solution involving the -s option effectively forces the entire file to be read into memory).\r\n\r\n2. jq&#39;s `unique` implies `sort`.  That is, `unique|sort` should be simplified to `unique` to avoid sorting twice.",
                "title": "Get all unique JSON key names with JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 25,
        "last_activity_date": 1616578822,
        "creation_date": 1429789882,
        "last_edit_date": 1616578822,
        "question_id": 29822622,
        "body_markdown": "Is there a way to get all unique key names, without invoking a unique sort outside `jq`?\r\n\r\nExample file:\r\n\r\n    {&quot;a&quot;: 1, &quot;b&quot;: 2, &quot;c&quot;: 3}\r\n    {&quot;a&quot;: 4, &quot;b&quot;: 5, &quot;d&quot;: 6}\r\n\r\nAnd `jq` and sort command as I use it now, but I think it&#39;s not so efficient:\r\n\r\n    jq -r keys[] example | sort -u                                                                               \r\n    a                                                                                                                                       \r\n    b                                                                                                                                       \r\n    c                                                                                                                                       \r\n    d     \r\n\r\n         ",
        "link": "https://stackoverflow.com/questions/29822622/get-all-unique-json-key-names-with-jq",
        "title": "Get all unique JSON key names with JQ"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1429834160,
                "last_edit_date": 1429834160,
                "creation_date": 1429828819,
                "answer_id": 29835618,
                "question_id": 29834097,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You need to think of it in terms of updating the requests array by filtering it.\r\n\r\nThis should work:\r\n\r\n    .requests |= map(select(.first_name == &quot;mike&quot;))",
                "title": "Extracting matched child json from a nested JSON object with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1429834160,
        "creation_date": 1429822368,
        "last_edit_date": 1429832621,
        "question_id": 29834097,
        "body_markdown": "Given a JSON array of objects thus:\r\n\r\n     {\r\n      &quot;header&quot; : {\r\n        &quot;user&quot; : &quot;baskar&quot;\r\n      },\r\n      &quot;requests&quot; : [ {\r\n        &quot;first_name&quot; : &quot;mike&quot;,\r\n        &quot;last_name&quot; : &quot;mat&quot;\r\n      }, {\r\n        &quot;first_name&quot; : &quot;mike1&quot;,\r\n        &quot;last_name&quot; : &quot;mat&quot;\r\n      } ],\r\n      &quot;check&quot; : [ &quot;Y&quot; ]\r\n    }\r\n\r\nI&#39;d like to extract a subset of the key/values from the nested requests based on the condition, whilst keeping other properties from the outer object intact, producing something like:  When i search for first_name=&#39;mike&#39;\r\n\r\n\r\n    {\r\n      &quot;header&quot; : {\r\n        &quot;user&quot; : &quot;baskar&quot;\r\n      },\r\n      &quot;requests&quot; : [ {\r\n        &quot;first_name&quot; : &quot;mike&quot;,\r\n        &quot;last_name&quot; : &quot;mat&quot;\r\n      } ],\r\n      &quot;check&quot; : [ &quot;Y&quot; ]\r\n    }\r\n\r\nI tried the below thing,\r\n\r\n    [.requests[] | select(.first_name == &quot;mike&quot;)]\r\n\r\nBut, it gives the subset of the matched requests but not returning header and check element.\r\n\r\nI&#39;m sure there must be a reasonably easy way of achieving this with jq. Help appreciated.",
        "link": "https://stackoverflow.com/questions/29834097/extracting-matched-child-json-from-a-nested-json-object-with-jq",
        "title": "Extracting matched child json from a nested JSON object with jq"
    },
    {
        "tags": [
            "json",
            "shell",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1430248706,
                "last_edit_date": 1430248706,
                "creation_date": 1430247015,
                "answer_id": 29927542,
                "question_id": 29926814,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The shell does not expand variables inside single quotes.  If `jq` is agnostic about the quote type, try swapping double and single quotes throughout.  Also, if you want to select only the line with `Service -` in it, you need the `-n` flag for sed:\r\n\r\n    sed -n &#39;s/.*Service - //p&#39; tes.log | jq &quot;if (.requests | length) != 0 then .requests |= map(select(.orderId == &#39;$ORDER_ID&#39;)) else &#39;NO&#39; end&quot; &gt; ~/result.log\r\n\r\n",
                "title": "JQ JSON select with dynamic shell param"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1503679350,
                "creation_date": 1503679350,
                "answer_id": 45886023,
                "question_id": 29926814,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "As the following bash script demonstrates, [Stephen Gildea](https://stackoverflow.com/users/4500538/stephen-gildea)&#39;s example will not work because jq does not allow use of `&#39;` single quotes. \r\n\r\n    #!/bin/bash\r\n    ORDER_ID=2260\r\n    \r\n    jq &quot;if (.requests | length) != 0 then .requests |= map(select(.orderId == &#39;$ORDER_ID&#39;)) else &#39;NO&#39; end&quot; &lt;&lt;EOF\r\n    {&quot;requests&quot;:[{&quot;orderId&quot;:2260}]}\r\n    EOF\r\n    \r\nSpecifically the `&#39;NO&#39;` literal will generate a syntax error:\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 (.requests | length) != 0 then .requests |= map(select(.orderId == &#39;2260&#39;)) else &#39;NO&#39; end                                                                      \r\n    jq: error: Possibly unterminated &#39;if&#39; statement at &lt;top-level&gt;, line 1:\r\n    if (.requests | length) != 0 then .requests |= map(select(.orderId == &#39;2260&#39;)) else &#39;NO&#39; end\r\n    jq: 2 compile errors\r\n    \r\nOne approach which will work is to use the `--argjson` option, use single quotes for the entire jq filter and double quotes for strings literals within the filter.  E.g.\r\n    \r\n    jq --argjson ORDER_ID &quot;$ORDER_ID&quot; &#39;\r\n    if (.requests|length)!=0 then .requests |= map(select(.orderId == $ORDER_ID)) else &quot;NO&quot; end\r\n    &#39;",
                "title": "JQ JSON select with dynamic shell param"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1503691668,
        "creation_date": 1430244471,
        "last_edit_date": 1503691668,
        "question_id": 29926814,
        "body_markdown": "I use JQ for JSON formatting and filtering the data.\r\n\r\n    sed &quot;s/.*Service - //p&quot; tes.log | jq &#39;if (.requests | length) != 0 then .requests |= map(select(.orderId == &quot;2260&quot;)) else &quot;NO&quot;  end&#39; &gt; ~/result.log\r\n\r\n  Here, the orderid is been hardcoded to 2260. But my requirement is to make it parameter driven.\r\n\r\nSo I store the param to a variable called ORDER_ID like,\r\n\r\n    ORDER_ID=2260\r\n\r\nand then using $ORDER_ID, but it doesnt work.\r\n\r\n    sed &quot;s/.*Service - //p&quot; tes.log | jq &#39;if (.requests | length) != 0 then .requests |= map(select(.orderId == &quot;$ORDER_ID&quot;)) else &quot;NO&quot;  end&#39; &gt; ~/result.log\r\n\r\n\r\nIt is not replacing the $ORDER_ID with the passed param.\r\n\r\nThanks\r\n\r\n\r\n  \r\n",
        "link": "https://stackoverflow.com/questions/29926814/jq-json-select-with-dynamic-shell-param",
        "title": "JQ JSON select with dynamic shell param"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1430252249,
                "creation_date": 1430252249,
                "answer_id": 29929103,
                "question_id": 29929025,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Try this:\r\n\r\n    jq &#39;{ &quot;dest&quot;: .dest,  &quot;source&quot;: .source }&#39;\r\n\r\nor for your final form:\r\n\r\n    jq &#39;{ &quot;dest&quot;: { &quot;ip&quot;: .dest.ip },  &quot;source&quot;: { &quot;ip&quot;: .source.ip } }&#39;\r\n\r\nwhich outputs:\r\n\r\n    {\r\n      &quot;dest&quot;: {\r\n        &quot;ip&quot;: &quot;192.168.2.2&quot;\r\n      },\r\n      &quot;source&quot;: {\r\n        &quot;ip&quot;: &quot;10.1.5.1&quot;\r\n      }\r\n    }",
                "title": "How can I extract multiple items and keep them as one json structure"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1430252249,
        "creation_date": 1430252026,
        "question_id": 29929025,
        "body_markdown": "I have an example JSON of\r\n\r\n    {\r\n      &quot;reason&quot;: &quot;TCP FINs&quot;,\r\n      &quot;bytes&quot;: &quot;1759&quot;,\r\n      &quot;duration&quot;: &quot;0:00:00&quot;,\r\n      &quot;dest&quot;: {\r\n        &quot;interface&quot;: &quot;inside&quot;,\r\n        &quot;ip&quot;: &quot;192.168.2.2&quot;,\r\n        &quot;port&quot;: &quot;88&quot;\r\n      },\r\n      &quot;source&quot;: {\r\n        &quot;interface&quot;: &quot;outside&quot;,\r\n        &quot;ip&quot;: &quot;10.1.5.1&quot;,\r\n        &quot;port&quot;: &quot;60470&quot;\r\n      },\r\n      &quot;connection-id&quot;: &quot;400508768&quot;,\r\n      &quot;proto&quot;: &quot;TCP&quot;,\r\n      &quot;hostname&quot;: &quot;192.168.1.1&quot;,\r\n      &quot;timestamp&quot;: &quot;Apr 28 13:00:01&quot;,\r\n      &quot;event.tags&quot;: [ &quot;cisco&quot;, &quot;ASA-6-302014&quot; ]\r\n     }\r\n\r\nand I want to extract out the source and dest sections, but as one object.\r\n\r\n    {\r\n      &quot;dest&quot;: {\r\n        &quot;interface&quot;: &quot;inside&quot;,\r\n        &quot;ip&quot;: &quot;192.168.2.2&quot;,\r\n        &quot;port&quot;: &quot;88&quot;\r\n      },\r\n      &quot;source&quot;: {\r\n        &quot;interface&quot;: &quot;outside&quot;,\r\n        &quot;ip&quot;: &quot;10.1.5.1&quot;,\r\n        &quot;port&quot;: &quot;60470&quot;\r\n      }\r\n    }\r\n\r\nIf I do jq &#39;.source,.dest&quot; then I get two different objects\r\n\r\n    &quot;dest&quot;: {\r\n      &quot;interface&quot;: &quot;inside&quot;,\r\n      &quot;ip&quot;: &quot;192.168.2.2&quot;,\r\n      &quot;port&quot;: &quot;88&quot;\r\n    }\r\n\r\n    &quot;source&quot;: {\r\n      &quot;interface&quot;: &quot;outside&quot;,\r\n      &quot;ip&quot;: &quot;10.1.5.1&quot;,\r\n      &quot;port&quot;: &quot;60470&quot;\r\n    }\r\n\r\nit&#39;s more obvious if you use -c because they come out as two different lines\r\n\r\nAs a more advanced stage, I would like to be able to get just part of this (the IP addresses) without the other data, but still as an object\r\n\r\n    {\r\n      &quot;dest&quot;: {\r\n        &quot;ip&quot;: &quot;192.168.2.2&quot;,\r\n      },\r\n      &quot;source&quot;: {\r\n        &quot;ip&quot;: &quot;10.1.5.1&quot;,\r\n      }\r\n    }\r\n",
        "link": "https://stackoverflow.com/questions/29929025/how-can-i-extract-multiple-items-and-keep-them-as-one-json-structure",
        "title": "How can I extract multiple items and keep them as one json structure"
    },
    {
        "tags": [
            "json",
            "if-statement",
            "syntax",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 10,
                "is_accepted": false,
                "score": 10,
                "last_activity_date": 1430342135,
                "creation_date": 1430342135,
                "answer_id": 29954718,
                "question_id": 29949184,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Since you&#39;re not making any further changes to the object, just use the &quot;identity&quot; filter `.`.\r\n\r\n    if (.requests | length) then ... else . end\r\n\r\nOn the other hand, you&#39;re just updating the `requests` or `result` property if non-empty using `map`.  The check isn&#39;t necessary.  If it&#39;s empty, then it will return empty.\r\n\r\nYou can simplify your filter to just:\r\n\r\n    .requests |= map(select(.id == \\&quot;123\\&quot;)) | .result |= map(select(.id== \\&quot;123\\&quot;))",
                "title": "JSON JQ if without else"
            },
            {
                "up_vote_count": 97,
                "is_accepted": true,
                "score": 97,
                "last_activity_date": 1558037541,
                "last_edit_date": 1558037541,
                "creation_date": 1430380988,
                "answer_id": 29962258,
                "question_id": 29949184,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You may want to use the idiom:\r\n\r\n    if CONDITION then WHATEVER else empty end\r\n\r\n`empty` is a filter that outputs nothing at all -- not even null, which is after all something (namely a JSON value).  It&#39;s a bit like a black hole, only blacker -- it will consume whatever it&#39;s offered, but unlike a black hole, it does not even emit Hawking radiation.\r\n\r\nIn your case, you have an &quot;elif&quot; so using &quot;else empty&quot; is probably what you want, but for reference, the above is exactly equivalent to:\r\n\r\n    select(CONDITION) | WHATEVER\r\n\r\n\r\nP.S. My guess is that whatever the goal of the sed command, it could be done more reliably as part of the jq program, perhaps using `walk/1`. \r\n\r\n## UPDATE\r\nAfter the release of jq 1.6, a change was made so that &quot;if without else&quot; has the semantics of &quot;if _ then _ else . end&quot;, that is:\r\n\r\n   `if P then Q end` === `if P then Q else . end`\r\n\r\n    ",
                "title": "JSON JQ if without else"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 51,
        "last_activity_date": 1598882036,
        "creation_date": 1430323990,
        "last_edit_date": 1598882036,
        "question_id": 29949184,
        "body_markdown": "I use the following JQ command to filter out the JSON. My requirement is to filter out the JSON message if the expected node is present. Or else, do nothing. Hence, I use if, elif, ....\r\n\r\n \r\n\r\n    sed -n &quot;s/.*Service - //p&quot; $1/response.log* |\r\n      jq &quot;if (.requests | length) != 0 then .requests |= map(select(.id == \\&quot;123\\&quot;))\r\n          elif (.result | length ) != 0  then .result |= map(select(.id== \\&quot;123\\&quot;)) \r\n          else &quot; &quot;  end&quot; &gt; ~/result.log\r\n\r\n Looks like else is mandatory here. I dont want to do anything inside the else block. Is there anyway, I can ignore else or just print some whitespce inside else.\r\n\r\n In the above case, it prints double quotes &quot; &quot; in the result file.",
        "link": "https://stackoverflow.com/questions/29949184/json-jq-if-without-else",
        "title": "JSON JQ if without else"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 21,
                "is_accepted": true,
                "score": 21,
                "last_activity_date": 1430464344,
                "creation_date": 1430464344,
                "answer_id": 29982986,
                "question_id": 29982897,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Use this filter:\r\n\r\n    .snapshots[] | &quot;\\(.end_time_in_millis) \\(.snapshot)&quot;\r\n\r\nThis builds up a string for each of the snapshots consisting of the end time and the snapshot name.\r\n\r\nJust make sure you use the `-r` option to get the raw output.",
                "title": "Using jq to extract specific property values and output on a single line"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 19,
        "last_activity_date": 1430464344,
        "creation_date": 1430463859,
        "last_edit_date": 1495540897,
        "question_id": 29982897,
        "body_markdown": "I&#39;ve this ElasticSearch snapshot output and would like to reduce it to print, on a single line, from each `snapshot` the values of the  `end_time_in_millis` and `snapshot` property separate by a space:\r\n\r\n    1429609790767 snapshot_1\r\n    1429681169896 snapshot_2\r\n\r\nBasically the output of\r\n\r\n- `cat  data | jq &#39;.snapshots[].end_time_in_millis&#39;` and\r\n- `cat  data | jq &#39;.snapshots[].snapshot&#39;`\r\n\r\nbut combined on one line.\r\n\r\nI was looking at `map` but couldn&#39;t make out how to apply it; also reading [this answer][1] I tried:\r\n\r\n    cat data  | jq &#39;.snapshots[] | map(. |= with_entries( select( .key == ( &quot;snapshot&quot;) ) ) )&#39;\r\n\r\nBut that produces lots of errors and `null` output.\r\n\r\nThe data:\r\n\r\n    {\r\n      &quot;snapshots&quot;: [\r\n        {\r\n          &quot;shards&quot;: {\r\n            &quot;successful&quot;: 1,\r\n            &quot;failed&quot;: 0,\r\n            &quot;total&quot;: 1\r\n          },\r\n          &quot;failures&quot;: [],\r\n          &quot;snapshot&quot;: &quot;snapshot_1&quot;,\r\n          &quot;indices&quot;: [\r\n            &quot;myindex1&quot;\r\n          ],\r\n          &quot;state&quot;: &quot;SUCCESS&quot;,\r\n          &quot;start_time&quot;: &quot;2015-04-21T09:45:47.041Z&quot;,\r\n          &quot;start_time_in_millis&quot;: 1429609547041,\r\n          &quot;end_time&quot;: &quot;2015-04-21T09:49:50.767Z&quot;,\r\n          &quot;end_time_in_millis&quot;: 1429609790767,\r\n          &quot;duration_in_millis&quot;: 243726\r\n        },\r\n        {\r\n          &quot;shards&quot;: {\r\n            &quot;successful&quot;: 1,\r\n            &quot;failed&quot;: 0,\r\n            &quot;total&quot;: 1\r\n          },\r\n          &quot;failures&quot;: [],\r\n          &quot;snapshot&quot;: &quot;snapshot_2&quot;,\r\n          &quot;indices&quot;: [\r\n            &quot;myindex1&quot;\r\n          ],\r\n          &quot;state&quot;: &quot;SUCCESS&quot;,\r\n          &quot;start_time&quot;: &quot;2015-04-22T05:36:02.333Z&quot;,\r\n          &quot;start_time_in_millis&quot;: 1429680962333,\r\n          &quot;end_time&quot;: &quot;2015-04-22T05:39:29.896Z&quot;,\r\n          &quot;end_time_in_millis&quot;: 1429681169896,\r\n          &quot;duration_in_millis&quot;: 207563\r\n        }\r\n      ]\r\n    }\r\n\r\n\r\n  [1]: https://stackoverflow.com/questions/29259249/extracting-selected-properties-from-a-nested-json-object-with-jq",
        "link": "https://stackoverflow.com/questions/29982897/using-jq-to-extract-specific-property-values-and-output-on-a-single-line",
        "title": "Using jq to extract specific property values and output on a single line"
    },
    {
        "tags": [
            "json",
            "csv",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 539810,
                    "reputation": 25227,
                    "user_id": 907779,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/AUTVc.jpg?s=256",
                    "display_name": "Joel Purra",
                    "link": "https://stackoverflow.com/users/907779/joel-purra"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1430803522,
                "post_id": 30015555,
                "comment_id": 48205037,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 16396767,
                    "reputation": 773,
                    "user_id": 11844048,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/ea6e082b3a00f49869541c9d914945d2?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Alwin Jose",
                    "link": "https://stackoverflow.com/users/11844048/alwin-jose"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1673690470,
                "post_id": 30015555,
                "comment_id": 132557629,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 56,
                "is_accepted": false,
                "score": 56,
                "last_activity_date": 1430670206,
                "creation_date": 1430670206,
                "answer_id": 30016257,
                "question_id": 30015555,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Just add the header text in an array in front of the values.\r\n\r\n    [&quot;Commit Message&quot;,&quot;Committer Name&quot;], (.[].commit | [.message,.committer.name]) | @csv",
                "title": "How to add a header to CSV export in jq?"
            },
            {
                "up_vote_count": 18,
                "is_accepted": true,
                "score": 17,
                "last_activity_date": 1430748556,
                "creation_date": 1430748556,
                "answer_id": 30032247,
                "question_id": 30015555,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Based on Anton&#39;s comments on Jeff Mercado&#39;s answer, this snippet will get the key names of the properties of the first element and output them as an array before the rows, thus using them as headers. If different rows have different properties, then it won&#39;t work well; then again, neither would the resulting CSV.\r\n\r\n`map({message: .commit.message, name: .commit.committer.name}) | (.[0] | to_entries | map(.key)), (.[] | [.[]]) | @csv`",
                "title": "How to add a header to CSV export in jq?"
            },
            {
                "up_vote_count": 5,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1515032060,
                "creation_date": 1515032060,
                "answer_id": 48087786,
                "question_id": 30015555,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "While I fully realize OP was looking for a _purely jq_ answer, I found this question looking for _any_ answer. So, let me offer one I found (and found useful) to others like me.\r\n\r\n1. `sudo apt install moreutils` - if you don&#39;t have them yet. [Moreutils website][1].\r\n2. `echo &quot;Any, column, name, that, is, not, in, your, json, object&quot; | cat - your.csv | sponge your.csv`\r\n\r\nDisadvantages: requires `moreutils` package, is not just `jq`-reliant, so some would understandably say less elegant.\r\n\r\nAdvantages: you choose your headers, not your JSON keys. Also, _pure `jq`_ ways are bothered by the sorting of the keys, [depending on your version][2]. \r\n\r\n\r\n### How does it work?\r\n\r\n1. echo outputs your header\r\n2. cat - takes echo output from stdin (cause -) and conCATenates it with your csv file\r\n3. sponge waits until that is done and writes the result to same file, overwriting it.\r\n\r\n### But you could do it with `tee` without having to install any packages!\r\n\r\nNo, you could not, as [Kos excellently demonstrates here][3]. Not unless you&#39;re fine with loosing your csv at some point.\r\n\r\n\r\n  [1]: http://joeyh.name/code/moreutils/\r\n  [2]: https://github.com/stedolan/jq/issues/561\r\n  [3]: https://askubuntu.com/a/752451/72260",
                "title": "How to add a header to CSV export in jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 35,
        "last_activity_date": 1515032060,
        "creation_date": 1430666512,
        "question_id": 30015555,
        "body_markdown": "I&#39;m taking a modified command from the `jq` [tutorial][1]:\r\n\r\n\r\n    curl &#39;https://api.github.com/repos/stedolan/jq/commits?per_page=5&#39; \\\r\n    | jq -r -c &#39;.[] | {message: .commit.message, name: .commit.committer.name} | [.[]] | @csv&#39;\r\n\r\nWhich does `csv` export well, but missing the headers as the top:\r\n\r\n    &quot;Fix README&quot;,&quot;Nicolas Williams&quot;\r\n    &quot;README: send questions to SO and Freenode&quot;,&quot;Nicolas Williams&quot;\r\n    &quot;usage() should check fprintf() result (fix #771)&quot;,&quot;Nicolas Williams&quot;\r\n    &quot;Use jv_mem_alloc() in compile.c (fix #771)&quot;,&quot;Nicolas Williams&quot;\r\n    &quot;Fix header guards (fix #770)&quot;,&quot;Nicolas Williams&quot;\r\n\r\nHow can I add the header (in this case `message,name`) at the top? (I know it&#39;s possible manually, but how to do it within `jq`?)\r\n\r\n\r\n  [1]: http://stedolan.github.io/jq/tutorial/",
        "link": "https://stackoverflow.com/questions/30015555/how-to-add-a-header-to-csv-export-in-jq",
        "title": "How to add a header to CSV export in jq?"
    },
    {
        "tags": [
            "json",
            "linux",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 166270,
                    "reputation": 135171,
                    "user_id": 390278,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/84715fec547362389d02f5be0ed12814?s=256&d=identicon&r=PG",
                    "display_name": "Jeff Mercado",
                    "link": "https://stackoverflow.com/users/390278/jeff-mercado"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1430776534,
                "post_id": 30039157,
                "comment_id": 48197303,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 4433665,
                    "reputation": 283,
                    "user_id": 3610137,
                    "user_type": "registered",
                    "accept_rate": 61,
                    "profile_image": "https://www.gravatar.com/avatar/0212a6eae0f43cafad0e5ee2fd28edc8?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "user3610137",
                    "link": "https://stackoverflow.com/users/3610137/user3610137"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1430785685,
                "post_id": 30039157,
                "comment_id": 48200267,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1430786346,
                "creation_date": 1430786346,
                "answer_id": 30042415,
                "question_id": 30039157,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "    $ jq -r &#39;.test[] | select(.type == &quot;3&quot;).Web&#39; file.json \r\n    target2.com\r\n    target3.com\r\n    target3.com\r\n\r\nThis passes the `.test[]` nodes to `select`, which filters its input using the `.type == &quot;3&quot;` selector. Then it selects `.Web` from the filtered list.",
                "title": "Using jq to extract certain info from JSON file"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1430786346,
        "creation_date": 1430770523,
        "last_edit_date": 1430786194,
        "question_id": 30039157,
        "body_markdown": "I am extracting some info from my json files that are formatted like this:\r\n\r\n    {\r\n        &quot;name&quot;: &quot;value&quot;,\r\n        &quot;website&quot;: &quot;https://google.com&quot;,\r\n        &quot;type&quot; : &quot;money&quot;,\r\n        &quot;some&quot;: &quot;0&quot;,\r\n        &quot;something_else&quot;: &quot;0&quot;,\r\n        &quot;something_new&quot;: &quot;0&quot;,\r\n        &quot;test&quot;: [\r\n          {&quot;Web&quot; : &quot;target1.com&quot;, &quot;type&quot; : &quot;2&quot; },\r\n          {&quot;Web&quot; : &quot;target2.com&quot;, &quot;type&quot; : &quot;3&quot; },\r\n          {&quot;Web&quot; : &quot;target3.com&quot;, &quot;type&quot; : &quot;3&quot; }, \r\n          {&quot;Web&quot; : &quot;target3.com&quot;, &quot;type&quot; : &quot;3&quot; } \r\n        ]\r\n    }\r\n\r\nI am aware that `jq -r .test[].Web` will output:\r\n\r\n    target1.com\r\n    target2.com\r\n    target3.com \r\n\r\nbut what if I only want to get the values with type is 3 meaning the output will only show target2.com and target3.com\r\n",
        "link": "https://stackoverflow.com/questions/30039157/using-jq-to-extract-certain-info-from-json-file",
        "title": "Using jq to extract certain info from JSON file"
    },
    {
        "tags": [
            "json",
            "unix",
            "csv",
            "flatten",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 166270,
                    "reputation": 135171,
                    "user_id": 390278,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/84715fec547362389d02f5be0ed12814?s=256&d=identicon&r=PG",
                    "display_name": "Jeff Mercado",
                    "link": "https://stackoverflow.com/users/390278/jeff-mercado"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1431041567,
                "post_id": 30113355,
                "comment_id": 48337569,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 308303,
                    "reputation": 37458,
                    "user_id": 620097,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/820980fd43f2607a815c1f3dbfe152cc?s=256&d=identicon&r=PG",
                    "display_name": "shellter",
                    "link": "https://stackoverflow.com/users/620097/shellter"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1431045017,
                "post_id": 30113355,
                "comment_id": 48338536,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1431450413,
                "creation_date": 1431450413,
                "answer_id": 30197322,
                "question_id": 30113355,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "cat Filename.json | sed 1d | sed &#39;s/},/}/&#39; | jq --raw-output &#39;. | [.Date, .Object, .ID, .Name ] | @csv&#39;",
                "title": "Error message when trying to flatten JSON file to CSV"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1431450413,
        "creation_date": 1431041433,
        "last_edit_date": 1431042789,
        "question_id": 30113355,
        "body_markdown": "Trying to flatten a `JSON` file to `CSV` in `UNIX` but getting an error message. Any help here to get the contents copied to `CSV` will be appreciated:\r\n\r\nCommand:\r\n\r\n    cat Filename.json | jq --raw-output &#39;._data.data[] | [.Date, .Object, .ID, .Name ] | @csv&#39; &gt; /home/Filename.csv\r\n\r\nError:\r\n\r\n    jq: error: Cannot iterate over null",
        "link": "https://stackoverflow.com/questions/30113355/error-message-when-trying-to-flatten-json-file-to-csv",
        "title": "Error message when trying to flatten JSON file to CSV"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1431406508,
                "last_edit_date": 1431406508,
                "creation_date": 1431338528,
                "answer_id": 30164725,
                "question_id": 30163016,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "jq &#39;to_entries | map(.key as $mykey | .value | to_entries | map([$mykey, .key, .value])) | add &#39; test.json \r\n\r\n1. transform JSON object to standard form jq\r\n2. remember key we has parsed\r\n3. parse value JSON object\r\n4. construct output\r\n\r\n\r\n--------------------------------------------------------------------------\r\nupdate:\r\njq &#39;to_entries | map(.key as $mykey | .value | to_entries | map(.key as $mykey2 | .value | to_entries | map([$mykey, $mykey2, .key]))) | add | add &#39; test.json \r\n\r\njq offers two kinds of tools that we can manipulate json files. Firstly we can filter data in json file but the filtering may lose data. Secondly we can map and reduce the data.\r\n\r\nSo we firstly must turn your variable json into fixed structure which we can access its key and value pair. After that we use filter to extract data from value field. As you have given a json file that nested 3 variable dict so we have to do three times to transform variable json to fixed filed one.",
                "title": "extracting json using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1431406508,
        "creation_date": 1431333396,
        "last_edit_date": 1431365583,
        "question_id": 30163016,
        "body_markdown": "I have sample Json file like this.How to extract data from it?\r\n\r\nI have tried few things.But could not get the desired result\r\n\r\n    {\r\n       &quot;adults&quot;:{\r\n                   &quot;car&quot;:{&quot;length&quot;:[20,25],&quot;width&quot;:[225,40]},\r\n                   &quot;tractor&quot;:{&quot;length&quot;:[20,23],&quot;width&quot;:[223,40]}\r\n                },\r\n       &quot;children&quot;:{\r\n                    &quot;cycle&quot;:{&quot;length&quot;:[20,21],&quot;width&quot;:[221,40]},\r\n                  }\r\n    }\r\n\r\nI want to insert this data to the database with the following columns:\r\n\r\nage_group | vehicle | measurements\r\n\r\nSo that my final table would be\r\n\r\n    age_group | vehicle  | measurements\r\n    ------------------------------------\r\n    adults      car         {&quot;length&quot;:[20,25],&quot;width&quot;:[225,40]}\r\n    adults      tractor     {&quot;length&quot;:[20,21],&quot;width&quot;:[223,40]}\r\n    children    cycle       {&quot;length&quot;:[20,21],&quot;width&quot;:[221,40]}\r\n\r\nHow Can I extract the info from the json object to a text file as required using jq?\r\n\r\n\r\nEdit:how to get the inner keys as required below?\r\n\r\n  \r\n\r\n    age_group | vehicle  | Dimension\r\n        ------------------------------------\r\n        adults      car         length\r\n        adults      car         width\r\n    \r\n        adults      tractor     length\r\n        adults       tractor     width\r\n        children    cycle       length\r\n        children    cycle        width\r\n\r\n",
        "link": "https://stackoverflow.com/questions/30163016/extracting-json-using-jq",
        "title": "extracting json using jq"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1431406899,
                "creation_date": 1431406899,
                "answer_id": 30182148,
                "question_id": 30172253,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Take a functional approach to this and create an update function that will create the updated values with the cumulative sum.\r\n\r\n    def accumulate(acc):\r\n        select(length &gt; 0) |\r\n        (.[0][1] + acc) as $next |\r\n        (.[0] | .[1] = $next), (.[1:] | accumulate($next))\r\n        ;\r\n    [accumulate(0)]\r\n\r\nHere, we break the array into &quot;head&quot; and &quot;tail&quot; updating the head with the current sum and recursively update the tail.  The results are placed back into a new array.",
                "title": "Cumulative sum in jq"
            },
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1493668008,
                "last_edit_date": 1493668008,
                "creation_date": 1431465410,
                "answer_id": 30201579,
                "question_id": 30172253,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The following is quite general (e.g. it can be used with an array of objects):\r\n\r\n    def accumulate(f):\r\n      reduce .[1:][] as $row\r\n        ([.[0]];\r\n         . as $x\r\n         | $x + [ $row | (f = ($x | .[length-1] | f) + ($row|f)  ) ] );\r\n    \r\n    accumulate(.[1])\r\n\r\n\r\nIf you are using a sufficiently recent version of jq, then &quot;$x |\r\n .[length-1]&quot; can be simplified to &quot;$x[-1]&quot;.\r\n\r\n### Solution using foreach\r\n\r\nIf your jq has foreach, then the following variant can be used.  It would be particularly appropriate if a stream of values rather than array is wanted.\r\n\r\n    def accumulates(f):\r\n      foreach .[] as $row\r\n        (0;\r\n         . + ($row | f) ;\r\n         . as $x | $row | (f = $x));\r\n\r\nUsage: \r\n\r\nFor a stream: `accumulates(.[0])`\r\n\r\nFor an array: `[accumulates(.[0])`\r\n",
                "title": "Cumulative sum in jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 3,
        "last_activity_date": 1493668008,
        "creation_date": 1431359676,
        "question_id": 30172253,
        "body_markdown": "I have a series of `[timestamp, count]` pairs in an array and a want to compute the cumulative sum at each timestamp using `jq`. How could I do that?\r\n\r\nHere a sample data set:\r\n\r\n    [\r\n      [1431047957699, 1],\r\n      [1431047958269, 1],\r\n      [1431047958901, 1],\r\n      [1431047959147, -1],\r\n      [1431047960164, 1]\r\n    ]\r\n\r\nAnd the expected result:\r\n\r\n    [1431047957699, 1],\r\n    [1431047958269, 2],\r\n    [1431047958901, 3],\r\n    [1431047959147, 2],\r\n    [1431047960164, 3]\r\n\r\nIs it possible to do this with `jq`?",
        "link": "https://stackoverflow.com/questions/30172253/cumulative-sum-in-jq",
        "title": "Cumulative sum in jq"
    },
    {
        "tags": [
            "json",
            "csv",
            "transformation",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1431551574,
                "last_edit_date": 1431551574,
                "creation_date": 1431550838,
                "answer_id": 30225100,
                "question_id": 30222305,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "TSV is fortunately a simpler format compared to CSV.  Assuming the values will not have newlines or tabs, you just need to build up each of the rows of data you want in the file and print them out separating values by tabs.  Just make sure you use the raw output `-r` option.\r\n\r\n    [ .a, .birthDay, .deathDay ] | join(&quot;\\t&quot;)",
                "title": "jQ: transforming json to tsv on Windows"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1431756098,
                "creation_date": 1431756098,
                "answer_id": 30272380,
                "question_id": 30222305,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Recent versions of jq (e.g. 1.5rc1 -- available via https://github.com/stedolan/jq/releases) include a filter named `@tsv`.\r\n\r\nOn April 15, jq was enhanced so that @tsv will produce valid tsv (one line per valid array), e.g. if an input string contains tabs, newlines, or NULs.",
                "title": "jQ: transforming json to tsv on Windows"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1454186638,
        "creation_date": 1431540596,
        "last_edit_date": 1454186638,
        "question_id": 30222305,
        "body_markdown": "I am using jq on a windows machine and I have the following data:\r\n\r\n    {&quot;a&quot;:&quot;Person&quot;,&quot;birthDay&quot;:&quot;12&quot;,&quot;deathDay&quot;:&quot;15&quot;, ...}\r\n    {&quot;a&quot;:&quot;Person&quot;,&quot;birthDay&quot;:&quot;13&quot;,&quot;deathDay&quot;:&quot;16&quot;, ...}\r\n    ...\r\nAnd I would like to have a tab separated file format:\r\n\r\n    Person   12   15\r\n    Person   13   16\r\n\r\nI can get the values with &quot;.a&quot;  or &quot;.birhtDay&quot;. But how can I get all values and separate them through a tab?\r\n\r\nKind regards,\r\nSnafu",
        "link": "https://stackoverflow.com/questions/30222305/jq-transforming-json-to-tsv-on-windows",
        "title": "jQ: transforming json to tsv on Windows"
    },
    {
        "tags": [
            "json",
            "linux",
            "bash",
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2141010,
                    "reputation": 124401,
                    "user_id": 1899640,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/47374ccb28e4b0d2454b64f7b975bc66?s=256&d=identicon&r=PG",
                    "display_name": "that other guy",
                    "link": "https://stackoverflow.com/users/1899640/that-other-guy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1431991162,
                "post_id": 30314137,
                "comment_id": 48723944,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 57200,
                    "reputation": 158728,
                    "user_id": 171318,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/ePRKy.jpg?s=256",
                    "display_name": "hek2mgl",
                    "link": "https://stackoverflow.com/users/171318/hek2mgl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1431991338,
                "post_id": 30314137,
                "comment_id": 48724000,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 1725940,
                    "reputation": 1079,
                    "user_id": 1580594,
                    "user_type": "registered",
                    "accept_rate": 76,
                    "profile_image": "https://www.gravatar.com/avatar/94c9e437d063b30b4b3f14147ddc0dad?s=256&d=identicon&r=PG",
                    "display_name": "odieatla",
                    "link": "https://stackoverflow.com/users/1580594/odieatla"
                },
                "reply_to_user": {
                    "account_id": 57200,
                    "reputation": 158728,
                    "user_id": 171318,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/ePRKy.jpg?s=256",
                    "display_name": "hek2mgl",
                    "link": "https://stackoverflow.com/users/171318/hek2mgl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1431991682,
                "post_id": 30314137,
                "comment_id": 48724113,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 57200,
                    "reputation": 158728,
                    "user_id": 171318,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/ePRKy.jpg?s=256",
                    "display_name": "hek2mgl",
                    "link": "https://stackoverflow.com/users/171318/hek2mgl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1431991805,
                "post_id": 30314137,
                "comment_id": 48724156,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1431992915,
                "last_edit_date": 1431992915,
                "creation_date": 1431992427,
                "answer_id": 30314499,
                "question_id": 30314137,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Your command fails not because you&#39;re looping wrong or passing arguments wrong, but because `protocol-config` is not a valid identifier:\r\n\r\n    $ jq &#39;.protocol-config&#39;\r\n    error: config is not defined\r\n\r\nThe first step should always be to find a command that works without a loop or variables. Don&#39;t try to write a loop for something you can&#39;t get to run once! Don&#39;t generalize a command you can&#39;t get to work in a specific case!\r\n\r\nHere&#39;s a working command to get `config-var1` from index `0`. \r\n\r\n    $ jq -r &#39;.[&quot;protocol-config&quot;][0][&quot;config-var1&quot;]&#39; &lt; json\r\n    vc1\r\n\r\nNow we can try to abstract out the arguments, testing to make sure it still works:\r\n\r\n    $ jq -r --arg i &quot;0&quot; --arg var &quot;config-var1&quot; \\\r\n        &#39;.[&quot;protocol-config&quot;][$i|tonumber][$var]&#39; &lt; json\r\n    vc1\r\n\r\nNow that we have a working way of getting single items, we can do that multiple times with a loop:\r\n\r\n    $ cat myscript\r\n    i=0\r\n    file=&quot;json&quot;\r\n    for var in &quot;var1&quot; &quot;var2&quot;\r\n    do\r\n        jq -r --arg i &quot;$i&quot; --arg var &quot;config-$var&quot; \\\r\n            &#39;.[&quot;protocol-config&quot;][$i|tonumber][$var]&#39; &lt; &quot;$file&quot;\r\n    done\r\n    \r\n    $ bash myscript\r\n    vc1\r\n    vc2\r\n\r\n",
                "title": "jq in shellscript: parse argument with &#39;-&#39;"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1432021004,
                "creation_date": 1432021004,
                "answer_id": 30319447,
                "question_id": 30314137,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "1. The original problem statement is unclear to me, but I suspect that there&#39;s no need to invoke jq more than once or even to use any bash scripting at all.  (jq is fast but there is some overhead in starting it up.)\r\n\r\nSuppose, for example, that you want to pass the list of &quot;var&quot; values to the jq program. This can be done as illustrated by the following:\r\n\r\n    $ jq -n --arg x &#39;[&quot;var2&quot;,&quot;var2&quot;]&#39; &#39;$x|fromjson&#39;\r\n    [\r\n      &quot;var2&quot;,\r\n      &quot;var2&quot;\r\n    ]\r\n  \r\n2. Regarding &quot;startswith&quot; -- the current &quot;stable&quot; release of jq is version 1.4, which has been available since June, 2014; it has the filter startswith/1, which has been available since December 2013.  For further information, about available downloads, see in particular:\r\n* http://stedolan.github.io/jq/download\r\n* https://github.com/stedolan/jq/releases\r\n",
                "title": "jq in shellscript: parse argument with &#39;-&#39;"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1432021004,
        "creation_date": 1431990247,
        "last_edit_date": 1431991398,
        "question_id": 30314137,
        "body_markdown": "Here&#39;s the json I need to parse:\r\n\r\n    {&quot;protocol-config&quot;:[\r\n        {&quot;protocol&quot;:&quot;p1&quot;,&quot;config-var1&quot;:&quot;vc1&quot;, &quot;config-var2&quot;:&quot;vc2&quot;},\r\n        {&quot;protocol&quot;:&quot;p2&quot;,&quot;config-var1&quot;:&quot;vc3&quot;, &quot;config-var2&quot;:&quot;vc4&quot;}\r\n    ]}\r\n\r\nAnd my code to parse is like the following:\r\n\r\n    declare -a vals=(&quot;var1&quot; &quot;var2&quot;)\r\n    for val in &quot;${vals[@]}&quot;; then\r\n        eval &quot;result=($(cat $INPUT | jq -r --arg i &quot;$i&quot; --arg var &quot;config-$val&quot; &#39;.protocol-config[$i | tonumber][$var]&#39;))&quot;\r\n    done\r\n\r\nThe problem is this part:\r\n\r\n    jq -r --arg i &quot;$i&quot; --arg var &quot;config-$val&quot; &#39;.protocol-config[$i | tonumber][$var]&#39;\r\n\r\nI can&#39;t get the value of it and I guess the reason is that I didn&#39;t pass $var correctly? I also tried\r\n\r\n    jq -r --arg i &quot;$i&quot; --arg var &quot;config-$val&quot; &#39;.protocol-config[$i | tonumber][\\&quot;$var\\&quot;]&#39;\r\nBut it doesn&#39;t work..Maybe the tiny &#39;-&#39; in the &quot;config-$val&quot; made it special? So my question is what is the right way to pass in argument like &quot;config-$val&quot; in jq?\r\n\r\nAny help is appreciated! Thanks very much!",
        "link": "https://stackoverflow.com/questions/30314137/jq-in-shellscript-parse-argument-with",
        "title": "jq in shellscript: parse argument with &#39;-&#39;"
    },
    {
        "tags": [
            "json",
            "variables",
            "dictionary",
            "key",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1432049634,
                "creation_date": 1432049634,
                "answer_id": 30330038,
                "question_id": 30330037,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "After playing around a bit, I came up with this function, which does the trick, by converting keys into values using &quot;to_entries&quot;:\r\n\r\n    def val(key):\r\n        key as $key | \r\n        to_entries | \r\n        .[] | select(.key == $key) | \r\n        .value;\r\n\r\n    &quot;a_key&quot; as $key | val($key) # outputs 2\r\n\r\n\r\nStill, I feel there should be a simpler solution.",
                "title": "How to select values of keys that are provided as variables in jq?"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1432050613,
                "creation_date": 1432050613,
                "answer_id": 30330367,
                "question_id": 30330037,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Just like in javascript, jq supports indexing.  You can access properties by name on objects.\r\n\r\n    &quot;a_key&quot; as $key | .[$key]",
                "title": "How to select values of keys that are provided as variables in jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1432050731,
        "creation_date": 1432049634,
        "last_edit_date": 1432050731,
        "question_id": 30330037,
        "body_markdown": "If this was the input,\r\n\r\n    {\r\n        &quot;a_key&quot;:        2,\r\n        &quot;another_key&quot;:  100,\r\n        &quot;one_more_key&quot;: -4.2\r\n    }\r\n\r\nwhat would be the best way to select the value of any of these keys by providing the name of the key as a variable? Ideally, I was looking for something like:\r\n\r\n    &quot;a_key&quot; as $key | .$key\r\n\r\nThis result in a syntax error, though (&quot;unexpected &#39;$&#39;&quot;). I could not figure out a straightforward way to make jq evaluate the variable.\r\n",
        "link": "https://stackoverflow.com/questions/30330037/how-to-select-values-of-keys-that-are-provided-as-variables-in-jq",
        "title": "How to select values of keys that are provided as variables in jq?"
    },
    {
        "tags": [
            "json",
            "sorting",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 162,
                "is_accepted": false,
                "score": 160,
                "last_activity_date": 1621109838,
                "last_edit_date": 1621109838,
                "creation_date": 1432057702,
                "answer_id": 30332672,
                "question_id": 30331504,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Ok with some assistance on the IRC channel I&#39;ve found an answer.\r\n\r\nBasically, it looks like this:\r\n\r\n```sh\r\njq \\\r\n  &#39;.components.rows|=sort_by(.id)|.components.rows[].properties|=sort_by(.name)&#39; \\\r\n  file.json &gt; out.json\r\n```\r\n\r\nSelect the right object,  \r\nwalk into arrays if needed,  \r\nthen `sort_by` a single value. \r\n\r\nI was trying `sort_by(.components.rows.id)` which failed.\r\n\r\n`|=` instead of `|` passes the values along instead of stripping them.",
                "title": "How to sort a json file by keys and values of those keys in jq"
            },
            {
                "up_vote_count": 180,
                "is_accepted": false,
                "score": 168,
                "last_activity_date": 1744043231,
                "last_edit_date": 1744043231,
                "creation_date": 1568897170,
                "answer_id": 58011343,
                "question_id": 30331504,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This doesn&#39;t answer the question, but here is another way to sort by attributes/keys:\r\n\r\nFrom [`man jq`](https://dyn.manpages.debian.org/jump?q=jq):\r\n&gt;**--sort-keys** / **-S**:  \r\n&gt;Output the fields of each object with the keys in sorted order.\r\n\r\nExample:\r\n\r\n&lt;!-- language-all: shell --&gt;\r\n    jq --sort-keys . my_file &gt; sorted_file\r\n-or-\r\n\r\n    jq -S . my_file &gt; sorted_file\r\n",
                "title": "How to sort a json file by keys and values of those keys in jq"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1676026875,
                "creation_date": 1676026875,
                "answer_id": 75410201,
                "question_id": 30331504,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you need it inside a JQ query go for:\r\n\r\n```\r\ndef sort_keys:\r\n\t(if (.|type!=&quot;object&quot;) then error(&quot;sort_keys: object expected&quot;) else . end)\r\n\t|(.|keys) as $keys\r\n\t|. as $o\r\n\t|reduce $keys[] as $i ({};.[$i]=$o[$i]);\r\n```",
                "title": "How to sort a json file by keys and values of those keys in jq"
            },
            {
                "up_vote_count": 13,
                "is_accepted": false,
                "score": 13,
                "last_activity_date": 1720219250,
                "last_edit_date": 1720219250,
                "creation_date": 1717557437,
                "answer_id": 78578599,
                "question_id": 30331504,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "# 1. Sort key/value in single JSONObject\r\n\r\ndemo json: (shell script)\r\n\r\n```shell\r\njson=&#39;\r\n{\r\n    &quot;key_a&quot;: 500,\r\n    &quot;key_e&quot;: 200,\r\n    &quot;key_f&quot;: 100,\r\n    &quot;key_b&quot;: 400,\r\n    &quot;key_c&quot;: 300\r\n}\r\n&#39;\r\n```\r\n## 1.1 Sort by key\r\n\r\ncommand:\r\n\r\n```shell\r\necho &quot;${json}&quot; | jq -r --sort-keys\r\n# or\r\necho &quot;${json}&quot; | jq -r &#39;to_entries | sort_by(.key) | from_entries&#39;\r\n```\r\n\r\noutput:\r\n\r\n```json\r\n{\r\n  &quot;key_a&quot;: 500,\r\n  &quot;key_b&quot;: 400,\r\n  &quot;key_c&quot;: 300,\r\n  &quot;key_e&quot;: 200,\r\n  &quot;key_f&quot;: 100\r\n}\r\n```\r\n\r\n## 1.1 Sort by value\r\n\r\ncommand :\r\n\r\n```shell\r\necho &quot;${json}&quot; | jq -r &#39;to_entries | sort_by(.value) | from_entries&#39;\r\n```\r\n\r\noutput:\r\n\r\n```json\r\n{\r\n  &quot;key_f&quot;: 100,\r\n  &quot;key_e&quot;: 200,\r\n  &quot;key_c&quot;: 300,\r\n  &quot;key_b&quot;: 400,\r\n  &quot;key_a&quot;: 500\r\n}\r\n```\r\n\r\n\r\n# 2. Sort elements in JSONArray\r\n\r\ndemo json: (shell script)\r\n\r\n```shell\r\njson=&#39;\r\n[\r\n    {&quot;name&quot;:&quot;zhang3&quot;, &quot;age&quot;:40},\r\n    {&quot;name&quot;:&quot;li4&quot;,    &quot;age&quot;:28},\r\n    {&quot;name&quot;:&quot;wang5&quot;,  &quot;age&quot;:50},\r\n    {&quot;name&quot;:&quot;zhao6&quot;,  &quot;age&quot;:18}\r\n]\r\n&#39;\r\n```\r\n\r\n## 2.1 Sort, ascending order , limit\r\n\r\nsort by element&#39;s property `age` value, take first 3 elements.\r\n\r\ncommand :\r\n\r\n```shell\r\necho &quot;${json}&quot; | jq -r &#39;sort_by(.age)|[limit(3;.[])]&#39;\r\n```\r\n\r\noutput : \r\n\r\n```json\r\n[\r\n  {\r\n    &quot;name&quot;: &quot;zhao6&quot;,\r\n    &quot;age&quot;: 18\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;li4&quot;,\r\n    &quot;age&quot;: 28\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;zhang3&quot;,\r\n    &quot;age&quot;: 40\r\n  }\r\n]\r\n```\r\n\r\n## 2.1 Descending order\r\n\r\njust use `reverse`.\r\n\r\ncommand :\r\n\r\n```shell\r\necho &quot;${json}&quot; | jq -r &#39;sort_by(.age)|reverse|[limit(3;.[])]&#39;\r\n```\r\n\r\noutput:\r\n```json\r\n[\r\n  {\r\n    &quot;name&quot;: &quot;wang5&quot;,\r\n    &quot;age&quot;: 50\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;zhang3&quot;,\r\n    &quot;age&quot;: 40\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;li4&quot;,\r\n    &quot;age&quot;: 28\r\n  }\r\n]\r\n```\r\n\r\n# 3 JSON Lines List of JSON Objects\r\n\r\nDemo [JSON Lines](https://jsonlines.org/) variable\r\n\r\n```shell\r\njson=&#39;                                   \r\n    {&quot;name&quot;:&quot;zhang3&quot;, &quot;age&quot;:40}\r\n    {&quot;name&quot;:&quot;li4&quot;,    &quot;age&quot;:28} \r\n    {&quot;name&quot;:&quot;wang5&quot;,  &quot;age&quot;:50} \r\n    {&quot;name&quot;:&quot;zhao6&quot;,  &quot;age&quot;:18}\r\n&#39;\r\n```\r\n\r\n# 3.1 Ascending order by age\r\n\r\n```shell\r\necho &quot;${json}&quot; | jq -c -s &#39;sort_by(.age) | .[]&#39;\r\n```\r\n\r\nOutput:\r\n\r\n```json\r\n{&quot;name&quot;:&quot;zhao6&quot;,&quot;age&quot;:18}\r\n{&quot;name&quot;:&quot;li4&quot;,&quot;age&quot;:28}\r\n{&quot;name&quot;:&quot;zhang3&quot;,&quot;age&quot;:40}\r\n{&quot;name&quot;:&quot;wang5&quot;,&quot;age&quot;:50}\r\n```\r\n\r\n# 3.2 Ascending order by age and sort fields in the objects\r\n\r\n```shell\r\necho &quot;${json}&quot; | jq -c -s &#39;sort_by(.age) | .[] | to_entries | sort_by(.key) | from_entries&#39;\r\n```\r\nor use `--sort-keys`\r\n```shell\r\necho &quot;${json}&quot; | jq -c -s --sort-keys &#39;sort_by(.age) | .[]&#39;\r\n```\r\n\r\nOutput: (note that age is the first field in each object now)\r\n\r\n```json\r\n{&quot;age&quot;:18,&quot;name&quot;:&quot;zhao6&quot;}\r\n{&quot;age&quot;:28,&quot;name&quot;:&quot;li4&quot;}\r\n{&quot;age&quot;:40,&quot;name&quot;:&quot;zhang3&quot;}\r\n{&quot;age&quot;:50,&quot;name&quot;:&quot;wang5&quot;}\r\n```",
                "title": "How to sort a json file by keys and values of those keys in jq"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": 166,
        "last_activity_date": 1744043231,
        "creation_date": 1432053922,
        "last_edit_date": 1620855178,
        "question_id": 30331504,
        "body_markdown": "We&#39;re building a website using the Pentaho CTools library, which has a graphical dashboard editor which writes out JSON-format files for part of the dashboard.\r\n\r\nI&#39;d like to apply a transform to these files before check-in to git in order to sort them by key and then by the value of certain keys. The purpose is to make diffs easier, since the editor has a habit of rearranging all of the json fields.\r\n\r\nFor example, we might have something like this:\r\n\r\n    {\r\n      &quot;components&quot;: {\r\n        &quot;rows&quot;: [\r\n          {\r\n            &quot;id&quot;: &quot;CHARTS&quot;,\r\n            &quot;name&quot;: &quot;Charts&quot;,\r\n            &quot;parent&quot;: &quot;UnIqEiD&quot;,\r\n            &quot;properties&quot;: [\r\n              {\r\n                &quot;name&quot;: &quot;Group&quot;,\r\n                &quot;type&quot;: &quot;Label&quot;,\r\n                &quot;value&quot;: &quot;Charts&quot;\r\n              }\r\n            ],\r\n            &quot;type&quot;: &quot;Label&quot;,\r\n            &quot;typeDesc&quot;: &quot;&lt;i&gt;Group&lt;/i&gt;&quot;\r\n          },\r\n          {\r\n            &quot;id&quot;: &quot;kjalajsdjf&quot;,\r\n            &quot;meta_cdwSupport&quot;: &quot;true&quot;,\r\n            &quot;parent&quot;: &quot;CHARTS&quot;,\r\n            &quot;properties&quot;: [\r\n              {\r\n                &quot;name&quot;: &quot;name&quot;,\r\n                &quot;type&quot;: &quot;Id&quot;,\r\n                &quot;value&quot;: &quot;Value1&quot;\r\n              },\r\n              {\r\n                &quot;name&quot;: &quot;title&quot;,\r\n                &quot;type&quot;: &quot;String&quot;,\r\n                &quot;value&quot;: &quot;Value2&quot;\r\n              },\r\n              {\r\n                &quot;name&quot;: &quot;listeners&quot;,\r\n                &quot;type&quot;: &quot;Listeners&quot;,\r\n                &quot;value&quot;: &quot;[]&quot;\r\n              },\r\n    ...\r\n\r\n\r\nWe are able to `jq --sort-keys` (http://stedolan.github.io/jq/) to sort all of the keys, but I&#39;m struggling to find out how to use the `sort_by` function to then sort certain specific elements by the value of certain keys (so, in the example above, sorting by `properties.name` for example. Any ideas?",
        "link": "https://stackoverflow.com/questions/30331504/how-to-sort-a-json-file-by-keys-and-values-of-those-keys-in-jq",
        "title": "How to sort a json file by keys and values of those keys in jq"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1432225745,
                "creation_date": 1432225745,
                "answer_id": 30379419,
                "question_id": 30378134,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "That&#39;s not a nested object... it&#39;s a json string. It&#39;s already pretty printed as it should. You need to parse the string if that&#39;s what you want.\r\n\r\n    .stream |= fromjson",
                "title": "Pretty print of nested stringified json in logs"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1610761245,
                "creation_date": 1610761245,
                "answer_id": 65745696,
                "question_id": 30378134,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "For me what worked is to take your json string and pipe it to jq using the -r (raw) flag. for example if you have a json object where the value is a long stringified log message like \r\n\r\n    {&quot;message&quot;:&quot;some long string with \\&quot;escaped characters \\n&quot;}\r\n\r\nYou take that input and pipe it to jq like  `| jq -r .message`",
                "title": "Pretty print of nested stringified json in logs"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1610761245,
        "creation_date": 1432222194,
        "question_id": 30378134,
        "body_markdown": "I&#39;m tailing some logs, and to be able to read them easier, I use jq (http://stedolan.github.io/jq/), but either it&#39;s missing something, or I don&#39;t know how to do what I need to do.\r\n\r\nSo all lines are json, and currently I&#39;m doing:\r\n\r\n    tail -f /path/to/log | jq .\r\n\r\nIssue is, sometimes, I have stuff like this (when logging http responses):\r\n\r\n    {\r\n      &quot;foo&quot;: &quot;bar&quot;,\r\n      &quot;fi&quot;: &quot;bo&quot;,\r\n      &quot;stream&quot;: &quot;{\\n  \\&quot;json\\&quot;: \\&quot;asAString\\&quot;\\n}&quot;\r\n    }\r\n\r\nAnd obviously, would like to end up with something like this:\r\n\r\n    {\r\n      &quot;foo&quot;: &quot;bar&quot;,\r\n      &quot;fi&quot;: &quot;bo&quot;,\r\n      &quot;stream&quot;: {\r\n        &quot;json&quot;: &quot;asAString&quot;\r\n      }\r\n    }\r\n\r\nAlthough we can assume in a first time I know the specific name of this fields that needs to be processed in a particular way, if you have an automated way to do that :-)\r\n\r\nThanks!",
        "link": "https://stackoverflow.com/questions/30378134/pretty-print-of-nested-stringified-json-in-logs",
        "title": "Pretty print of nested stringified json in logs"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2009956,
                    "reputation": 337,
                    "user_id": 1798671,
                    "user_type": "registered",
                    "accept_rate": 57,
                    "profile_image": "https://i.sstatic.net/udAar.png?s=256",
                    "display_name": "Pedro Monteiro",
                    "link": "https://stackoverflow.com/users/1798671/pedro-monteiro"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1432225905,
                "post_id": 30379445,
                "comment_id": 48848159,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 6344619,
                    "reputation": 305,
                    "user_id": 4925557,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/6ba224cc27644b10a3067b5de78a3941?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "innocentunremarkable",
                    "link": "https://stackoverflow.com/users/4925557/innocentunremarkable"
                },
                "reply_to_user": {
                    "account_id": 2009956,
                    "reputation": 337,
                    "user_id": 1798671,
                    "user_type": "registered",
                    "accept_rate": 57,
                    "profile_image": "https://i.sstatic.net/udAar.png?s=256",
                    "display_name": "Pedro Monteiro",
                    "link": "https://stackoverflow.com/users/1798671/pedro-monteiro"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1432226577,
                "post_id": 30379445,
                "comment_id": 48848573,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1432231519,
                "post_id": 30379445,
                "comment_id": 48851596,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 11,
                "is_accepted": true,
                "score": 11,
                "last_activity_date": 1432232376,
                "creation_date": 1432232376,
                "answer_id": 30381461,
                "question_id": 30379445,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "First step would be to flatten down the results to rows.\r\n\r\n    [{ unique } + (.coordinates[] | { time } + .xyz[])]\r\n\r\nThis would yield an array of objects per row:\r\n\r\n    [\r\n      {\r\n        &quot;unique&quot;: 1924,\r\n        &quot;time&quot;: &quot;2015-01-25T00:00:01.683&quot;,\r\n        &quot;id&quot;: 99,\r\n        &quot;x&quot;: 1,\r\n        &quot;y&quot;: 2,\r\n        &quot;z&quot;: 4\r\n      },\r\n      {\r\n        &quot;unique&quot;: 1924,\r\n        &quot;time&quot;: &quot;2015-01-25T00:00:01.683&quot;,\r\n        &quot;id&quot;: 100,\r\n        &quot;x&quot;: 8,\r\n        &quot;y&quot;: 9,\r\n        &quot;z&quot;: 9\r\n      },\r\n      {\r\n        &quot;unique&quot;: 1924,\r\n        &quot;time&quot;: &quot;2015-01-25T00:00:01.683&quot;,\r\n        &quot;id&quot;: 101,\r\n        &quot;x&quot;: 10,\r\n        &quot;y&quot;: 6,\r\n        &quot;z&quot;: 9\r\n      },\r\n      {\r\n        &quot;unique&quot;: 1924,\r\n        &quot;time&quot;: &quot;2015-01-25T00:00:02.790&quot;,\r\n        &quot;id&quot;: 99,\r\n        &quot;x&quot;: 7,\r\n        &quot;y&quot;: 3,\r\n        &quot;z&quot;: 0\r\n      },\r\n      ...\r\n    ]\r\n\r\nThen it&#39;s just a matter of converting this to csv rows.\r\n\r\n    [&quot;unique&quot;,&quot;time&quot;,&quot;id&quot;,&quot;x&quot;,&quot;y&quot;,&quot;z&quot;] as $fields | $fields, (.[] | [.[$fields[]]]) | @csv",
                "title": "Processing JSON of arrays in array with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 6,
        "last_activity_date": 1432233306,
        "creation_date": 1432225819,
        "last_edit_date": 1432233306,
        "question_id": 30379445,
        "body_markdown": "Environment: JQ 1.5, Windows 64-bit.\r\n\r\nI have the following JSON:\r\n\r\n    {\r\n      &quot;unique&quot;: 1924,\r\n      &quot;coordinates&quot;: [\r\n        {\r\n          &quot;time&quot;: &quot;2015-01-25T00:00:01.683&quot;,\r\n          &quot;xyz&quot;: [\r\n            {\r\n              &quot;z&quot;: 4,\r\n              &quot;y&quot;: 2,\r\n              &quot;x&quot;: 1,\r\n              &quot;id&quot;: 99\r\n            },\r\n            {\r\n              &quot;z&quot;: 9,\r\n              &quot;y&quot;: 9,\r\n              &quot;x&quot;: 8,\r\n              &quot;id&quot;: 100\r\n            },\r\n            {\r\n              &quot;z&quot;: 9,\r\n              &quot;y&quot;: 6,\r\n              &quot;x&quot;: 10,\r\n              &quot;id&quot;: 101\r\n            }\r\n          ]\r\n        },\r\n        {\r\n          &quot;time&quot;: &quot;2015-01-25T00:00:02.790&quot;,\r\n          &quot;xyz&quot;: [\r\n            {\r\n              &quot;z&quot;: 0,\r\n              &quot;y&quot;: 3,\r\n              &quot;x&quot;: 7,\r\n              &quot;id&quot;: 99\r\n            },\r\n            {\r\n              &quot;z&quot;: 4,\r\n              &quot;y&quot;: 6,\r\n              &quot;x&quot;: 2,\r\n              &quot;id&quot;: 100\r\n            },\r\n            {\r\n              &quot;z&quot;: 2,\r\n              &quot;y&quot;: 9,\r\n              &quot;x&quot;: 51,\r\n              &quot;id&quot;: 101\r\n            }\r\n          ]\r\n        }\r\n      ]\r\n    }\r\n\r\nAnd would like to convert it into this CSV format with jq:\r\n\r\n    unique,time,id,x,y,z\r\n    1924,&quot;2015-01-25T00:00:01.683&quot;,99,1,2,4\r\n    1924,&quot;2015-01-25T00:00:01.683&quot;,100,8,9,9\r\n\r\n(and so on)\r\n\r\nI tried a few things, such as:\r\n\r\n    jq -r &#39;{unique: .unique, coordinates: .coordinates[].xyz[] | [.id, .x, .y, .z], time: .coordinates.[].time} | flatten | @csv&#39; \r\n\r\nwhich gave me my desired JSON, but multiplied for every id, x, y, and z (i.e. each unique line appears four times - one each for id, x, y, z). \r\n\r\nAssigning a number to the array, such as\r\n\r\n    jq -r &#39;{unique: .unique, coordinates: .coordinates[0].xyz[] | [.id, .x, .y, .z], time: .coordinates.[0].time} | flatten | @csv&#39; \r\n\r\ngives me the first index of the `coordinates` array, but I&#39;d like all of them, naturally.\r\n",
        "link": "https://stackoverflow.com/questions/30379445/processing-json-of-arrays-in-array-with-jq",
        "title": "Processing JSON of arrays in array with jq"
    },
    {
        "tags": [
            "xml",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1432690642,
                "creation_date": 1432690642,
                "answer_id": 30471723,
                "question_id": 30463264,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The default output format is one or more valid JSON values.  XML is clearly not JSON.  However the string itself is valid, but the value it represents isn&#39;t.  You can ignore this restriction by using the raw output option (`-r`).  This will return the value of the string.\r\n\r\n    $ tail system.log | jq -r &#39;.rom_response_body&#39;\r\n    &lt;?xml version=&quot;1.0&quot; encoding=&quot;UTF-8&quot;?&gt;\r\n    &lt;OrderCreateResponse xmlns=&quot;http://api.example.com/schema/checkout/1.0&quot;&gt;\r\n       &lt;ResponseStatus&gt;Success&lt;/ResponseStatus&gt;\r\n       &lt;ResponseDescription&gt;CustomerOrderId = 0005410600539 , OrderUUID = 57c27a87-2f2e-41d1-bc20-afef511b91aa&lt;/ResponseDescription&gt;\r\n    &lt;/OrderCreateResponse&gt;",
                "title": "Pretty print xml encased in JSON"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1432690642,
        "creation_date": 1432655351,
        "question_id": 30463264,
        "body_markdown": "Log messages from an application conform to LogStash expectations (JSON), but we haven&#39;t got LogStash up and running in every case, so I&#39;ve been trying to learn to use [jq](https://stedolan.github.io/jq/) to read output when LogStash isn&#39;t available. The problem becomes tricky when the output is XML within the JSON. I get output like…\r\n\r\n    {\r\n        &lt;SNIP&gt;\r\n        &quot;rom_response_body&quot;: &quot;&lt;?xml version=\\&quot;1.0\\&quot; encoding=\\&quot;UTF-8\\&quot;?&gt;\\n&lt;OrderCreateResponse xmlns=\\&quot;http://api.example.com/schema/checkout/1.0\\&quot;&gt;\\n   &lt;ResponseStatus&gt;Success&lt;/ResponseStatus&gt;\\n   &lt;ResponseDescription&gt;CustomerOrderId = 0005410600539 , OrderUUID = 57c27a87-2f2e-41d1-bc20-afef511b91aa&lt;/ResponseDescription&gt;\\n&lt;/OrderCreateResponse&gt;&quot;,\r\n        &lt;SNIP&gt;\r\n    }\r\n\r\nWhat I would like to get is:\r\n\r\n    &lt;?xml version=&quot;1.0&quot; encoding=&quot;UTF-8&quot;?&gt;\r\n    &lt;OrderCreateResponse xmlns=&quot;http://api.example.com/schema/checkout/1.0&quot;&gt;\r\n        &lt;ResponseStatus&gt;Success&lt;/ResponseStatus&gt;\r\n        &lt;ResponseDescription&gt;CustomerOrderId = 0005410600541 , OrderUUID = 3bc76558-f5aa-4e2e-866d-5c4707e873db&lt;/ResponseDescription&gt;\r\n    &lt;/OrderCreateResponse&gt;\r\n\r\nOr at least the well-formed xml in any raw form (from that point I can use xmllint). And I can _sorta_ get there with jq. If I do\r\n\r\n    tail system.log | jq &quot;select(.rom_response_body)|.rom_response_body|fromjson&quot;\r\n\r\nI get _error_ output like\r\n\r\n    jq: error: Invalid numeric literal at line 1, column 6 (while parsing &#39;&lt;?xml version=&quot;1.0&quot; encoding=&quot;UTF-8&quot;?&gt;\r\n    &lt;OrderCreateResponse xmlns=&quot;http://api.example.com/schema/checkout/1.0&quot;&gt;\r\n       &lt;ResponseStatus&gt;Success&lt;/ResponseStatus&gt;\r\n       &lt;ResponseDescription&gt;CustomerOrderId = 0005410600541 , OrderUUID = 3bc76558-f5aa-4e2e-866d-5c4707e873db&lt;/ResponseDescription&gt;\r\n    &lt;/OrderCreateResponse&gt;&#39;)\r\n\r\nI think the problem is that that input is not actually json, it&#39;s just a json-escaped string literal. It would be valid if wrapped with `{&quot;key&quot;: }`. Is there a saner way to get the output I need besides manually wrapping each line to make it complete JSON?",
        "link": "https://stackoverflow.com/questions/30463264/pretty-print-xml-encased-in-json",
        "title": "Pretty print xml encased in JSON"
    },
    {
        "tags": [
            "bash",
            "shell",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 11,
                "is_accepted": true,
                "score": 11,
                "last_activity_date": 1542192608,
                "last_edit_date": 1542192608,
                "creation_date": 1432899386,
                "answer_id": 30528604,
                "question_id": 30528518,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You have to use the right quotation, like this:\r\n\r\n    total_rows=`echo &quot;$emails&quot; | ./jq &#39;.total_rows&#39;`\r\n\r\nThe `` will execute the command and give `total_rows` the value of it, so whatever would be the output of\r\n\r\n    echo &quot;$emails&quot; | ./jq &#39;.total_rows&#39;\r\n\r\nwill so be stored in `total_rows`.\r\n\r\nAs mentioned in the comments by Tom Fenech, it is better to use `$()` for command substitution. It provides a better readability. So what you can do is:\r\n\r\n    total_rows=$(echo &quot;$emails&quot; | ./jq &#39;.total_rows&#39;)",
                "title": "Store value to variable in Shell script"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1542192608,
        "creation_date": 1432899127,
        "question_id": 30528518,
        "body_markdown": "&quot;$emails&quot; has the array of values, i want to parse the values from it, To do it, i am using the [jq][1]. if i do below command\r\n\r\n    echo &quot;$emails&quot; | ./jq &#39;.total_rows&#39;\r\n\r\ni could get the value i.e 4, i want to store the returned results into some variable,\r\n\r\n    total_rows=&quot;$emails&quot; | ./jq &#39;.total_rows&#39;\r\n\r\nbut total_rows has no value.\r\n\r\n    echo $total_rows\r\n\r\nHow do store the returned result into variable?\r\n\r\n\r\n\r\n  [1]: http://stedolan.github.io/jq",
        "link": "https://stackoverflow.com/questions/30528518/store-value-to-variable-in-shell-script",
        "title": "Store value to variable in Shell script"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1433131531,
                "last_edit_date": 1433131531,
                "creation_date": 1433130259,
                "answer_id": 30565334,
                "question_id": 30564976,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The [multiplication](http://stedolan.github.io/jq/manual/#Multiplicationdivisionmoduloand) of objects recursively merges the two.  You can merge the `[global]` object with an object with the new values.  The string values on the RHS will be used in the result.\r\n\r\n    .&quot;[global]&quot; *= { current: &quot;alpha&quot;, hash: &quot;bravo&quot; }\r\n\r\nAddtion would work here too, but multiplication is generally more useful, particularly with nested objects.  Rather than replacing corresponding objects, they are also merged.",
                "title": "Set multiple values"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1501784530,
                "creation_date": 1501784530,
                "answer_id": 45491849,
                "question_id": 30564976,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "As [Jeff](https://stackoverflow.com/users/390278/jeff-mercado) indicated, the non-recursive `+=` operator will also work in this situation.  Specifically:\r\n\r\n      .&quot;[global]&quot; += {current: &quot;alpha&quot;, hash:&quot;bravo&quot;}\r\n",
                "title": "Set multiple values"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 3,
        "last_activity_date": 1501784530,
        "creation_date": 1433126905,
        "question_id": 30564976,
        "body_markdown": "Given this file\r\n\r\n    {\r\n      &quot;[global]&quot;: {\r\n        &quot;current&quot;: &quot;&quot;,\r\n        &quot;hash&quot;: &quot;&quot;\r\n      }\r\n    }\r\n\r\nI would like this output:\r\n\r\n    {\r\n      &quot;[global]&quot;: {\r\n        &quot;current&quot;: &quot;alpha&quot;,\r\n        &quot;hash&quot;: &quot;bravo&quot;\r\n      }\r\n    }\r\n\r\nI have this working command:\r\n\r\n    jq &#39;.&quot;[global]&quot;.current=&quot;alpha&quot; | .&quot;[global]&quot;.hash=&quot;bravo&quot;&#39; example.json\r\n\r\nHowever I would rather not have to repeat the `.&quot;[global]&quot;` part. I tried this\r\ncommand but it only returns part of the input:\r\n\r\n    $ jq &#39;.&quot;[global]&quot; | .current=&quot;alpha&quot; | .hash=&quot;bravo&quot;&#39; example.json\r\n    {\r\n      &quot;current&quot;: &quot;alpha&quot;,\r\n      &quot;hash&quot;: &quot;bravo&quot;\r\n    }",
        "link": "https://stackoverflow.com/questions/30564976/set-multiple-values",
        "title": "Set multiple values"
    },
    {
        "tags": [
            "json",
            "categories",
            "data-manipulation",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1433132228,
                "creation_date": 1433132228,
                "answer_id": 30565570,
                "question_id": 30565569,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "This did the job:\r\n\r\n    def subgroups:\r\n    group_by(.&quot;Subgroup&quot;)|\r\n    map({\r\n      &quot;type&quot;: &quot;group&quot;, \r\n      &quot;name&quot;: .[0].&quot;Subgroup&quot;, \r\n      &quot;items&quot;: (map(del(.Subgroup)))\r\n    });\r\n    \r\n    group_by(.&quot;Group name&quot;)|\r\n    map({\r\n      &quot;type&quot;: &quot;group&quot;, \r\n      &quot;name&quot;: .[0].&quot;Group name&quot;, \r\n      &quot;items&quot;: (subgroups2|map(del(.&quot;Group name&quot;)))\r\n    })\r\n\r\nIt&#39;s just the same process twice:\r\n\r\n1. `group_by` to sort the outer items on &quot;group name&quot;\r\n2. For each of those groups, construct an object whose name is taken from the first item, and whose items are...\r\n3. Passed through to a function that repeats 1 and 2, and removes the grouping field.",
                "title": "How to convert flat array of objects with &quot;categories&quot; and &quot;subcategories&quot; to tree with JQ?"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1433138373,
                "last_edit_date": 1433138373,
                "creation_date": 1433136798,
                "answer_id": 30566219,
                "question_id": 30565569,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "I&#39;m not sure what your expected output is exactly, but this could be done more efficiently.  By parameterizing your grouping function, you could build up your trees in a reusable fashion.\r\n\r\n    def regroup(keyfilter; itemfilter):\r\n        group_by(keyfilter) | map({\r\n            type: &quot;group&quot;,\r\n            name: (.[0] | keyfilter),\r\n            items: itemfilter\r\n        })\r\n        ;\r\n    regroup(.&quot;Group name&quot;;\r\n        regroup(.Subgroup;\r\n            map({ name })\r\n        )\r\n    )\r\n\r\nThis yields the following results:\r\n\r\n    [\r\n      {\r\n        &quot;type&quot;: &quot;group&quot;,\r\n        &quot;name&quot;: &quot;Elevation&quot;,\r\n        &quot;items&quot;: [\r\n          {\r\n            &quot;type&quot;: &quot;group&quot;,\r\n            &quot;name&quot;: &quot;Contours&quot;,\r\n            &quot;items&quot;: [\r\n              { &quot;name&quot;: &quot;Contours - Labels&quot; },\r\n              { &quot;name&quot;: &quot;Contours&quot; }\r\n            ]\r\n          },\r\n          {\r\n            &quot;type&quot;: &quot;group&quot;,\r\n            &quot;name&quot;: &quot;Cuttings&quot;,\r\n            &quot;items&quot;: [\r\n              { &quot;name&quot;: &quot;Cuttings&quot; }\r\n            ]\r\n          }\r\n        ]\r\n      },\r\n      {\r\n        &quot;type&quot;: &quot;group&quot;,\r\n        &quot;name&quot;: &quot;Framework&quot;,\r\n        &quot;items&quot;: [\r\n          {\r\n            &quot;type&quot;: &quot;group&quot;,\r\n            &quot;name&quot;: &quot;Indigenous Reserves&quot;,\r\n            &quot;items&quot;: [\r\n              { &quot;name&quot;: &quot;Reserves&quot; }\r\n            ]\r\n          },\r\n          {\r\n            &quot;type&quot;: &quot;group&quot;,\r\n            &quot;name&quot;: &quot;Land Borders&quot;,\r\n            &quot;items&quot;: [\r\n              { &quot;name&quot;: &quot;Mainland&quot; }\r\n            ]\r\n          },\r\n          {\r\n            &quot;type&quot;: &quot;group&quot;,\r\n            &quot;name&quot;: &quot;Reserves&quot;,\r\n            &quot;items&quot;: [\r\n              { &quot;name&quot;: &quot;Reserves&quot; }\r\n            ]\r\n          }\r\n        ]\r\n      }\r\n    ]\r\n\r\nFunctions are very powerful, you should try to utilize it more.  Hopefully this shows just how powerful it can be.",
                "title": "How to convert flat array of objects with &quot;categories&quot; and &quot;subcategories&quot; to tree with JQ?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1433138373,
        "creation_date": 1433132228,
        "last_edit_date": 1433137407,
        "question_id": 30565569,
        "body_markdown": "I have a JSON array of objects with groups and subgroups that looks like this:\r\n\r\n    [\r\n      {\r\n        &quot;Group name&quot;: &quot;Elevation&quot;, \r\n        &quot;Subgroup&quot;: &quot;Contours&quot;, \r\n        &quot;name&quot;: &quot;Contours - Labels&quot;\r\n      }, \r\n      {\r\n        &quot;Group name&quot;: &quot;Elevation&quot;, \r\n        &quot;Subgroup&quot;: &quot;Contours&quot;, \r\n        &quot;name&quot;: &quot;Contours&quot;\r\n      }, \r\n      {\r\n        &quot;Group name&quot;: &quot;Elevation&quot;, \r\n        &quot;Subgroup&quot;: &quot;Cuttings&quot;, \r\n        &quot;name&quot;: &quot;Cuttings&quot;\r\n      },\r\n      {\r\n        &quot;Group name&quot;: &quot;Framework&quot;, \r\n        &quot;Subgroup&quot;: &quot;Reserves&quot;, \r\n        &quot;name&quot;: &quot;Reserves&quot;\r\n      }, \r\n      {\r\n        &quot;Group name&quot;: &quot;Framework&quot;, \r\n        &quot;Subgroup&quot;: &quot;Indigenous Reserves&quot;, \r\n        &quot;name&quot;: &quot;Reserves&quot;\r\n      }, \r\n      {\r\n        &quot;Group name&quot;: &quot;Framework&quot;, \r\n        &quot;Subgroup&quot;: &quot;Land Borders&quot;, \r\n        &quot;name&quot;: &quot;Mainland&quot;\r\n      }\r\n    ]\r\n\r\nI&#39;d like to convert it to a nested structure:\r\n\r\n    [ { type: group, name: Elevation, Items: [ ... ] } ]\r\n\r\nHow do you do this in JQ?",
        "link": "https://stackoverflow.com/questions/30565569/how-to-convert-flat-array-of-objects-with-categories-and-subcategories-to-tr",
        "title": "How to convert flat array of objects with &quot;categories&quot; and &quot;subcategories&quot; to tree with JQ?"
    },
    {
        "tags": [
            "object",
            "stream",
            "enumerate",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1433346178,
                "creation_date": 1433346178,
                "answer_id": 30624776,
                "question_id": 30584256,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Using the `-s` (slurp) option, you could do the following:\r\n\r\n`yes &#39;{}&#39; | head -n10 | jq -s &#39;to_entries | map(.value.count = .key)[].value&#39;`\r\n\r\nBut, yes, as you said yourself, slurping is wasteful; and, even worse, it blocks the stream.\r\n\r\nWhat you could do instead is, for each element, compact it so that it takes one line (piping it through `jq -c &#39;.&#39;`; your &quot;yes&quot; object sample doesn&#39;t need it, but arbitrary objects coming from the pipeline might) and then iterate through it on your shell. On fish shell, but easily portable to anything else:\r\n\r\n    set j 0\r\n    for i in (yes &#39;{}&#39; | head -n 100000 | jq -c &#39;.&#39;)\r\n      set j (expr $j + 1)\r\n      echo $i | jq --arg j $j &#39;.count = ($j | tonumber)&#39;\r\n    end",
                "title": "JQ: Enumerate Object Stream"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1435482397,
                "creation_date": 1435482397,
                "answer_id": 31097906,
                "question_id": 30584256,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Using a recent version of jq (i.e. with foreach and inputs), e.g jq 1.5rc1, the task can be performed efficiently and quite elegantly along the following lines:\r\n\r\n    yes 1 | head -n10 |\\\r\n     jq -c -n &#39;foreach inputs as $line (0; .+1; {&quot;count&quot;: &quot;Num_\\(.)&quot;})&#39;\r\n\r\nThe key here is to use the -n option.",
                "title": "JQ: Enumerate Object Stream"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1435482397,
        "creation_date": 1433197044,
        "question_id": 30584256,
        "body_markdown": "I&#39;ve got a pipe full of objects and I am trying to add a accumulating count string to each object in a stream with `jq` to get the following output\r\n\r\n    {&quot;count&quot;:&quot;Num_000&quot;}\r\n    {&quot;count&quot;:&quot;Num_001&quot;}\r\n    {&quot;count&quot;:&quot;Num_002&quot;}\r\n    {&quot;count&quot;:&quot;Num_003&quot;}\r\n    {&quot;count&quot;:&quot;Num_004&quot;}\r\n    {&quot;count&quot;:&quot;Num_005&quot;}\r\n    {&quot;count&quot;:&quot;Num_006&quot;}\r\n    {&quot;count&quot;:&quot;Num_007&quot;}\r\n    {&quot;count&quot;:&quot;Num_008&quot;}\r\n    {&quot;count&quot;:&quot;Num_009&quot;}\r\n\r\nSomething like the following but I&#39;m sure I don&#39;t need to rely on awk.\r\n\r\n    yes &#39;{}&#39; | head -n10 | jq -c &#39;.count|=&quot;Num_ &quot;&#39; | awk &#39;{printf(&quot;%s%03i%s\\n&quot;,$1,NR-1,$2)}&#39;\r\n\r\nSo far I have found one way to get the count into my objects but it feels very wasteful since I slurp up all the objects.\r\n\r\n    yes &#39;{}&#39; | head -n10 | jq -c -s &#39;range(0;.|length) as $i|(.[$i]|.count|=$i)&#39;\r\n\r\nI&#39;m going to keep playing with this but I figured this was a chance for me to learn. Any ideas how i can do this more efficiently?\r\n\r\nI&#39;ve also figured out one hack-y way to format the string since I assume &lt; 1000 objects in my stream.\r\n\r\n    yes &#39;{}&#39; | head -n20 | jq -c -s &#39;range(0;.|length) as $i|(.[$i]|.count|=(1000+$i|tostring|ltrimstr(&quot;1&quot;)|&quot;Num_&quot;+.))&#39;\r\n",
        "link": "https://stackoverflow.com/questions/30584256/jq-enumerate-object-stream",
        "title": "JQ: Enumerate Object Stream"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2251762,
                    "reputation": 292345,
                    "user_id": 1983854,
                    "user_type": "registered",
                    "accept_rate": 96,
                    "profile_image": "https://i.sstatic.net/KiqLo.png?s=256",
                    "display_name": "fedorqui",
                    "link": "https://stackoverflow.com/users/1983854/fedorqui"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1433257159,
                "post_id": 30599619,
                "comment_id": 49267903,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 98335,
                    "reputation": 6866,
                    "user_id": 266252,
                    "user_type": "registered",
                    "accept_rate": 84,
                    "profile_image": "https://www.gravatar.com/avatar/2e2de66a6abf92b6348f203bd3aaca50?s=256&d=identicon&r=PG",
                    "display_name": "Stephen Furlani",
                    "link": "https://stackoverflow.com/users/266252/stephen-furlani"
                },
                "reply_to_user": {
                    "account_id": 2251762,
                    "reputation": 292345,
                    "user_id": 1983854,
                    "user_type": "registered",
                    "accept_rate": 96,
                    "profile_image": "https://i.sstatic.net/KiqLo.png?s=256",
                    "display_name": "fedorqui",
                    "link": "https://stackoverflow.com/users/1983854/fedorqui"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1433257287,
                "post_id": 30599619,
                "comment_id": 49267988,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 57200,
                    "reputation": 158728,
                    "user_id": 171318,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/ePRKy.jpg?s=256",
                    "display_name": "hek2mgl",
                    "link": "https://stackoverflow.com/users/171318/hek2mgl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1433257467,
                "post_id": 30599619,
                "comment_id": 49268115,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 98335,
                    "reputation": 6866,
                    "user_id": 266252,
                    "user_type": "registered",
                    "accept_rate": 84,
                    "profile_image": "https://www.gravatar.com/avatar/2e2de66a6abf92b6348f203bd3aaca50?s=256&d=identicon&r=PG",
                    "display_name": "Stephen Furlani",
                    "link": "https://stackoverflow.com/users/266252/stephen-furlani"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1433257572,
                "post_id": 30599619,
                "comment_id": 49268186,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 57200,
                    "reputation": 158728,
                    "user_id": 171318,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/ePRKy.jpg?s=256",
                    "display_name": "hek2mgl",
                    "link": "https://stackoverflow.com/users/171318/hek2mgl"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1433257937,
                "post_id": 30599619,
                "comment_id": 49268456,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1433258080,
                "post_id": 30599619,
                "comment_id": 49268542,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 106232,
                    "reputation": 42816,
                    "user_id": 283078,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/27046ee7321f6c8a4c31c5a8ee066460?s=256&d=identicon&r=PG",
                    "display_name": "cmbuckley",
                    "link": "https://stackoverflow.com/users/283078/cmbuckley"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1433258111,
                "post_id": 30599619,
                "comment_id": 49268566,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "reply_to_user": {
                    "account_id": 106232,
                    "reputation": 42816,
                    "user_id": 283078,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/27046ee7321f6c8a4c31c5a8ee066460?s=256&d=identicon&r=PG",
                    "display_name": "cmbuckley",
                    "link": "https://stackoverflow.com/users/283078/cmbuckley"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1433258133,
                "post_id": 30599619,
                "comment_id": 49268583,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1433258335,
                "post_id": 30599619,
                "comment_id": 49268713,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1433258518,
                "post_id": 30599619,
                "comment_id": 49268852,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1433258891,
                "post_id": 30599619,
                "comment_id": 49269137,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 98335,
                    "reputation": 6866,
                    "user_id": 266252,
                    "user_type": "registered",
                    "accept_rate": 84,
                    "profile_image": "https://www.gravatar.com/avatar/2e2de66a6abf92b6348f203bd3aaca50?s=256&d=identicon&r=PG",
                    "display_name": "Stephen Furlani",
                    "link": "https://stackoverflow.com/users/266252/stephen-furlani"
                },
                "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": 1433265423,
                "post_id": 30599619,
                "comment_id": 49273404,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1433258755,
                "last_edit_date": 1433258755,
                "creation_date": 1433258218,
                "answer_id": 30600060,
                "question_id": 30599619,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "A simple transformation of your working code (also moving to lower-case variable names, as per convention for variable names not reserved for shell or system use):\r\n\r\n    payload=$(jq -n --argfile attach &lt;(printf &#39;%s\\n&#39; &quot;$final_json&quot;) &#39;{ \r\n    &quot;attachments&quot;:$attach\r\n    }&#39;)\r\n\r\nI&#39;m sticking with `--argfile` here since it parses the file&#39;s contents as JSON; using `--arg` wouldn&#39;t have that effect.\r\n\r\nThe `&lt;(...)` syntax is process substitution, which is replaced with a filename for a named pipe or temporary file connected to the content in question.\r\n\r\n---\r\n\r\nHowever, you can also use `--arg`, and apply the `fromjson` filter to parse as JSON:\r\n\r\n    payload=$(jq -n --arg attach &quot;$final_json&quot; &#39;{ \r\n    &quot;attachments&quot;:$attach|fromjson\r\n    }&#39;)",
                "title": "Passing JSON arguments (not simple strings) to jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1433258852,
        "creation_date": 1433257042,
        "last_edit_date": 1433258852,
        "question_id": 30599619,
        "body_markdown": "How do I pass in bash variables into a jq `--arg` parameter?\r\n\r\nAll I can get to work is this:\r\n\r\n    FINAL_JSON= #some JSON\r\n\r\n    PAYLOAD=$(echo $FINAL_JSON | jq &#39; {\r\n    &quot;attachments&quot;: .\r\n    } &#39;)\r\n\r\nWhat&#39;s bothering me is that `echo $FINAL_JSON` thing.  I should be able to pass in variables in `jq`??\r\n\r\n    PAYLOAD=$(jq -n --arg attach &quot;$FINAL_JSON&quot; &#39;{ \r\n    &quot;attachments&quot;:$attach\r\n    }&#39;)\r\n\r\nBut all that does is pass the JSON in as a string.  Without quotes `&quot;` around the `$FINAL_JSON` I get this error:\r\n\r\n    error: syntax error, unexpected $end\r\n    {1 compile error",
        "link": "https://stackoverflow.com/questions/30599619/passing-json-arguments-not-simple-strings-to-jq",
        "title": "Passing JSON arguments (not simple strings) to jq"
    },
    {
        "tags": [
            "json",
            "amazon-web-services",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 34,
                "is_accepted": true,
                "score": 34,
                "last_activity_date": 1433266624,
                "creation_date": 1433266624,
                "answer_id": 30602908,
                "question_id": 30601278,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You can use a variable to store the `OwnerID` as in:\r\n\r\n    .Reservations[] | .OwnerId as $OwnerId | ( .Instances[] | { &quot;OwnerId&quot;: $OwnerId, InstanceId, ImageId, PrivateIpAddress, Platform} )",
                "title": "How to extract keys from multiple, nested arrays using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 19,
        "last_activity_date": 1649294833,
        "creation_date": 1433261611,
        "question_id": 30601278,
        "body_markdown": "**SETUP**\r\n\r\nI&#39;m trying to figure out how jq filters work and having trouble figuring out nested arrays. Using the data below I cannot make a flat 5 key output. I can get 1 key and 4 nulls or 4 keys and 1 null, but not all 5 keys.\r\n\r\n1 key, 4 nulls:\r\n\r\n    .Reservations[] | {OwnerId, InstanceId, ImageId, PrivateIpAddress, Platform}\r\n\r\nReturns:\r\n\r\n    {\r\n     &quot;OwnerId&quot;: &quot;000000000000&quot;,\r\n     &quot;InstanceId&quot;: null,\r\n     &quot;ImageId&quot;: null,\r\n     &quot;PrivateIpAddress&quot;: null,\r\n     &quot;Platform&quot;: null\r\n    }\r\n\r\n4 keys, 1 null:\r\n\r\n    .Reservations[].Instances[] | {OwnerId, InstanceId, ImageId, PrivateIpAddress, Platform}\r\n\r\n    {\r\n      &quot;OwnerId&quot;: null,\r\n      &quot;InstanceId&quot;: &quot;i-v33333333&quot;,\r\n      &quot;ImageId&quot;: &quot;ami-44444444&quot;,\r\n      &quot;PrivateIpAddress&quot;: &quot;10.0.0.0&quot;,\r\n      &quot;Platform&quot;: &quot;windows&quot;\r\n    }\r\n\r\nFor a various reasons I cannot use the &quot;--query&quot; option in AWS CLI which does return the format I&#39;m looking for:\r\n\r\n\r\n    aws ec2 describe-instances --region us-east-1 --profile temp --query &#39;Reservations[*].{InstanceId:Instances[0].InstanceId,IP:Instances[0].PrivateIpAddress,Platform:Instances[0].Platform,OwnerId:OwnerId}&#39;\r\n\r\nOutput:\r\n\r\n    [\r\n        {\r\n            &quot;InstanceId&quot;: &quot;i-11111111&quot;,\r\n            &quot;IP&quot;: &quot;10.9.9.3&quot;,\r\n            &quot;OwnerId&quot;: &quot;111111111111&quot;,\r\n            &quot;Platform&quot;: windows\r\n        },\r\n        {\r\n            &quot;InstanceId&quot;: &quot;i-22222222&quot;,\r\n            &quot;IP&quot;: &quot;10.0.0.0&quot;,\r\n            &quot;OwnerId&quot;: &quot;111111111111&quot;,\r\n            &quot;Platform&quot;: windows\r\n        }\r\n    ]\r\n\r\n\r\n\r\n\r\nHere is the JSON input:\r\n\r\n       {\r\n        &quot;Reservations&quot;: [\r\n            {\r\n                &quot;OwnerId&quot;: &quot;000000000000&quot;,\r\n                &quot;ReservationId&quot;: &quot;r-22222222&quot;,\r\n                &quot;Groups&quot;: [],\r\n                &quot;RequesterId&quot;: &quot;111111111111&quot;,\r\n                &quot;Instances&quot;: [\r\n                    {\r\n                        &quot;Monitoring&quot;: {\r\n                            &quot;State&quot;: &quot;enabled&quot;\r\n                        },\r\n                        &quot;PublicDnsName&quot;: null,\r\n                        &quot;State&quot;: {\r\n                            &quot;Code&quot;: 16,\r\n                            &quot;Name&quot;: &quot;running&quot;\r\n                        },\r\n                        &quot;EbsOptimized&quot;: false,\r\n                        &quot;LaunchTime&quot;: &quot;2015-04-10T00:02:02.000Z&quot;,\r\n                        &quot;Platform&quot;: &quot;windows&quot;,\r\n                        &quot;PrivateIpAddress&quot;: &quot;10.0.0.0&quot;,\r\n                        &quot;ProductCodes&quot;: [\r\n                            {\r\n                                &quot;ProductCodeId&quot;: &quot;0000000000000000000000000&quot;,\r\n                                &quot;ProductCodeType&quot;: &quot;marketplace&quot;\r\n                            }\r\n                        ],\r\n                        &quot;VpcId&quot;: &quot;vpc-2222222&quot;,\r\n                        &quot;StateTransitionReason&quot;: null,\r\n                        &quot;InstanceId&quot;: &quot;i-v33333333&quot;,\r\n                        &quot;ImageId&quot;: &quot;ami-44444444&quot;,\r\n                        &quot;PrivateDnsName&quot;: &quot;ip-10-0-0-0.aws.foobarcloud.com&quot;,\r\n                        &quot;KeyName&quot;: &quot;bar-servicemesh&quot;,\r\n                        &quot;SecurityGroups&quot;: [\r\n                            {\r\n                                &quot;GroupName&quot;: &quot;bar-wildcard-dns-intranet-InstanceSecurityGroup-VN0DFQ13QCDY&quot;,\r\n                                &quot;GroupId&quot;: &quot;sg-55555555&quot;\r\n                            }\r\n                        ],\r\n                        &quot;ClientToken&quot;: &quot;11111111-2222-3333-4444-555555555555_subnet-66666666_1&quot;,\r\n                        &quot;SubnetId&quot;: &quot;subnet-66666666&quot;,\r\n                        &quot;InstanceType&quot;: &quot;t2.medium&quot;,\r\n                        &quot;NetworkInterfaces&quot;: [\r\n                            {\r\n                                &quot;Status&quot;: &quot;in-use&quot;,\r\n                                &quot;MacAddress&quot;: &quot;00:00:00:00:00:77&quot;,\r\n                                &quot;SourceDestCheck&quot;: true,\r\n                                &quot;VpcId&quot;: &quot;vpc-66666666&quot;,\r\n                                &quot;Description&quot;: null,\r\n                                &quot;NetworkInterfaceId&quot;: &quot;eni-11111111&quot;\r\n                            }\r\n                        ]\r\n                    }\r\n                ]\r\n            }\r\n        ]\r\n    }\r\n    \r\n**QUESTION**\r\nUsing the JSON input above, how do you use jq to produce the following output?:\r\n\r\n    {\r\n      &quot;OwnerId&quot;: &quot;000000000000&quot;,\r\n      &quot;InstanceId&quot;: &quot;i-v33333333&quot;,\r\n      &quot;ImageId&quot;: &quot;ami-44444444&quot;,\r\n      &quot;PrivateIpAddress&quot;: &quot;10.0.0.0&quot;,\r\n      &quot;Platform&quot;: &quot;windows&quot;\r\n    }\r\n",
        "link": "https://stackoverflow.com/questions/30601278/how-to-extract-keys-from-multiple-nested-arrays-using-jq",
        "title": "How to extract keys from multiple, nested arrays using jq"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1433693541,
                "last_edit_date": 1433693541,
                "creation_date": 1433666277,
                "answer_id": 30691605,
                "question_id": 30691088,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "This should work:\r\n\r\n    group_by(.date) | map({\r\n        key: .[0].date,\r\n        value: map({\r\n            key: .trial_status,\r\n            value: .count\r\n        }) | from_entries\r\n    }) | from_entries\r\n\r\nThe key is to use `from_entries` to build up the mappings.  &lt;strike&gt;This is the only way you can set up &quot;properties&quot;/keys by name.&lt;/strike&gt;  You just need to generate the key/value pairs that will make up the object.\r\n\r\n&lt;hr&gt;\r\n\r\nSantiago points out that you can dynamically set properties by name with a special syntax.  This would work too.\r\n\r\n    group_by(.date) | map({\r\n        (.[0].date): map({\r\n            (.trial_status): .count\r\n        }) | add\r\n    }) | add",
                "title": "JQ Aggregations and Crosstabs"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1433830072,
                "creation_date": 1433830072,
                "answer_id": 30724164,
                "question_id": 30691088,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "If you find your head spinning because of maps inside maps, or if you prefer a direct approach (which in this case at least also happens to be fast and simple), consider using `reduce` like so:\r\n`\r\n  reduce .[] as $o\r\n    ({}; . + {($o.date): (.[$o.date] + {($o.trial_status): $o.count} )})\r\n`\r\n\r\nThanks to jq&#39;s null semantics, this can be simplified and shortened to:\r\n`\r\n  reduce .[] as $o\r\n    ({}; .[$o.date] += { ($o.trial_status): $o.count } )\r\n`",
                "title": "JQ Aggregations and Crosstabs"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1504622559,
                "creation_date": 1504622559,
                "answer_id": 46057734,
                "question_id": 30691088,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a solution using [reduce](https://stedolan.github.io/jq/manual/#Reduce), [destructuring variable binding](https://stedolan.github.io/jq/manual/#Variable/SymbolicBindingOperator:...as$identifier|...) and [setpath](https://stedolan.github.io/jq/manual/#setpath\\(PATHS;VALUE\\))\r\n\r\n    reduce .[] as {count:$c, trial_status:$s, date:$d} (\r\n      {}\r\n    ; setpath([$d, $s]; $c)\r\n    )\r\n    \r\nIf this filter is in `filter.jq` and `data.json` contains the sample data then the command\r\n\r\n    $ jq -M -f filter.jq data.json\r\n\r\nproduces\r\n\r\n    {\r\n      &quot;2015-06-06&quot;: {\r\n        &quot;Follow up&quot;: 4,\r\n        &quot;Hold&quot;: 3,\r\n        &quot;Trial&quot;: 2,\r\n        &quot;Trial + Confirm&quot;: 1\r\n      }\r\n    }",
                "title": "JQ Aggregations and Crosstabs"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 2,
        "last_activity_date": 1504622559,
        "creation_date": 1433661634,
        "question_id": 30691088,
        "body_markdown": "I have some data thus:\r\n\r\n    [\r\n      {\r\n        &quot;count&quot;: 4,\r\n        &quot;trial_status&quot;: &quot;Follow up&quot;,\r\n        &quot;date&quot;: &quot;2015-06-06&quot;\r\n      },\r\n      {\r\n        &quot;count&quot;: 3,\r\n        &quot;trial_status&quot;: &quot;Hold&quot;,\r\n        &quot;date&quot;: &quot;2015-06-06&quot;\r\n      },\r\n      {\r\n        &quot;count&quot;: 2,\r\n        &quot;trial_status&quot;: &quot;Trial&quot;,\r\n        &quot;date&quot;: &quot;2015-06-06&quot;\r\n      },\r\n      {\r\n        &quot;count&quot;: 1,\r\n        &quot;trial_status&quot;: &quot;Trial + Confirm&quot;,\r\n        &quot;date&quot;: &quot;2015-06-06&quot;\r\n      }....\r\n\r\nwhich I would like to transform to\r\n\r\n    {&quot;2015-06-06&quot;: {&quot;Trial + Confirm&quot;: 1, &quot;Follow Up&quot;: 4, &quot;Hold&quot;: 3, &quot;Trial&quot;: 2}}\r\n\r\nI am not making much headway with any of my approaches so would really appreciate some help.        ",
        "link": "https://stackoverflow.com/questions/30691088/jq-aggregations-and-crosstabs",
        "title": "JQ Aggregations and Crosstabs"
    },
    {
        "tags": [
            "json",
            "filter",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 12,
                "is_accepted": true,
                "score": 12,
                "last_activity_date": 1433980575,
                "creation_date": 1433980575,
                "answer_id": 30769322,
                "question_id": 30768196,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Always proceed with caution when using filters that uses multiple `[]` in a single expression.  You may get unexpected results if you aren&#39;t careful.\r\n\r\nI would approach this as converting to CSV (but using a different delimiter, a tab).\r\n\r\nFirst convert the data to what will be your rows.\r\n\r\n    .Collections[] | { InstanceIdentifier, Version } + (.OptionGroups[] | { OptionGroupName })\r\n\r\nWith these new objects, you can build up arrays of the row values and write out the row.  Instead of passing the arrays to the `@csv` filter, just join them with tabs.\r\n\r\n    [ .OptionGroupName, .InstanceIdentifier, .Version ] | join(&quot;\\t&quot;)\r\n",
                "title": "Multiple filters using JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 7,
        "last_activity_date": 1433980575,
        "creation_date": 1433974280,
        "question_id": 30768196,
        "body_markdown": "My boss wants our team to use JQ to parse JSON files.  An app I use produces JSON that I need to transform.  I have a file that looks like this:\r\n\r\n    {\r\n        &quot;Collections&quot;: [\r\n            {\r\n                &quot;OptionGroups&quot;: [\r\n                    {\r\n                        &quot;OptionGroupName&quot;: &quot;Test1&quot;,\r\n                        &quot;Status&quot;: &quot;in-sync&quot;\r\n                    }\r\n                ],\r\n                &quot;Version&quot;: &quot;3.4.25&quot;,\r\n                &quot;InstanceIdentifier&quot;: &quot;Dev1&quot;\r\n            },\r\n            {\r\n                &quot;OptionGroups&quot;: [\r\n                    {\r\n                        &quot;OptionGroupName&quot;: &quot;Test2&quot;,\r\n                        &quot;Status&quot;: &quot;in-sync&quot;\r\n                    }\r\n                ],\r\n                &quot;Version&quot;: &quot;3.4.22&quot;,\r\n                &quot;InstanceIdentifier&quot;: &quot;Dev2&quot;\r\n            }\r\n        ]\r\n    }\r\n\r\nUsing JQ, when I execute this:\r\n\r\n    cat json.txt | jq -r &#39;.Collections[].OptionGroups[].OptionGroupName, .Collections[].InstanceIdentifier, .Collections[].Version&#39;\r\n\r\nI get this output:\r\n\r\n    Test1\r\n    Test2\r\n    Dev1\r\n    Dev2\r\n    3.4.25\r\n    3.4.22\r\n\r\nHow do I get output that looks something like this:\r\n\r\n    Test1    Dev1    3.4.25\r\n    Test2    Dev2    3.4.22\r\n",
        "link": "https://stackoverflow.com/questions/30768196/multiple-filters-using-jq",
        "title": "Multiple filters using JQ"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2200186,
                    "reputation": 7684,
                    "user_id": 1944784,
                    "user_type": "registered",
                    "accept_rate": 83,
                    "profile_image": "https://www.gravatar.com/avatar/2a80265a0b2b4a91cf07bf8b9cd50c0e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "4ae1e1",
                    "link": "https://stackoverflow.com/users/1944784/4ae1e1"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1433989202,
                "post_id": 30769667,
                "comment_id": 49592620,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1433989668,
                "last_edit_date": 1433989668,
                "creation_date": 1433989349,
                "answer_id": 30770499,
                "question_id": 30769667,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "When trying to use extra parameters in your filters, use the `--arg` option to pass them in.  Don&#39;t rely on the shell to insert it into your filter string, keep that separate.\r\n\r\n    jq --arg key &quot;$enkey&quot; &#39;.[] |\r\n      .environmentStatuses[].deploymentResult |\r\n      select(.key.entityKey.key == $key) |\r\n      .lifeCycleState&#39; ~/Desktop/results.json",
                "title": "filtering data using parameters"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1458896568,
                "creation_date": 1458896568,
                "answer_id": 36216969,
                "question_id": 30769667,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "This worked for me :\r\n\r\n      jq &#39;.[] | .environmentStatuses[].deploymentResult |\r\n      select(.key.entityKey.key == &quot;&#39;$key&#39;&quot;) |\r\n      .lifeCycleState&#39; ~/Desktop/results.json \r\n\r\n`--arg` does not works as expected ... ",
                "title": "filtering data using parameters"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1458896568,
        "creation_date": 1433983003,
        "last_edit_date": 1433989030,
        "question_id": 30769667,
        "body_markdown": "I have this command that is working..\r\n\r\n    cat  ~/Desktop/results.json |  jq &#39;.[] | .environmentStatuses[].deploymentResult | select(.key.entityKey.key==&quot;39583746-39747586&quot;) | .lifeCycleState &#39;\r\n\r\nI want to pass the entity key as variable , tried the below ones ,but none seems to work-\r\n\r\n    enkey=&quot;39583746-39747586&quot;\r\n    \r\n    cat  ~/Desktop/results.json |  jq &#39;.[] | .environmentStatuses[].deploymentResult | select(.key.entityKey.key==&quot;&quot;&quot;${enkey}&quot;&quot;&quot;) | .lifeCycleState &#39;\r\n    \r\n    cat  ~/Desktop/results.json |  jq &#39;.[] | .environmentStatuses[].deploymentResult | select(.key.entityKey.key==&quot;${enkey}&quot;) | .lifeCycleState &#39;\r\n\r\n",
        "link": "https://stackoverflow.com/questions/30769667/filtering-data-using-parameters",
        "title": "filtering data using parameters"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1434737149,
                "creation_date": 1434737149,
                "answer_id": 30944613,
                "question_id": 30932872,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "With a help of a function, you can do this recursively.\r\n\r\n    def update_dependencies:\r\n        { dep: &quot;\\(.organization):\\(.name):\\(.version)&quot; }\r\n        +\r\n        with_entries(select(.key == &quot;dependencies&quot;) | .value |= map(update_dependencies))\r\n        ;\r\n    .projects |= map(\r\n        .configurations |= map(\r\n            .dependencies |= map(update_dependencies)\r\n        )\r\n    )",
                "title": "How to use `jq` to convert a json by combine some of the values?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1434737149,
        "creation_date": 1434700439,
        "question_id": 30932872,
        "body_markdown": "Say I have a JSON:\r\n\r\n    {\r\n        &quot;name&quot;:&quot;my-project&quot;,\r\n        &quot;projects&quot; : [\r\n        {\r\n            &quot;project&quot;: &quot;core&quot;,\r\n            &quot;configurations&quot;: [\r\n            {\r\n                &quot;configuration&quot;: &quot;compile&quot;,\r\n                &quot;dependencies&quot; : [\r\n                    {\r\n                        &quot;organization&quot;: &quot;a11&quot;,\r\n                        &quot;name&quot; : &quot;b11&quot;,\r\n                        &quot;version&quot; : &quot;1.1&quot;\r\n                    },\r\n                    {\r\n                        &quot;organization&quot;: &quot;a22&quot;,\r\n                        &quot;name&quot; : &quot;b22&quot;,\r\n                        &quot;version&quot; : &quot;2.2&quot;,\r\n                        &quot;dependencies&quot; : [\r\n                             {\r\n                                &quot;organization&quot;: &quot;a33&quot;,\r\n                                &quot;name&quot; : &quot;b33&quot;,\r\n                                &quot;version&quot; : &quot;3.3&quot;\r\n                            }\r\n                        ]\r\n                    }\r\n                ]\r\n            }\r\n            ]\r\n        }\r\n        ]\r\n    }\r\n\r\nHow can I use `jq` to convert the JSON to:\r\n\r\n    {\r\n        &quot;name&quot;:&quot;my-project&quot;,\r\n        &quot;projects&quot; : [\r\n        {\r\n            &quot;project&quot;: &quot;core&quot;,\r\n            &quot;configurations&quot;: [\r\n            {\r\n                &quot;configuration&quot;: &quot;compile&quot;,\r\n                &quot;dependencies&quot; : [\r\n                    {\r\n                        &quot;dep&quot; : &quot;a11:b11:1.1&quot;\r\n                    },\r\n                    {\r\n                        &quot;dep&quot;: &quot;a22:b22:2.2&quot;,\r\n                        &quot;dependencies&quot; : [\r\n                             {\r\n                                &quot;dep&quot;: &quot;a33:b33:3.3&quot;\r\n                            }\r\n                        ]\r\n                    }\r\n                ]\r\n            }\r\n            ]\r\n        }\r\n        ]\r\n    }",
        "link": "https://stackoverflow.com/questions/30932872/how-to-use-jq-to-convert-a-json-by-combine-some-of-the-values",
        "title": "How to use `jq` to convert a json by combine some of the values?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 166270,
                    "reputation": 135171,
                    "user_id": 390278,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/84715fec547362389d02f5be0ed12814?s=256&d=identicon&r=PG",
                    "display_name": "Jeff Mercado",
                    "link": "https://stackoverflow.com/users/390278/jeff-mercado"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1434989322,
                "post_id": 30982175,
                "comment_id": 49999580,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 6508276,
                    "reputation": 61,
                    "user_id": 5036471,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/323e7c2eedaef2222cd0e83a57e2a933?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Saikat Saha",
                    "link": "https://stackoverflow.com/users/5036471/saikat-saha"
                },
                "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": 1434992126,
                "post_id": 30982175,
                "comment_id": 50001281,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 166270,
                    "reputation": 135171,
                    "user_id": 390278,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/84715fec547362389d02f5be0ed12814?s=256&d=identicon&r=PG",
                    "display_name": "Jeff Mercado",
                    "link": "https://stackoverflow.com/users/390278/jeff-mercado"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1434992836,
                "post_id": 30982175,
                "comment_id": 50001712,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 166270,
                    "reputation": 135171,
                    "user_id": 390278,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/84715fec547362389d02f5be0ed12814?s=256&d=identicon&r=PG",
                    "display_name": "Jeff Mercado",
                    "link": "https://stackoverflow.com/users/390278/jeff-mercado"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1434993529,
                "post_id": 30982175,
                "comment_id": 50002054,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 6508276,
                    "reputation": 61,
                    "user_id": 5036471,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/323e7c2eedaef2222cd0e83a57e2a933?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Saikat Saha",
                    "link": "https://stackoverflow.com/users/5036471/saikat-saha"
                },
                "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": 1434994052,
                "post_id": 30982175,
                "comment_id": 50002341,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 166270,
                    "reputation": 135171,
                    "user_id": 390278,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/84715fec547362389d02f5be0ed12814?s=256&d=identicon&r=PG",
                    "display_name": "Jeff Mercado",
                    "link": "https://stackoverflow.com/users/390278/jeff-mercado"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1434994525,
                "post_id": 30982175,
                "comment_id": 50002606,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1436913945,
                "creation_date": 1436913945,
                "answer_id": 31418687,
                "question_id": 30982175,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "For a file of this size, you need to stream the file in and process one item at a time.  First seek to &#39;&quot;results&quot;: [&#39; then use a function called something like &#39;readItem&#39; that uses a stack to match braces, until your opening brace closes, appending each character to your buffer, then deserializes the item once the closing brace is found.\r\n\r\nI recommend node.js + lodash for implementation language.",
                "title": "Load a large JSON file using multi threading/"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1503597863,
                "last_edit_date": 1503597863,
                "creation_date": 1503540483,
                "answer_id": 45851860,
                "question_id": 30982175,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a streaming approach which assumes your 3GB data file is in `data.json` and the following filter is in `filter1.jq`:\r\n\r\n      select(length==2)\r\n    | . as [$p, $v]\r\n    | {r:$p[1]}\r\n    | if   $p[2:6] == [&quot;body&quot;,&quot;party&quot;,&quot;general-info&quot;,&quot;full-name&quot;]       then .name = $v\r\n      elif $p[2:6] == [&quot;body&quot;,&quot;party&quot;,&quot;xrefs&quot;,&quot;xref&quot;] and $p[7] == &quot;id&quot; then .id   = $v\r\n      else  empty\r\n      end      \r\n\r\nWhen you run jq with\r\n\r\n    $ jq -M -c --stream -f filter1.jq data.json\r\n\r\njq will produce a stream of results with minimal details you need \r\n\r\n    {&quot;r&quot;:0,&quot;name&quot;:&quot;Ibercaja Gestion SGIIC SAPensiones Nuevas Oportunidades&quot;}\r\n    {&quot;r&quot;:0,&quot;id&quot;:&quot;X00893X&quot;}\r\n    {&quot;r&quot;:0,&quot;id&quot;:&quot;1012227139&quot;}\r\n    {&quot;r&quot;:1,&quot;name&quot;:&quot;Innova Capital Sp zoo&quot;}\r\n    {&quot;r&quot;:1,&quot;id&quot;:&quot;144349875&quot;}\r\n    {&quot;r&quot;:1,&quot;id&quot;:&quot;6098743&quot;}\r\n    {&quot;r&quot;:1,&quot;id&quot;:&quot;1001210218&quot;}\r\n    {&quot;r&quot;:1,&quot;id&quot;:&quot;1001210218&quot;}\r\n    {&quot;r&quot;:1,&quot;id&quot;:&quot;10009050&quot;}\r\n    {&quot;r&quot;:1,&quot;id&quot;:&quot;0000068508&quot;}\r\n    {&quot;r&quot;:1,&quot;id&quot;:&quot;13159&quot;}\r\n    \r\nwhich you can convert to your desired format by using a second `filter2.jq`:\r\n\r\n    foreach .[] as $i (\r\n         {c: null, r:null, id:null, name:null}\r\n\r\n       ; .c = $i\r\n       | if .r != .c.r then .id=null | .name=null | .r=.c.r else . end   # control break\r\n       | .id   = if .c.id == null   then .id   else .c.id   end\r\n       | .name = if .c.name == null then .name else .c.name end\r\n\r\n       ; [.id, .name]\r\n       | if contains([null]) then empty else . end\r\n       | join(&quot;~&quot;)\r\n    )\r\n \r\nwhich consumes the output of the first filter when run with \r\n \r\n    $ jq -M -c --stream -f filter1.jq data.json | jq -M -s -r -f filter2.jq\r\n\r\nand produces\r\n\r\n    X00893X~Ibercaja Gestion SGIIC SAPensiones Nuevas Oportunidades\r\n    1012227139~Ibercaja Gestion SGIIC SAPensiones Nuevas Oportunidades\r\n    144349875~Innova Capital Sp zoo\r\n    6098743~Innova Capital Sp zoo\r\n    1001210218~Innova Capital Sp zoo\r\n    1001210218~Innova Capital Sp zoo\r\n    10009050~Innova Capital Sp zoo\r\n    0000068508~Innova Capital Sp zoo\r\n    13159~Innova Capital Sp zoo\r\n\r\nThis might be all you need using just two **jq** processes.  If you need more parallelism you could use the record number (r) as to partition the data and process the partitions in parallel.  For example, if you save the intermediate output into a `temp.json` file\r\n\r\n    $ jq -M -c --stream -f filter1.jq data.json &gt; temp.json\r\n\r\nthen you could process `temp.json` in parallel with filters such as\r\n\r\n    $ jq -M &#39;select(0==.r%3)&#39; temp.json | jq -M -s -r -f filter2.jq &gt; result0.out &amp;\r\n    $ jq -M &#39;select(1==.r%3)&#39; temp.json | jq -M -s -r -f filter2.jq &gt; result1.out &amp;\r\n    $ jq -M &#39;select(2==.r%3)&#39; temp.json | jq -M -s -r -f filter2.jq &gt; result2.out &amp;\r\n    \r\nand concatenate your partitions into a single result at the end if necessary.  This example uses 3 partitions but you could easily extend this approach to any number of partitions if you need more parallelism.\r\n\r\n[GNU parallel](https://www.gnu.org/software/parallel) is also a good option. As mentioned in the [JQ Cookbook](https://github.com/stedolan/jq/wiki/Cookbook), [jq-hopkok&#39;s parallelism folder](https://github.com/joelpurra/jq-hopkok/tree/master/src/parallelism) has some good examples",
                "title": "Load a large JSON file using multi threading/"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 6,
        "last_activity_date": 1504649560,
        "creation_date": 1434982400,
        "last_edit_date": 1504649560,
        "question_id": 30982175,
        "body_markdown": "I am trying to load a large 3 GB JSON file. Currently, with JQ utility I can load the entire file in nearly 40 mins. Now, I want to know how I can use parallelism/multi threading approach in JQ in order to complete the process in less amount of time. I am using v1.5\r\n\r\n**Command Used:**\r\n\r\n    JQ.exe -r -s &quot;map(.\\&quot;results\\&quot; | map({\\&quot;ID\\&quot;: (((.\\&quot;body\\&quot;?.\\&quot;party\\&quot;?.\\&quot;xrefs\\&quot;?.\\&quot;xref\\&quot;//[] | map(select(ID))[]?.\\&quot;id\\&quot;?))//null), \\&quot;Name\\&quot;: (((.\\&quot;body\\&quot;?.\\&quot;party\\&quot;?.\\&quot;general-info\\&quot;?.\\&quot;full-name\\&quot;?))//null)} | [(.\\&quot;ID\\&quot;//\\&quot;\\&quot;|tostring), (.\\&quot;Name\\&quot;//\\&quot;\\&quot;|tostring)])) | add[] | join(\\&quot;~\\&quot;)&quot; &quot;\\C:\\InputFile.txt&quot; &gt;&quot;\\C:\\OutputFile.txt&quot;\r\n\r\nMy data:\r\n\r\n    {\r\n      &quot;results&quot;: [\r\n        {\r\n          &quot;_id&quot;: &quot;0000001&quot;,\r\n          &quot;body&quot;: {\r\n            &quot;party&quot;: {\r\n              &quot;related-parties&quot;: {},\r\n              &quot;general-info&quot;: {\r\n                &quot;last-update-ts&quot;: &quot;2011-02-14T08:21:51.000-05:00&quot;,\r\n                &quot;full-name&quot;: &quot;Ibercaja Gestion SGIIC SAPensiones Nuevas Oportunidades&quot;,\r\n                &quot;status&quot;: &quot;ACTIVE&quot;,\r\n                &quot;last-update-user&quot;: &quot;TS42922&quot;,\r\n                &quot;create-date&quot;: &quot;2011-02-14T08:21:51.000-05:00&quot;,\r\n                &quot;classifications&quot;: {\r\n                  &quot;classification&quot;: [\r\n                    {\r\n                      &quot;code&quot;: &quot;PENS&quot;\r\n                    }\r\n                  ]\r\n                }\r\n              },\r\n              &quot;xrefs&quot;: {\r\n                &quot;xref&quot;: [\r\n                  {\r\n                    &quot;type&quot;: &quot;LOCCU1&quot;,\r\n                    &quot;id&quot;: &quot;X00893X&quot;\r\n                  },\r\n                  {\r\n                    &quot;type&quot;: &quot;ID&quot;,\r\n                    &quot;id&quot;: &quot;1012227139&quot;\r\n                  }\r\n                ]\r\n              }\r\n            }\r\n          }\r\n        },\r\n        {\r\n          &quot;_id&quot;: &quot;000002&quot;,\r\n          &quot;body&quot;: {\r\n            &quot;party&quot;: {\r\n              &quot;related-parties&quot;: {},\r\n              &quot;general-info&quot;: {\r\n                &quot;last-update-ts&quot;: &quot;2015-05-21T15:10:45.174-04:00&quot;,\r\n                &quot;full-name&quot;: &quot;Innova Capital Sp zoo&quot;,\r\n                &quot;status&quot;: &quot;ACTIVE&quot;,\r\n                &quot;last-update-user&quot;: &quot;jw74592&quot;,\r\n                &quot;create-date&quot;: &quot;1994-08-31T00:00:00.000-04:00&quot;,\r\n                &quot;classifications&quot;: {\r\n                  &quot;classification&quot;: [\r\n                    {\r\n                      &quot;code&quot;: &quot;CORP&quot;\r\n                    }\r\n                  ]\r\n                }\r\n              },\r\n              &quot;xrefs&quot;: {\r\n                &quot;xref&quot;: [\r\n                  {\r\n                    &quot;type&quot;: &quot;ULTDUN&quot;,\r\n                    &quot;id&quot;: &quot;144349875&quot;\r\n                  },\r\n                  {\r\n                    &quot;type&quot;: &quot;AVID&quot;,\r\n                    &quot;id&quot;: &quot;6098743&quot;\r\n                  },\r\n                  {\r\n                    &quot;type&quot;: &quot;LOCCU1&quot;,\r\n                    &quot;id&quot;: &quot;1001210218&quot;\r\n                  },\r\n                  {\r\n                    &quot;type&quot;: &quot;ID&quot;,\r\n                    &quot;id&quot;: &quot;1001210218&quot;\r\n                  },\r\n                  {\r\n                    &quot;type&quot;: &quot;BLMBRG&quot;,\r\n                    &quot;id&quot;: &quot;10009050&quot;\r\n                  },\r\n                  {\r\n                    &quot;type&quot;: &quot;REG_CO&quot;,\r\n                    &quot;id&quot;: &quot;0000068508&quot;\r\n                  },\r\n                  {\r\n                    &quot;type&quot;: &quot;SMCI&quot;,\r\n                    &quot;id&quot;: &quot;13159&quot;\r\n                  }\r\n                ]\r\n              }\r\n            }\r\n          }\r\n        }\r\n      ]\r\n    }\r\n\r\n \r\n\r\nCan someone please help me which command I need to use in v1.5 in order to achieve parallelism/multithreading.\r\n\r\n",
        "link": "https://stackoverflow.com/questions/30982175/load-a-large-json-file-using-multi-threading",
        "title": "Load a large JSON file using multi threading/"
    },
    {
        "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": 1435017380,
                "post_id": 30991616,
                "comment_id": 50013073,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 1463192,
                    "reputation": 13037,
                    "user_id": 1376896,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/b783e2a88b07336a730d7b440ad6a96c?s=256&d=identicon&r=PG",
                    "display_name": "Wenbing Li",
                    "link": "https://stackoverflow.com/users/1376896/wenbing-li"
                },
                "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": 1435017587,
                "post_id": 30991616,
                "comment_id": 50013131,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 166270,
                    "reputation": 135171,
                    "user_id": 390278,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/84715fec547362389d02f5be0ed12814?s=256&d=identicon&r=PG",
                    "display_name": "Jeff Mercado",
                    "link": "https://stackoverflow.com/users/390278/jeff-mercado"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1435017852,
                "post_id": 30991616,
                "comment_id": 50013189,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 1463192,
                    "reputation": 13037,
                    "user_id": 1376896,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/b783e2a88b07336a730d7b440ad6a96c?s=256&d=identicon&r=PG",
                    "display_name": "Wenbing Li",
                    "link": "https://stackoverflow.com/users/1376896/wenbing-li"
                },
                "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": 1435022588,
                "post_id": 30991616,
                "comment_id": 50014240,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 166270,
                    "reputation": 135171,
                    "user_id": 390278,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/84715fec547362389d02f5be0ed12814?s=256&d=identicon&r=PG",
                    "display_name": "Jeff Mercado",
                    "link": "https://stackoverflow.com/users/390278/jeff-mercado"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1435022922,
                "post_id": 30991616,
                "comment_id": 50014311,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 1463192,
                    "reputation": 13037,
                    "user_id": 1376896,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/b783e2a88b07336a730d7b440ad6a96c?s=256&d=identicon&r=PG",
                    "display_name": "Wenbing Li",
                    "link": "https://stackoverflow.com/users/1376896/wenbing-li"
                },
                "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": 1435023188,
                "post_id": 30991616,
                "comment_id": 50014375,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1435023215,
                "last_edit_date": 1435023215,
                "creation_date": 1435022644,
                "answer_id": 30992394,
                "question_id": 30991616,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is the solution:\r\n\r\n    jq -n --argfile number &lt;(printf &#39;%d&#39; 3000) &#39;{&quot;number&quot;:$number}&#39;\r\n\r\nOr\r\n\r\n    jq -n --arg number 3000 &#39;{&quot;number&quot;:$number|fromjson}&#39;",
                "title": "Replace jq predefined variable with number"
            },
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1435473892,
                "creation_date": 1435473892,
                "answer_id": 31096932,
                "question_id": 30991616,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Or:\r\n\r\n    jq -n --arg number 300 &#39;{&quot;number&quot;: $number|tonumber}&#39;\r\n\r\nor (as Jeff pointed out) with jq 1.5:\r\n\r\n    jq -n --argjson number 300 &#39;{&quot;number&quot;: $number}&#39;\r\n\r\nor (with versions of jq after June 26, 2015):\r\n\r\n    jq -n --arg number 300 &#39;{$number} | .number |= tonumber&#39;",
                "title": "Replace jq predefined variable with number"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1435473892,
        "creation_date": 1435016193,
        "last_edit_date": 1435022439,
        "question_id": 30991616,
        "body_markdown": "`jq` could have predefined variables and replace with `--arg` options. It works well with string. However, I don&#39;t know how to replace the variable as number.\r\n\r\n    $jq -n --arg number 3000 &#39;{&quot;number&quot;:$number}&#39;\r\n    {\r\n      &quot;number&quot;: &quot;3000&quot;\r\n    }\r\n\r\nI would like to be able to generate something as following :\r\n\r\n    {\r\n      &quot;number&quot;: 3000\r\n    }\r\n\r\nThanks in advance.",
        "link": "https://stackoverflow.com/questions/30991616/replace-jq-predefined-variable-with-number",
        "title": "Replace jq predefined variable with number"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 216,
                "is_accepted": true,
                "score": 214,
                "last_activity_date": 1745595411,
                "last_edit_date": 1745595411,
                "creation_date": 1435182241,
                "answer_id": 31037640,
                "question_id": 31034746,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You set values of an object using the `=` operator.  `|=` on the other hand is used to update a value.  Use `|=` if you need to know the current value of the property, it will be passed as the **input** (.) on your right hand side (if set). Using `=` on the other hand does not set the input at all for the RHS, it will simply be `null`.  It&#39;s a subtle but important difference.  The context of the RHS changes.\r\n\r\nSince you are setting a property to a constant value, use the `=` operator.\r\n\r\n    .shipping.local = false\r\n\r\nJust note that when setting a value to a property, it doesn&#39;t necessarily have to exist.  You can add new values easily this way.\r\n\r\n    .shipping.local = false | .shipping.canada = false | .shipping.mexico = true\r\n\r\n\r\n\r\n\r\n\r\n",
                "title": "How do I update a single value in a json document using jq?"
            },
            {
                "up_vote_count": 14,
                "is_accepted": false,
                "score": 13,
                "last_activity_date": 1576065689,
                "creation_date": 1576065689,
                "answer_id": 59285390,
                "question_id": 31034746,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "a similar function to the operator |= is map.\r\nmap will be suitable to avoid the requirement of a previous filter for the array...\r\n\r\nimagine that your data is an array (very common for this example)\r\n\r\n    [\r\n      {\r\n        &quot;shipping&quot;: {\r\n          &quot;local&quot;: true,\r\n          &quot;us&quot;: true,\r\n          &quot;us_rate&quot;: {\r\n            &quot;amount&quot;: &quot;1.00&quot;,\r\n            &quot;currency&quot;: &quot;USD&quot;,\r\n            &quot;symbol&quot;: &quot;$&quot;\r\n          }\r\n        }\r\n      },\r\n      {\r\n        &quot;shipping&quot;: {\r\n          &quot;local&quot;: true,\r\n          &quot;us&quot;: true,\r\n          &quot;us_rate&quot;: {\r\n            &quot;amount&quot;: &quot;1.00&quot;,\r\n            &quot;currency&quot;: &quot;USD&quot;,\r\n            &quot;symbol&quot;: &quot;$&quot;\r\n          }\r\n        }\r\n      }\r\n    ]\r\n\r\nhence it is necessary to consider the array in the code as:\r\n\r\n    http://example.com/shipping.json | jq &#39;.[] | .shipping.local = &quot;new place&quot;&#39; | curl -X PUT http://example.com/shipping.json\r\n\r\nor to use the map function that is crafted to work in every array element as\r\n\r\n    http://example.com/shipping.json | jq &#39;map(.shipping.local = &quot;new place&quot;)&#39; | curl -X PUT http://example.com/shipping.json\r\n\r\n**Observation**\r\n\r\nFor the sake of those that are learning, you also did some mistakes in the jq usage, just consider that it does &quot;read&quot; the 1st parameter as the program, hence all the desired commands shall be included in the very first string after calling the program.",
                "title": "How do I update a single value in a json document using jq?"
            },
            {
                "up_vote_count": 132,
                "is_accepted": false,
                "score": 130,
                "last_activity_date": 1581934563,
                "last_edit_date": 1581934563,
                "creation_date": 1581933777,
                "answer_id": 60259978,
                "question_id": 31034746,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Update a value (sets .foo.bar to &quot;new value&quot;):\r\n\r\n    jq &#39;.foo.bar = &quot;new value&quot;&#39; file.json\r\n\r\nUpdate a value using a variable (sets .foo.bar to &quot;hello&quot;):\r\n\r\n    variable=&quot;hello&quot;; jq --arg variable &quot;$variable&quot; &#39;.foo.bar = $variable&#39; file.json",
                "title": "How do I update a single value in a json document using jq?"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1702576342,
                "last_edit_date": 1702576342,
                "creation_date": 1702408166,
                "answer_id": 77648505,
                "question_id": 31034746,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I defined a `test.json` with `{}` content and my `test.json` is empty when I try to change single field value by running following command:\r\n\r\n```\r\njq &#39;.test = &quot;new-value&quot;&#39; test.json &gt; test.json\r\n```\r\n\r\nAfter this command; `test.json` file content is empty. There is nothing.\r\n\r\nThe trick is that we need to echo to rewrite json file with modified data by running following command:\r\n\r\n```\r\necho $(jq &#39;.test = &quot;new-value&quot;&#39; test.json) &gt; test.json\r\n```\r\n\r\nThis works for me.",
                "title": "How do I update a single value in a json document using jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": 220,
        "last_activity_date": 1745595411,
        "creation_date": 1435172192,
        "question_id": 31034746,
        "body_markdown": "Appologies if I&#39;ve overlooked something very obvious; I&#39;ve just found `jq` and am trying to use it to update one JSON value without affecting the surrounding data.\r\n\r\n\r\nI&#39;d like to pipe a `curl` result into `jq`, update a value, and pipe the updated JSON to a `curl -X PUT`.  Something like \r\n\r\n    curl http://example.com/shipping.json | jq &#39;.&#39; field: value | curl -X PUT http://example.com/shipping.json\r\n\r\nSo far I&#39;ve hacked it together using `sed`, but after looking at a few examples of the `|=` operator in `jq` I&#39;m sure that I don&#39;t need these.\r\n\r\nHere&#39;s a JSON sample--how would I use `jq` to set `&quot;local&quot;: false`, while preserving the rest of the JSON?\r\n\r\n    {\r\n      &quot;shipping&quot;: {\r\n        &quot;local&quot;: true,\r\n        &quot;us&quot;: true,\r\n        &quot;us_rate&quot;: {\r\n          &quot;amount&quot;: &quot;0.00&quot;,\r\n          &quot;currency&quot;: &quot;USD&quot;,\r\n          &quot;symbol&quot;: &quot;$&quot;\r\n        }\r\n      }\r\n    }\r\n\r\n",
        "link": "https://stackoverflow.com/questions/31034746/how-do-i-update-a-single-value-in-a-json-document-using-jq",
        "title": "How do I update a single value in a json document using jq?"
    },
    {
        "tags": [
            "json",
            "group-by",
            "jq",
            "aggregation",
            "counting"
        ],
        "answers": [
            {
                "up_vote_count": 16,
                "is_accepted": true,
                "score": 16,
                "last_activity_date": 1435176961,
                "creation_date": 1435176961,
                "answer_id": 31036137,
                "question_id": 31035704,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You need to to do `group_by` twice, once to group by the machine name, and then a sub-grouping to get the sub-counts for each domain.\r\n\r\njq query:\r\n\r\n    group_by(.machine) | map({\r\n        &quot;machine&quot;: .[0].machine, \r\n        &quot;total&quot;:length, \r\n        &quot;domains&quot;: (group_by(.domain) | map({\r\n            &quot;key&quot;:.[0].domain, \r\n            &quot;value&quot;:length}) | from_entries\r\n        )\r\n    })\r\n\r\nExample output:\r\n\r\n    {\r\n      &quot;machine&quot;: &quot;possible_victim01&quot;,\r\n      &quot;total&quot;: 3,\r\n      &quot;domains&quot;: {\r\n        &quot;evil.com&quot;: 2,\r\n        &quot;soevil.com&quot;: 1\r\n      }\r\n    }\r\n    {\r\n      &quot;machine&quot;: &quot;possible_victim02&quot;,\r\n      &quot;total&quot;: 1,\r\n      &quot;domains&quot;: {\r\n        &quot;bad.com&quot;: 1\r\n      }\r\n    }\r\n    {\r\n      &quot;machine&quot;: &quot;possible_victim03&quot;,\r\n      &quot;total&quot;: 1,\r\n      &quot;domains&quot;: {\r\n        &quot;soevil.com&quot;: 1\r\n      }\r\n    }\r\n",
                "title": "Use jq to count on multiple levels"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1435472123,
                "creation_date": 1435472123,
                "answer_id": 31096727,
                "question_id": 31035704,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Using group_by in the manner described is fine, but if you have a\r\nvery large number of lines (i.e. JSON entities) to read as suggested\r\nby the sample provided, then you may run into performance issues\r\nand/or capacity constraints.\r\n\r\nThese issues can be resolved very effectively in any version of jq with the &quot;inputs&quot; builtin (e.g. jq 1.5rc1).\r\n\r\nPlease note that using &quot;inputs&quot; you would invoke jq with the -n option, like this:\r\n\r\n    jq -n -f program.jq data.json\r\n\r\nPlease note also that it is preferable here to produce JSON output, and the following seems to be close to what is wanted:\r\n\r\n    {&quot;possible_victim01&quot;: { &quot;total&quot;: 3, &quot;evildoers&quot;: {&quot;evil.com&quot;: 2, &quot;soevil.com&quot;: 1} },\r\n     &quot;possible_victim02&quot;: ...}`\r\n\r\nThe following program could be made more concise but the\r\npresentation here is intended to make the process transparent,\r\nassuming a basic understanding of jq.  If there is magic here,\r\nit is that one does not have to make a special case of &quot;null&quot;.\r\n\r\n    reduce inputs as $line\r\n      ({};\r\n       . as $in\r\n       | ($line.machine) as $machine\r\n       | ($line.domain) as $domain\r\n       | ($in[$machine].evildoers ) as $evildoers\r\n       | . + { ($machine): {&quot;total&quot;: (1 + $in[$machine][&quot;total&quot;]),\r\n                            &quot;evildoers&quot;: ($evildoers | (.[$domain] += 1)) }} )\r\n\r\n\r\nUsing the sample input provided, the output is:\r\n\r\n    {\r\n      &quot;possible_victim01&quot;: {\r\n        &quot;total&quot;: 3,\r\n        &quot;evildoers&quot;: {\r\n          &quot;evil.com&quot;: 2,\r\n          &quot;soevil.com&quot;: 1\r\n        }\r\n      },\r\n      &quot;possible_victim02&quot;: {\r\n        &quot;total&quot;: 1,\r\n        &quot;evildoers&quot;: {\r\n          &quot;bad.com&quot;: 1\r\n        }\r\n      },\r\n      &quot;possible_victim03&quot;: {\r\n        &quot;total&quot;: 1,\r\n        &quot;evildoers&quot;: {\r\n          &quot;soevil.com&quot;: 1\r\n        }\r\n      }\r\n    }\r\n    ",
                "title": "Use jq to count on multiple levels"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1504597115,
                "creation_date": 1504597115,
                "answer_id": 46049444,
                "question_id": 31035704,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a solution using [reduce](https://stedolan.github.io/jq/manual/#Reduce), [getpath](https://stedolan.github.io/jq/manual/#getpath\\(PATHS\\)) and [setpath](https://stedolan.github.io/jq/manual/#setpath\\(PATHS;VALUE\\))\r\n\r\n    reduce .[] as $o (\r\n      {}\r\n    ; [$o.machine, &quot;total&quot;] as $p1\r\n    | [$o.machine, &quot;domains&quot;, $o.domain] as $p2\r\n    | setpath($p1; 1+getpath($p1))\r\n    | setpath($p2; 1+getpath($p2))\r\n    )\r\n    \r\nIf `filter.jq` contains this filter and `data.json` contains the sample data then the command\r\n\r\n    $ jq -M -s -f filter.jq data.json\r\n\r\nproduces\r\n\r\n    {\r\n      &quot;possible_victim01&quot;: {\r\n        &quot;total&quot;: 3,\r\n        &quot;domains&quot;: {\r\n          &quot;evil.com&quot;: 2,\r\n          &quot;soevil.com&quot;: 1\r\n        }\r\n      },\r\n      &quot;possible_victim02&quot;: {\r\n        &quot;total&quot;: 1,\r\n        &quot;domains&quot;: {\r\n          &quot;bad.com&quot;: 1\r\n        }\r\n      },\r\n      &quot;possible_victim03&quot;: {\r\n        &quot;total&quot;: 1,\r\n        &quot;domains&quot;: {\r\n          &quot;soevil.com&quot;: 1\r\n        }\r\n      }\r\n    }",
                "title": "Use jq to count on multiple levels"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 12,
        "last_activity_date": 1544966044,
        "creation_date": 1435175380,
        "last_edit_date": 1544966044,
        "question_id": 31035704,
        "body_markdown": "We&#39;ve discovered some domain names tied to infections. Now we have a list of DNS names in a .json file, and I&#39;d like to produce a summarized output showing: a list of users, the unique domains they visited, the total count. Bonus points if I can also get count per domain name.\r\n\r\nHere is a sample of the file:\r\n\r\n    {&quot;machine&quot;: &quot;possible_victim01&quot;, &quot;domain&quot;: &quot;evil.com&quot;, &quot;timestamp&quot;:1435071870}\r\n    {&quot;machine&quot;: &quot;possible_victim01&quot;, &quot;domain&quot;: &quot;evil.com&quot;, &quot;timestamp&quot;:1435071875}\r\n    {&quot;machine&quot;: &quot;possible_victim01&quot;, &quot;domain&quot;: &quot;soevil.com&quot;, &quot;timestamp&quot;:1435071877}\r\n    {&quot;machine&quot;: &quot;possible_victim02&quot;, &quot;domain&quot;: &quot;bad.com&quot;, &quot;timestamp&quot;:1435071877}\r\n    {&quot;machine&quot;: &quot;possible_victim03&quot;, &quot;domain&quot;: &quot;soevil.com&quot;, &quot;timestamp&quot;:1435071879}\r\n\r\nIdeally, I would like the output to be something like:\r\n\r\n    {&quot;possible_victim01&quot;: &quot;total&quot;: 3, {&quot;evil.com&quot;: 2, &quot;soevil.com&quot;: 1}}\r\n    {&quot;possible_victim02&quot;: &quot;total&quot;: 1, {&quot;bad.com&quot;: 1}}\r\n    {&quot;possible_victim03&quot;: &quot;total&quot;: 1, {&quot;soevil.com&quot;: 1}}\r\n\r\nI would gladly settle for:\r\n\r\n    {&quot;possible_victim01&quot;: &quot;total&quot;: 3, [&quot;evil.com&quot;, &quot;soevil.com&quot;]}\r\n    {&quot;possible_victim02&quot;: &quot;total&quot;: 1, [&quot;bad.com&quot;]}\r\n    {&quot;possible_victim03&quot;: &quot;total&quot;: 1, [&quot;soevil.com&quot;]}\r\n\r\nI can get a total count of records per user, but I lose the list of domains:\r\n\r\n    cat sample.json | jq -s &#39;group_by(.machine) | map({machine:.[0].machine,domain:.[0].domain, count:length}) &#39;\r\n    [{&quot;machine&quot;: &quot;possible_victim01&quot;, &quot;domain&quot;: &quot;evil.com&quot;, &quot;count&quot;: 3},  \r\n    {&quot;machine&quot;: &quot;possible_victim02&quot;, &quot;domain&quot;: &quot;bad.com&quot;, &quot;count&quot;: 1},\r\n    {&quot;machine&quot;: &quot;possible_victim03&quot;, &quot;domain&quot;: &quot;soevil.com&quot;, &quot;count&quot;: 1}]\r\n\r\nThis post describes how to solve the second half of the problem... https://stackoverflow.com/questions/30691088/jq-aggregations-and-crosstabs. I haven&#39;t found anything yet that describes the first half, getting to:\r\n\r\n    {&quot;machine&quot;: &quot;possible_victim01&quot;, &quot;domain&quot;: &quot;evil.com&quot;, &quot;count&quot;:2}\r\n    {&quot;machine&quot;: &quot;possible_victim01&quot;, &quot;domain&quot;: &quot;soevil.com&quot;, &quot;count&quot;:1}\r\n    {&quot;machine&quot;: &quot;possible_victim02&quot;, &quot;domain&quot;: &quot;bad.com&quot;, &quot;count&quot;:1}\r\n    {&quot;machine&quot;: &quot;possible_victim03&quot;, &quot;domain&quot;: &quot;soevil.com&quot;, &quot;count&quot;:1}\r\n\r\n",
        "link": "https://stackoverflow.com/questions/31035704/use-jq-to-count-on-multiple-levels",
        "title": "Use jq to count on multiple levels"
    },
    {
        "tags": [
            "json",
            "bash",
            "shell",
            "amazon-web-services",
            "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": 1435519153,
                "post_id": 31103748,
                "comment_id": 50222666,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 1518869,
                    "reputation": 439,
                    "user_id": 1419158,
                    "user_type": "registered",
                    "accept_rate": 70,
                    "profile_image": "https://www.gravatar.com/avatar/0b5874bda442acfbf9a7ea26a5cf1cae?s=256&d=identicon&r=PG",
                    "display_name": "cfircoo",
                    "link": "https://stackoverflow.com/users/1419158/cfircoo"
                },
                "reply_to_user": {
                    "account_id": 4663062,
                    "reputation": 89888,
                    "user_id": 3776858,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Cagbk.jpg?s=256",
                    "display_name": "Cyrus",
                    "link": "https://stackoverflow.com/users/3776858/cyrus"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1435519911,
                "post_id": 31103748,
                "comment_id": 50222935,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 308303,
                    "reputation": 37458,
                    "user_id": 620097,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/820980fd43f2607a815c1f3dbfe152cc?s=256&d=identicon&r=PG",
                    "display_name": "shellter",
                    "link": "https://stackoverflow.com/users/620097/shellter"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1435523213,
                "post_id": 31103748,
                "comment_id": 50223950,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 4663062,
                    "reputation": 89888,
                    "user_id": 3776858,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Cagbk.jpg?s=256",
                    "display_name": "Cyrus",
                    "link": "https://stackoverflow.com/users/3776858/cyrus"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1435524152,
                "post_id": 31103748,
                "comment_id": 50224241,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 100740,
                    "reputation": 79490,
                    "user_id": 271415,
                    "user_type": "registered",
                    "accept_rate": 91,
                    "profile_image": "https://www.gravatar.com/avatar/8648256cc53b261c5e1d266380a256fc?s=256&d=identicon&r=PG",
                    "display_name": "jarmod",
                    "link": "https://stackoverflow.com/users/271415/jarmod"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1435536335,
                "post_id": 31103748,
                "comment_id": 50227109,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": false,
                "score": 5,
                "last_activity_date": 1435523342,
                "creation_date": 1435523342,
                "answer_id": 31104427,
                "question_id": 31103748,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You&#39;re using single quotes around your jq program, which is causing the shell variable to not be interpolated. Furthermore, even if it were, you would still need to add string quoting around the variable interpolation to make jq interpret it as a string literal. Since doing shell variable interpolation into jq programs is hard and error-prone, jq provides a command-line argument to this effect, `--arg`, intended to lift shell variables into jq variables. Your jq invocation would therefore look like this:\r\n\r\n`jq --arg ip &quot;$ip&quot; &#39;.Addresses[] | select(.PublicIp == $ip) | .InstanceId&#39;`",
                "title": "bash/shell jq parse to variable from aws json"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": -1,
                "last_activity_date": 1435657860,
                "creation_date": 1435657860,
                "answer_id": 31134968,
                "question_id": 31103748,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Thanks for your help. the right format is:\r\n    \r\n    cat 1.txt | jq &quot;.Addresses | .[] | select(.PublicIp==\\&quot;$ip\\&quot;) | .InstanceId&quot;",
                "title": "bash/shell jq parse to variable from aws json"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": -2,
        "last_activity_date": 1435657860,
        "creation_date": 1435518796,
        "last_edit_date": 1435519038,
        "question_id": 31103748,
        "body_markdown": "I am trying to parse json result from aws result, but I getting error or null when I am using $ip, when I am using specific IP it work. something wrong when I am using tne variable inside the jq command \r\n\r\n    #!/bin/bash\r\n\r\n    aws ec2 describe-addresses --region eu-west-1 &gt; 1.txt\r\n    ipList=( &quot;52.16.121.238&quot; &quot;52.17.250.188&quot; )\r\n\r\n    for ip in &quot;${ipList[@]}&quot;;\r\n    do\r\n        echo $ip\r\n        cat 1.txt | jq &#39;.Addresses | .[] | select (.PublicIp==$ip) |    .InstanceId&#39;\r\n        #echo $result\r\n    done\r\n\r\nPlease advise.",
        "link": "https://stackoverflow.com/questions/31103748/bash-shell-jq-parse-to-variable-from-aws-json",
        "title": "bash/shell jq parse to variable from aws json"
    },
    {
        "tags": [
            "json",
            "bash",
            "shell",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 6,
                "is_accepted": false,
                "score": 6,
                "last_activity_date": 1449690285,
                "last_edit_date": 1449690285,
                "creation_date": 1435702750,
                "answer_id": 31149532,
                "question_id": 31149012,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The idea is to update the person array where the object that has the name `&quot;mike&quot;` will be modified to have the `weight` `&quot;195&quot;`.  Otherwise it&#39;s just skipped.\r\n\r\n    .person |= map(\r\n        if .name == &quot;mike&quot;\r\n            then .weight = &quot;195&quot;\r\n            else .\r\n        end)\r\n\r\nOr more concisely, search for the persons to update and update them:\r\n\r\n    (.person[] | select(.name == &quot;mike&quot;)).weight = &quot;195&quot;",
                "title": "bash JQ. How can modify a key value pair from json file containing list of objects?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1546691992,
        "creation_date": 1435700437,
        "question_id": 31149012,
        "body_markdown": "I am using jq to work on a large json file. It looks something like this:\r\n\r\nFILE1.json\r\n\r\n    {\r\n      &quot;person&quot;: [\r\n          {\r\n              &quot;name&quot;: &quot;sam&quot;,\r\n              &quot;age&quot;: &quot;40&quot;,\r\n              &quot;weight&quot;: &quot;180&quot;,\r\n              &quot;height&quot;: &quot;6&quot;\r\n           },\r\n           {\r\n              &quot;name&quot;: &quot;peter&quot;,\r\n              &quot;age&quot;: &quot;41&quot;,\r\n              &quot;weight&quot;: &quot;180&quot;,\r\n              &quot;height&quot;: &quot;6.1&quot;\r\n           },\r\n           {\r\n              &quot;name&quot;: &quot;mike&quot;,\r\n              &quot;age&quot;: &quot;40&quot;,\r\n              &quot;weight&quot;: &quot;200&quot;,\r\n              &quot;height&quot;: &quot;5.9&quot;\r\n           },\r\n           {\r\n              &quot;name&quot;: &quot;ethan&quot;,\r\n              &quot;age&quot;: &quot;41&quot;,\r\n              &quot;weight&quot;: &quot;190&quot;,\r\n              &quot;height&quot;: &quot;6&quot;\r\n           }\r\n      ]\r\n    }\r\n\r\n\r\nI want to use jq tool to change the value of weight from 200 to 195 where name is &quot;mike&quot;.  \r\nHow can i do this?\r\n",
        "link": "https://stackoverflow.com/questions/31149012/bash-jq-how-can-modify-a-key-value-pair-from-json-file-containing-list-of-objec",
        "title": "bash JQ. How can modify a key value pair from json file containing list of objects?"
    },
    {
        "tags": [
            "json",
            "bash",
            "shell",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1435755292,
                "creation_date": 1435755292,
                "answer_id": 31161926,
                "question_id": 31161831,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "I think you need to escape &quot;+&quot; (plus) with &quot;\\\\+&quot; and see. Like:\r\n\r\n    echo &#39;{&quot;version&quot;:1}&#39;|jq &#39;{&quot;v&quot;:.version\\+1}&#39;",
                "title": "How to increment a number when transforming json"
            },
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1435755669,
                "creation_date": 1435755669,
                "answer_id": 31162086,
                "question_id": 31161831,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Try\r\n\r\n    echo &#39;{&quot;version&quot;:1}&#39; | jq &#39;{&quot;v&quot;:(.version+1)}&#39;\r\n\r\nThis seems to work on the [playground of jq][1].\r\n\r\n\r\n  [1]: https://jqplay.org",
                "title": "How to increment a number when transforming json"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 5,
        "last_activity_date": 1435755669,
        "creation_date": 1435755038,
        "question_id": 31161831,
        "body_markdown": "I am trying to increment a version field. Input is\r\n\r\n    {&quot;version&quot;:1}\r\n\r\nOutput should be\r\n\r\n    {&quot;v&quot;:2}\r\n\r\nWhen I do\r\n\r\n    echo &#39;{&quot;version&quot;:1}&#39;|jq &#39;{&quot;v&quot;:.version+1}&#39;\r\n\r\nI get\r\n\r\n    error: syntax error, unexpected &#39;+&#39;, expecting &#39;}&#39;\r\n\r\nWhile adding in string interpolation works\r\n\r\n    echo &#39;{&quot;version&quot;:1}&#39;|jq &#39;{&quot;v&quot;:&quot;\\(.version+1)&quot;}&#39;\r\n\r\nyields\r\n\r\n    {\r\n      &quot;v&quot;:&quot;2&quot;\r\n    }\r\n\r\nI need v to be of number type, though.",
        "link": "https://stackoverflow.com/questions/31161831/how-to-increment-a-number-when-transforming-json",
        "title": "How to increment a number when transforming json"
    },
    {
        "tags": [
            "sql-server",
            "sql-server-2008",
            "bcp",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1436365048,
                "creation_date": 1436365048,
                "answer_id": 31295408,
                "question_id": 31294151,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Judging by what I can see in [MSDN](https://msdn.microsoft.com/en-us/library/ms162802.aspx), it seems like BCP only accepts files for inputs.\r\n\r\nFor Windows, there is a special file called `con` that could be used to capture stdin (similar to `/dev/stdin`).  Try using that.\r\n\r\n    JQCommand | BCP Database.Schema.Table in con -T -S &quot;Server&quot; -w -t ~ -r \\n",
                "title": "Is it possible to use BCP In with named pipe in SQL Server 2008 R2?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1607974621,
                "creation_date": 1607974621,
                "answer_id": 65295351,
                "question_id": 31294151,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Yes, it is possible - but the pipe must be marked as `InOut`.  Example:\r\n\r\n    var pipeId = $&quot;bcp_{Guid.NewGuid():n}&quot;;\r\n    Thread copyThread;\r\n    using (var np = new NamedPipeServerStream(pipeId))\r\n    {\r\n        copyThread = new Thread(_1 =&gt;\r\n        {\r\n            np.WaitForConnection();\r\n\r\n            using (var dst = File.Create(&quot;out.txt&quot;))\r\n            {\r\n                np.CopyTo(dst, 4096);\r\n            }\r\n        });\r\n        copyThread.Start();\r\n\r\n        var bcp = Process.Start(\r\n            @&quot;bcp.exe&quot;,\r\n            $@&quot;dbo.Table out \\\\.\\pipe\\{pipeId} -S Server -U sa -P password -w -t,&quot;);\r\n        bcp.WaitForExit();\r\n    }\r\n    copyThread.Join();",
                "title": "Is it possible to use BCP In with named pipe in SQL Server 2008 R2?"
            }
        ],
        "is_answered": false,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1607974621,
        "creation_date": 1436362025,
        "question_id": 31294151,
        "body_markdown": "I have a input JSON file which I want to load into SQL Server Table.\r\nCurrently I am following below steps:\r\n\r\n1)\tConvert JSON file to Flat Structure using JQ utility. (http://stedolan.github.io/jq/)\r\n\r\n2)\tStore the output of JQ into Flat File\r\n\r\n3)\tLoad flat file into SQL Table using BCP\r\n\r\n    BCP Database.Schema.Table in &quot;\\\\SharedDirectory\\InputFileName.txt&quot; -T -S &quot;Server&quot; -w -t ~ -r \\n\r\n\r\nIs it possible to skip Step 2) and load output of JQ directly into SQL Server table using BCP?\r\nI am trying to run something like below command:\r\n\r\n    JQCommand | BCP Database.Schema.Table in -T -S &quot;Server&quot; -w -t ~ -r \\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/31294151/is-it-possible-to-use-bcp-in-with-named-pipe-in-sql-server-2008-r2",
        "title": "Is it possible to use BCP In with named pipe in SQL Server 2008 R2?"
    },
    {
        "tags": [
            "json",
            "csv",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6222551,
                    "reputation": 1918,
                    "user_id": 4841794,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/66b8af619dadb7909d3444beda43ce10?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Dipen Shah",
                    "link": "https://stackoverflow.com/users/4841794/dipen-shah"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1436453796,
                "post_id": 31321124,
                "comment_id": 50629244,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 1608936,
                    "reputation": 1,
                    "user_id": 4109044,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/323e623427ec1c1885248682f593c550?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Kapral",
                    "link": "https://stackoverflow.com/users/4109044/kapral"
                },
                "reply_to_user": {
                    "account_id": 6222551,
                    "reputation": 1918,
                    "user_id": 4841794,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/66b8af619dadb7909d3444beda43ce10?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Dipen Shah",
                    "link": "https://stackoverflow.com/users/4841794/dipen-shah"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1436454910,
                "post_id": 31321124,
                "comment_id": 50630064,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1436468356,
                "creation_date": 1436468356,
                "answer_id": 31326025,
                "question_id": 31321124,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Try this:\r\n\r\n    { Time } + (.Data | to_entries[] | { key: .key | tonumber } + .value)\r\n        | [ .Time, .key, .Lat, .Lng, .Qline ]\r\n        | @csv\r\n\r\nMake sure you get the raw output by using the `-r` switch.",
                "title": "json parsing with jq and convert to csv"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1436484206,
                "creation_date": 1436484206,
                "answer_id": 31329994,
                "question_id": 31321124,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here&#39;s another solution that doesn&#39;t involve the +&#39;s.\r\n\r\n    {Time, Data: (.Data | to_entries)[]} \r\n    | [.Time, (.Data.key | tonumber), .Data.value.Lat, .Data.value.Lng, .Data.value.Qline] \r\n    | @csv",
                "title": "json parsing with jq and convert to csv"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1504302344,
                "creation_date": 1504302344,
                "answer_id": 46008324,
                "question_id": 31321124,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is another solution.  If `data.json` contains the sample data then\r\n\r\n    jq -M -r &#39;(.Data|keys[]) as $k | {Time,k:$k}+.Data[$k] | [.[]] | @csv&#39; data.json\r\n\r\nwill produce\r\n\r\n    &quot;14:16:23&quot;,&quot;101043&quot;,49,15,420\r\n    &quot;14:16:23&quot;,&quot;101044&quot;,48,15,421",
                "title": "json parsing with jq and convert to csv"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1504302344,
        "creation_date": 1436453669,
        "last_edit_date": 1436628157,
        "question_id": 31321124,
        "body_markdown": "I need to get some values from a json file with JQ. I need to get a csv (Time, Data.key, Lat, Lng, Qline) \r\n\r\nInput:\r\n\r\n    {\r\n       &quot;Time&quot;:&quot;14:16:23&quot;,\r\n       &quot;Data&quot;:{\r\n          &quot;101043&quot;:{\r\n             &quot;Lat&quot;:49,\r\n             &quot;Lng&quot;:15,\r\n             &quot;Qline&quot;:420\r\n          },\r\n          &quot;101044&quot;:{\r\n             &quot;Lat&quot;:48,\r\n             &quot;Lng&quot;:15,\r\n             &quot;Qline&quot;:421\r\n          }\r\n       }\r\n    }\r\n\r\nExample output of csv:\r\n\r\n    &quot;14:16:23&quot;, 101043, 49, 15, 420\r\n    &quot;14:16:23&quot;, 101044, 48, 15, 421\r\n\r\nThanks a lot.\r\nI tried only to:\r\n&lt;!-- language: lang-bash --&gt;\r\n\r\n    cat test.json | jq &#39;.Data[] |[ .Lat, .Lng, .Qline  ] | @csv&#39; \r\n\r\n",
        "link": "https://stackoverflow.com/questions/31321124/json-parsing-with-jq-and-convert-to-csv",
        "title": "json parsing with jq and convert to csv"
    },
    {
        "tags": [
            "json",
            "regex",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 166270,
                    "reputation": 135171,
                    "user_id": 390278,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/84715fec547362389d02f5be0ed12814?s=256&d=identicon&r=PG",
                    "display_name": "Jeff Mercado",
                    "link": "https://stackoverflow.com/users/390278/jeff-mercado"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1436993851,
                "post_id": 31438087,
                "comment_id": 50851236,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 35,
                "is_accepted": true,
                "score": 35,
                "last_activity_date": 1465941664,
                "last_edit_date": 1465941664,
                "creation_date": 1436987881,
                "answer_id": 31439185,
                "question_id": 31438087,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "It&#39;s not completely clear to me what your provided script does, but it seems like it only looks for a string that contains the provided subset. I would suggest using [`contains`](http://stedolan.github.io/jq/manual/#containselement) or [`startswith`](http://stedolan.github.io/jq/manual/#startswithstr). A sample script would look like:\r\n\r\n    echo &quot;${json}&quot; | jq --arg subnet &quot;$subnet&quot; &#39;.subnets[] | select(.cidr | startswith($subnet)).id&#39;\r\n\r\nSince you mention regex: the latest release of jq, 1.5, includes regex support (thanks to Jeff Mercado for pointing this out!) and, if you have to deal with string manipulation problems frequently, I&#39;d recommend checking it out.\r\n",
                "title": "regex-like search in a json with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 22,
        "last_activity_date": 1504028084,
        "creation_date": 1436984193,
        "last_edit_date": 1504028084,
        "question_id": 31438087,
        "body_markdown": "I have this json and I want to get the id of the corresponding subnet that fit the variable subnet.\r\n\r\n    subnet=&quot;192.168.112&quot;\r\n    json=&#39;{\r\n      &quot;subnets&quot;: [\r\n        {\r\n          &quot;cidr&quot;: &quot;192.168.112.0/24&quot;,\r\n          &quot;id&quot;: &quot;123&quot;\r\n        },\r\n        {\r\n          &quot;cidr&quot;: &quot;10.120.47.0/24&quot;,\r\n          &quot;id&quot;: &quot;456&quot;\r\n        }\r\n      ]\r\n    }&#39;\r\n\r\nSince regex is not supported with jq. The only way I found to get the right id is to mixte grep, sed and jq like this :\r\n\r\n    tabNum=$((`echo ${json} | jq &quot;.subnets[].cidr&quot; | grep -n &quot;$subnet&quot; | sed &quot;s/^\\([0-9]\\+\\):.*$/\\1/&quot;` - 1))\r\n    NET_ID=`echo ${json} | jq -r &quot;.subnets[${tabNum}].id&quot;`\r\n\r\n\r\nIs there a way to get the id only using jq ?",
        "link": "https://stackoverflow.com/questions/31438087/regex-like-search-in-a-json-with-jq",
        "title": "regex-like search in a json with jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1437074600,
                "creation_date": 1437074600,
                "answer_id": 31462815,
                "question_id": 31462702,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Use:\r\n\r\n    cat $JSON_FILE |\r\n    jq -r &#39;.MetricAlarms[] |\r\n          { MetricName,\r\n            Threshold,\r\n            EvaluationPeriods,\r\n            &quot;AlarmActions&quot; : .AlarmActions[0]\r\n          } +\r\n          ( .Dimensions[] | { DimName: .Name, DimValue: .Value } )\r\n    &#39;\r\n\r\ni.e. don&#39;t use  shortcut syntax for the `AlarmActions` element.",
                "title": "JQ: Show the contents/value of a single-element array"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1437074600,
        "creation_date": 1437074253,
        "question_id": 31462702,
        "body_markdown": "My JSON file:\r\n\r\n    {\r\n        &quot;MetricAlarms&quot;: [\r\n            {\r\n                &quot;EvaluationPeriods&quot;: 2,\r\n                &quot;AlarmActions&quot;: [\r\n                    &quot;this is causing me trouble&quot;\r\n                ],\r\n                &quot;Threshold&quot;: 0.0,\r\n                &quot;Dimensions&quot;: [\r\n                    {\r\n                        &quot;Name&quot;: &quot;DBInstanceIdentifier&quot;,\r\n                        &quot;Value&quot;: &quot;db-master02&quot;\r\n                    }\r\n                ],\r\n                &quot;MetricName&quot;: &quot;ReplicaLag&quot;\r\n            }\r\n        ]\r\n    }\r\nMy current command to flatten the JSON file (jq 1.3, cannot upgrade right now):\r\n\r\n    cat $JSON_FILE |\r\n       jq -r &#39;.MetricAlarms[] |\r\n              { MetricName,\r\n                Threshold,\r\n                EvaluationPeriods,\r\n                AlarmActions\r\n              } +\r\n              ( .Dimensions[] | { DimName: .Name, DimValue: .Value } )\r\n       &#39;\r\nproduces:\r\n\r\n    {\r\n      &quot;DimName&quot;: &quot;DBInstanceIdentifier&quot;,\r\n      &quot;DimValue&quot;: &quot;db-master02&quot;,\r\n      &quot;AlarmActions&quot;: [\r\n        &quot;this is causing me trouble&quot;\r\n      ],\r\n      &quot;EvaluationPeriods&quot;: 2,\r\n      &quot;Threshold&quot;: 0,\r\n      &quot;MetricName&quot;: &quot;ReplicaLag&quot;\r\n    }\r\nWhat I really want:\r\n\r\n    {\r\n      &quot;DimName&quot;: &quot;DBInstanceIdentifier&quot;,\r\n      &quot;DimValue&quot;: &quot;db-master02&quot;,\r\n      &quot;AlarmActions&quot;: &quot;this is causing me trouble&quot;,\r\n      &quot;EvaluationPeriods&quot;: 2,\r\n      &quot;Threshold&quot;: 0,\r\n      &quot;MetricName&quot;: &quot;ReplicaLag&quot;\r\n    }\r\nI want to show the value for &quot;AlarmActions&quot; without an array.\r\n\r\nThis seems like a simple problem, but the answer eludes me.  I have tried treating &quot;AlarmActions&quot; in a manner similar to the way I treat &quot;Dimensions&quot;.  I have tried every variation of [], [0], periods, pipes, and function calls I can think of, but to no avail.  What am I missing?\r\n",
        "link": "https://stackoverflow.com/questions/31462702/jq-show-the-contents-value-of-a-single-element-array",
        "title": "JQ: Show the contents/value of a single-element array"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 6,
                "is_accepted": true,
                "score": 6,
                "last_activity_date": 1437197250,
                "creation_date": 1437197250,
                "answer_id": 31488101,
                "question_id": 31485906,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You can use the `-e` flag that will make `jq` return exit code `0` if the last output value was neither `false` or `null` so then your logic may become:\r\n\r\n    result=$(jq -e -r &#39;.some | .filters&#39;) &amp;&amp; foo || bar",
                "title": "Is there a better way to pass string output from jq to bash?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 4,
        "last_activity_date": 1437197250,
        "creation_date": 1437173980,
        "last_edit_date": 1437174289,
        "question_id": 31485906,
        "body_markdown": "I’ve just discovered jq and been really loving it. One thing I find myself doing a lot though stuff like:\r\n\r\n    result=$(jq --raw-output &#39;.some | .filters // &quot;&quot;&#39;)\r\n    if [[ $result ]]; then\r\n        foo\r\n    else\r\n        bar\r\n    fi\r\n\r\n\r\nThe default to an empty string seems to play more nicely with bash &quot;truthiness&quot; than e.g. `if [[ $result != &quot;null&quot; ]]`, and raw-output is usually necessary to store just the resultant string in a variable. My question is, I’m using these two tweaks so consistently in scripts, is there perhaps a better way to achieve the same functionality? Or would it make sense (as a possible enhancement to jq) to be able to set a couple env vars to control this behavior for the duration of the script?",
        "link": "https://stackoverflow.com/questions/31485906/is-there-a-better-way-to-pass-string-output-from-jq-to-bash",
        "title": "Is there a better way to pass string output from jq to bash?"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1437482594,
                "creation_date": 1437482594,
                "answer_id": 31539372,
                "question_id": 31537719,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The following script takes the string value from each of the separate objects with `.string`, wraps them in an array `[...]` and then joins the members of the array with commas using `join`.\r\n\r\nI modified the regex because you didn&#39;t actually need a capture group for the given use case, but if you wanted to access the capture groups you could do `.captures[].string` instead of `.string`.\r\n\r\n`echo &#39;&quot;foo foo&quot;&#39; | jq &#39;[match(&quot;foo&quot;; &quot;g&quot;).string] | join(&quot;,&quot;)&#39;`",
                "title": "How to process output from match function in jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1437482594,
        "creation_date": 1437477945,
        "question_id": 31537719,
        "body_markdown": "I&#39;m using js tool to parse some JSONs/strings. My minimal example is the following command:\r\n\r\n    echo &#39;&quot;foo foo&quot;&#39; | jq &#39;match(&quot;(foo)&quot;; &quot;g&quot;)&#39;\r\n\r\nWhich results in the following output:\r\n\r\n    {\r\n      &quot;offset&quot;: 0,\r\n      &quot;length&quot;: 3,\r\n      &quot;string&quot;: &quot;foo&quot;,\r\n      &quot;captures&quot;: [\r\n        {\r\n          &quot;offset&quot;: 0,\r\n          &quot;length&quot;: 3,\r\n          &quot;string&quot;: &quot;foo&quot;,\r\n          &quot;name&quot;: null\r\n        }\r\n      ]\r\n    }\r\n    {\r\n      &quot;offset&quot;: 4,\r\n      &quot;length&quot;: 3,\r\n      &quot;string&quot;: &quot;foo&quot;,\r\n      &quot;captures&quot;: [\r\n        {\r\n          &quot;offset&quot;: 4,\r\n          &quot;length&quot;: 3,\r\n          &quot;string&quot;: &quot;foo&quot;,\r\n          &quot;name&quot;: null\r\n        }\r\n      ]\r\n    }\r\n\r\nI want my final output for this example to be:\r\n\r\n    &quot;foo,foo&quot;\r\n\r\nBut in this case I get two separate objects instead of an array or similar that I could call `implode` on. I guess either the API isn&#39;t made for my UC or my understanding of it is very wrong. Please, advise.",
        "link": "https://stackoverflow.com/questions/31537719/how-to-process-output-from-match-function-in-jq",
        "title": "How to process output from match function in jq?"
    },
    {
        "tags": [
            "json",
            "rest",
            "parsing",
            "conditional-statements",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1437488027,
                "creation_date": 1437488027,
                "answer_id": 31541596,
                "question_id": 31540337,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "found the solution on jq&#39;s manual (with #ifthenelse and #Objects) - http://stedolan.github.io/jq/manual\r\n\r\n    jq -r &#39;{name1: .[].item1, name2: .[].array[].item2} | /\r\n    if .item2 == &quot;bbb&quot; then .name1 elif .item2 != &quot;bbb&quot; then empty else empty end&#39;",
                "title": "Parse json and extract items in array upon condition of nested values"
            },
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1437491004,
                "creation_date": 1437491004,
                "answer_id": 31542812,
                "question_id": 31540337,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "An easier solution is available thanks to the magic powers of the recurse operator, `..`:\r\n\r\n`jq -r &#39;.[] | select(.. | .item2? == &quot;bbb&quot;).item1&#39;`\r\n\r\nBasically what this does is, for each (`.[]`) object in the original array, pick (`select`) only those in which any of the keys recursively (`..`) named `.item2` equals `&quot;bbb&quot;`, and then select the `.item1` property of said object.",
                "title": "Parse json and extract items in array upon condition of nested values"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1437530474,
                "creation_date": 1437530474,
                "answer_id": 31552650,
                "question_id": 31540337,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "\r\nIf you find the magic of .. too powerful for your purposes, the following may be useful.  It restricts the search for the &quot;item2&quot; key.\r\n\r\n\r\n    def some(condition): reduce .[] as $x\r\n     (false; if . then . else $x|condition end);\r\n\r\n    .[]\r\n    | to_entries\r\n    | select( some( .value | (type == &quot;array&quot;) and some(.item2 == &quot;bbb&quot;)) )\r\n    | from_entries\r\n    | .item1\r\n\r\n\r\nIf your jq has any/1, then use it instead of some/1.",
                "title": "Parse json and extract items in array upon condition of nested values"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1505970312,
                "last_edit_date": 1505970312,
                "creation_date": 1503681710,
                "answer_id": 45886598,
                "question_id": 31540337,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a solution which uses **tostream** and **getpath**\r\n\r\n    foreach (tostream|select(length==2)) as [$p,$v] (.;.;\r\n      if $p[-1] == &quot;item2&quot; and $v == &quot;bbb&quot; then getpath($p[:-3]).item1 else empty end\r\n    )\r\n\r\n\r\nEDIT: I now realize a filter of the form `foreach E as $X (.; .; R)` can almost always be rewritten as `E as $X | R` so the above is really just\r\n\r\n      (tostream | select(length==2)) as [$p,$v]\r\n    | if $p[-1] == &quot;item2&quot; and $v == &quot;bbb&quot; then getpath($p[:-3]).item1 else empty end\r\n\r\n",
                "title": "Parse json and extract items in array upon condition of nested values"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": 1,
        "last_activity_date": 1505970312,
        "creation_date": 1437485064,
        "last_edit_date": 1504597065,
        "question_id": 31540337,
        "body_markdown": "I&#39;ve already asked a similar question here - https://stackoverflow.com/questions/31533719/parse-json-and-choose-items-keys-upon-condition, but this time it&#39;s slightly different.\r\n\r\nThis is the Example:\r\n\r\n\t[\r\n\t  {\r\n\t\t&quot;item1&quot;: &quot;value123&quot;,\r\n\t\t&quot;array0&quot;: [\r\n\t\t  {\r\n\t\t\t&quot;item2&quot;: &quot;aaa&quot;\r\n\t\t  }\r\n\t\t]\r\n\t  },\r\n\t  {\r\n\t\t&quot;item1&quot;: &quot;value456&quot;,\r\n\t\t&quot;array1&quot;: [\r\n\t\t  {\r\n\t\t\t&quot;item2&quot;: &quot;bbb&quot;\r\n\t\t  }\r\n\t\t]\r\n\t  },\r\n\t  {\r\n\t\t&quot;item1&quot;: &quot;value789&quot;,\r\n\t\t&quot;array2&quot;: [\r\n\t\t  {\r\n\t\t\t&quot;item2&quot;: &quot;ccc&quot;\r\n\t\t  }\r\n\t\t]\r\n\t  }\r\n\t]\r\n\r\nI&#39;d like to get the value of &quot;item1&quot;, only when &quot;item2&quot; has a specific value.\r\n\r\nLet&#39;s say if item2 equals &quot;bbb&quot;, then all I want to get back is &quot;value456&quot;.\r\n\r\nI&#39;ve tried to solve it with jq like it worked for me in the issue mentioned above, but to no avail, as I can&#39;t extract values from a &quot;higher&quot; level than the one i&#39;m searching in with jq&#39;s select and map.\r\n\r\n",
        "link": "https://stackoverflow.com/questions/31540337/parse-json-and-extract-items-in-array-upon-condition-of-nested-values",
        "title": "Parse json and extract items in array upon condition of nested values"
    },
    {
        "tags": [
            "python",
            "python-2.7",
            "streaming",
            "jq",
            "input-filtering"
        ],
        "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": 5,
                "creation_date": 1438363286,
                "post_id": 31640639,
                "comment_id": 51437170,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1438785098,
                "post_id": 31640639,
                "comment_id": 51592699,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 6679513,
                    "reputation": 21,
                    "user_id": 5153166,
                    "user_type": "registered",
                    "profile_image": "https://lh5.googleusercontent.com/-V_ft-tfBwY4/AAAAAAAAAAI/AAAAAAAAABE/j7YMVMd3cV8/s256-rj/photo.jpg",
                    "display_name": "Brian Bowles",
                    "link": "https://stackoverflow.com/users/5153166/brian-bowles"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1438887586,
                "post_id": 31640639,
                "comment_id": 51646596,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 0,
        "last_activity_date": 1447896060,
        "creation_date": 1437936301,
        "last_edit_date": 1447896060,
        "question_id": 31640639,
        "body_markdown": "I&#39;m trying to figure out how to filter data that is being forwarded from one port to another. \r\n\r\nWhat I&#39;m doing is taking in data from an indoor positioning system and importing it into my Oracle database. Here is the script I&#39;m using to forward the data and it works great. \r\n\r\nBasically my indoor positioning system will only connect to port 8787 and my database pulls in data from port 8081.\r\n\r\n\timport socket\r\n\tport = 8787\r\n\ts = socket.socket(socket.AF_INET, socket.SOCK_DGRAM)\r\n\ts.bind((&quot;&quot;, port))\r\n\tprint (&quot;waiting on port:&quot;, port)\r\n\twhile 1:\r\n\t\tdata, addr = s.recvfrom(1024)\r\n\t\ts.sendto(data, (&#39;192.1.1.1&#39;,8788)) \r\n\r\nAnd here is the data its streaming:\r\n\r\n&gt; {&quot;id&quot;:&quot;0xDECA34303170235F&quot;,&quot;timestamp&quot;:946684889.332,&quot;msgid&quot;:78,&quot;coordinates&quot;:{&quot;x&quot;:0.392,&quot;y&quot;:0.616,&quot;z&quot;:1.228,&quot;heading&quot;:0.000,&quot;pqf&quot;:100},&quot;meas&quot;:[{&quot;anchor&quot;:&quot;0xDECA353034301E99&quot;,&quot;dist&quot;:1.433,&quot;dqf&quot;:100},{&quot;anchor&quot;:&quot;0xDECA323030901DE2&quot;,&quot;dist&quot;:8.307,&quot;dqf&quot;:100},{&quot;anchor&quot;:&quot;0xDECA323031300FBF&quot;,&quot;dist&quot;:6.288,&quot;dqf&quot;:89},{&quot;anchor&quot;:&quot;0xDECA333035101DAA&quot;,&quot;dist&quot;:10.308,&quot;dqf&quot;:87}]}\r\n\r\nHere is what I need instead:\r\n\r\n&gt; [\r\n  &quot;0xDECA34303170235F&quot;,\r\n  946684889.332,\r\n  78,\r\n  0.392,\r\n  0.616,\r\n  1.228,\r\n  0\r\n]\r\n\r\nI got that from setting up a filter and running sample data through it via [jqplay][1]. Here is the filter that I used to get that;\r\n\r\n\t [.id, .timestamp, .msgid, .coordinates[&quot;x&quot;,&quot;y&quot;,&quot;z&quot;,&quot;heading&quot;]]\r\n\r\nWhat I&#39;m trying to figure out is where to put those filters into my forwarding script so the data can be filtered before it&#39;s forwarded. Any missing data has to be null for the database. \r\n\r\nI&#39;m using Python 2.7 On Windows 8 and I downloaded and installed jq via choco.\r\n\r\n  [1]: http://www.jqplay.org",
        "link": "https://stackoverflow.com/questions/31640639/jq-to-filter-streaming-data-in-python",
        "title": "Jq to filter streaming data in Python"
    },
    {
        "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": 1,
                "creation_date": 1438039123,
                "post_id": 31658278,
                "comment_id": 51274211,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 166270,
                    "reputation": 135171,
                    "user_id": 390278,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/84715fec547362389d02f5be0ed12814?s=256&d=identicon&r=PG",
                    "display_name": "Jeff Mercado",
                    "link": "https://stackoverflow.com/users/390278/jeff-mercado"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1438039617,
                "post_id": 31658278,
                "comment_id": 51274380,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "user_type": "does_not_exist",
                    "display_name": "user3899165"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1438039966,
                "post_id": 31658278,
                "comment_id": 51274489,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1438753126,
                "creation_date": 1438753126,
                "answer_id": 31824194,
                "question_id": 31658278,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "To do what is requested is possible using features that were added after the release of jq 1.4.  The following uses *foreach* and *inputs*:\r\n\r\n    label $top\r\n    | foreach inputs as $line\r\n       # state: true means found; false means not yet found\r\n       (false;\r\n        if . then break $top\r\n        else if $line | tostring | test(&quot;goodbye&quot;) then true else false end\r\n        end;\r\n        if . then $line else empty end\r\n       )\r\n\r\n\r\nExample:\r\n\r\n    $ cat &lt;&lt; EOF | jq -n -f exit.jq\r\n    1\r\n    &quot;goodbye&quot;\r\n    3\r\n    4\r\n    EOF\r\n\r\nResult:\r\n    &quot;goodbye&quot;",
                "title": "Terminating jq processing when condition is met"
            },
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1504763650,
                "creation_date": 1504763650,
                "answer_id": 46088779,
                "question_id": 31658278,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is an approach which uses a recent version of `first/1` (currently in  master) \r\n\r\n    def first(g): label $out | g | ., break $out; \r\n\r\n    first(inputs | if .==&quot;100&quot; then . else empty end)\r\n\r\nExample:\r\n\r\n    $ seq 1000000000 | jq -M -Rn -f filter.jq\r\n\r\nOutput (followed by immediate termination)\r\n\r\n    &quot;100&quot;\r\n\r\nHere I use `seq` in lieu of a large JSON dataset.",
                "title": "Terminating jq processing when condition is met"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1733149952,
                "last_edit_date": 1733149952,
                "creation_date": 1636425498,
                "answer_id": 69892185,
                "question_id": 31658278,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can accomplish it using [`halt`][1] and the [`inputs`][2] builtin:\r\n\r\n```sh\r\njq -n &#39;inputs | if ... then &quot;something&quot;, halt else ... end&#39;\r\n```\r\n\r\nWill print `&quot;something&quot;` and terminate gracefully when the condition matches.\r\n\r\nFor this to work (i.e. terminate when condition is true), `jq` needs the `-n` parameter. See this [issue][3]\r\n\r\n\r\n  [1]: https://jqlang.github.io/jq/manual/v1.6/#halt\r\n  [2]: https://jqlang.github.io/jq/manual/v1.6/#inputs\r\n  [3]: https://github.com/stedolan/jq/issues/2368",
                "title": "Terminating jq processing when condition is met"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 6,
        "last_activity_date": 1733149952,
        "creation_date": 1438014026,
        "last_edit_date": 1438175332,
        "question_id": 31658278,
        "body_markdown": "I am using jq to search for specific results in a large file. I do not care for duplicate entries matching this specific condition, and it takes a while to process the whole file. What I would like to do is print some details about the first match and then terminate the jq command on the file to save time.\r\n\r\nI.e.\r\n\r\n    jq &#39;. | if ... then &quot;print something; exit jq&quot; else ... end&#39;\r\n\r\nI looked into http://stedolan.github.io/jq/manual/?#Breakingoutofcontrolstructures but this didn&#39;t quite seem to apply\r\n\r\n\r\nEDIT:\r\nThe file I am parsing contains multiple json objects, one after another. They are not in an array.",
        "link": "https://stackoverflow.com/questions/31658278/terminating-jq-processing-when-condition-is-met",
        "title": "Terminating jq processing when condition is met"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6586882,
                    "reputation": 149,
                    "user_id": 5089400,
                    "user_type": "registered",
                    "accept_rate": 50,
                    "profile_image": "https://i.sstatic.net/NUyY8.png?s=256",
                    "display_name": "underscore_nico",
                    "link": "https://stackoverflow.com/users/5089400/underscore-nico"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1438093123,
                "post_id": 31677800,
                "comment_id": 51299677,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 6591357,
                    "reputation": 1,
                    "user_id": 5092396,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/e2feca7c5076f40cd45fd29a011d0fdb?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Д Торн",
                    "link": "https://stackoverflow.com/users/5092396/%d0%94-%d0%a2%d0%be%d1%80%d0%bd"
                },
                "reply_to_user": {
                    "account_id": 6586882,
                    "reputation": 149,
                    "user_id": 5089400,
                    "user_type": "registered",
                    "accept_rate": 50,
                    "profile_image": "https://i.sstatic.net/NUyY8.png?s=256",
                    "display_name": "underscore_nico",
                    "link": "https://stackoverflow.com/users/5089400/underscore-nico"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1438094081,
                "post_id": 31677800,
                "comment_id": 51300512,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 1201953,
                    "reputation": 54871,
                    "user_id": 1172428,
                    "user_type": "registered",
                    "accept_rate": 94,
                    "profile_image": "https://www.gravatar.com/avatar/240fe123035f1c6e184f59da2f1465d9?s=256&d=identicon&r=PG",
                    "display_name": "FatalError",
                    "link": "https://stackoverflow.com/users/1172428/fatalerror"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1438264851,
                "post_id": 31677800,
                "comment_id": 51387835,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 6591357,
                    "reputation": 1,
                    "user_id": 5092396,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/e2feca7c5076f40cd45fd29a011d0fdb?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Д Торн",
                    "link": "https://stackoverflow.com/users/5092396/%d0%94-%d0%a2%d0%be%d1%80%d0%bd"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1438354372,
                "post_id": 31677800,
                "comment_id": 51432083,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 57200,
                    "reputation": 158728,
                    "user_id": 171318,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/ePRKy.jpg?s=256",
                    "display_name": "hek2mgl",
                    "link": "https://stackoverflow.com/users/171318/hek2mgl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1438356116,
                "post_id": 31677800,
                "comment_id": 51433201,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1438361428,
                "creation_date": 1438361428,
                "answer_id": 31751282,
                "question_id": 31677800,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "With jq 1.5, regular expression support has been added\r\n\r\nSo assuming `property` is an array of your test objects (your example is broken and invalid), you could do this to select the objects with names that follow the pattern:\r\n\r\n    .property | map(select(.name | test(&quot;test[0-9]&quot;)))\r\n\r\nThen for each of those objects, the `value` appears to be json strings.  You would have to parse those out before you could get anything out of those.\r\n\r\n    .property | map(\r\n        select(.name | test(&quot;test[0-9]&quot;))\r\n            | .value |= fromjson\r\n            | { name } + .value\r\n        )\r\n\r\nThis will give you an array:\r\n\r\n    [\r\n      {\r\n        &quot;name&quot;: &quot;test1&quot;,\r\n        &quot;test_type&quot;: &quot;jsystem&quot;,\r\n        &quot;order&quot;: 1,\r\n        &quot;test_id&quot;: &quot;test_01&quot;,\r\n        &quot;physical_setup_id&quot;: &quot;prd_01&quot;,\r\n        &quot;timeout&quot;: &quot;20&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;test2&quot;,\r\n        &quot;test_type&quot;: &quot;jsystem&quot;,\r\n        &quot;order&quot;: 2,\r\n        &quot;test_id&quot;: &quot;test_02&quot;,\r\n        &quot;physical_setup_id&quot;: &quot;prd_02&quot;,\r\n        &quot;timeout&quot;: &quot;30&quot;\r\n      }\r\n    ]\r\n\r\nFormat it to your liking.",
                "title": "JSON file parsing using jq"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1438361428,
        "creation_date": 1438090217,
        "last_edit_date": 1438355979,
        "question_id": 31677800,
        "body_markdown": "I have a JSON file with such detailes in it(not full file):\r\n   \r\n\r\n    {&quot;property&quot;: [\r\n        {\r\n\r\n     {\r\n          &quot;name&quot;: &quot;test1&quot;,\r\n          &quot;value&quot;: &quot;{\\&quot;test_type\\&quot;:\\&quot;jsystem\\&quot;,\\&quot;order\\&quot;:1,\\&quot;test_id\\&quot;:\\&quot;test_01\\&quot;,\\&quot;physical_setup_id\\&quot;:\\&quot;prd_01\\&quot;,\\&quot;timeout\\&quot;:\\&quot;20\\&quot;}&quot;,\r\n          &quot;own&quot;: true\r\n        },\r\n       {\r\n          &quot;name&quot;: &quot;test2&quot;,\r\n          &quot;value&quot;: &quot;{\\&quot;test_type\\&quot;:\\&quot;jsystem\\&quot;,\\&quot;order\\&quot;:2,\\&quot;test_id\\&quot;:\\&quot;test_02\\&quot;,\\&quot;physical_setup_id\\&quot;:\\&quot;prd_02\\&quot;,\\&quot;timeout\\&quot;:\\&quot;30\\&quot;}&quot;,\r\n          &quot;own&quot;: true\r\n        },\r\n       {\r\n          &quot;name&quot;: &quot;pass&quot;,\r\n          &quot;value&quot;: &quot;{\\&quot;test_type\\&quot;:\\&quot;jsystem\\&quot;,\\&quot;order\\&quot;:3,\\&quot;test_id\\&quot;:\\&quot;test_03\\&quot;,\\&quot;physical_setup_id\\&quot;:\\&quot;prd_01\\&quot;,\\&quot;timeout\\&quot;:\\&quot;15\\&quot;}&quot;,\r\n          &quot;own&quot;: true\r\n        }\r\n     ]\r\n    }\r\n\r\nAnd I am trying to extract all the fields that are contain &quot;name test%NUMBER%&quot; \r\nI&#39;ve tried this:\r\n`cat build.json | jq &#39;.property | .[] | select(.name==&quot;test1&quot;)&#39;`  - it works OK , but I want to add digital parameter to .name==test.\r\nSomething like this:\r\n\r\n    cat build.json | jq &#39;.property | .[] | select(.name==&quot;test&#39;[0-9]&#39;&quot;)&#39;\r\n\r\nAns second I need to parse each data under &quot;value&quot; parameter.\r\nLike this: \r\n\r\n    test1:\r\n    test_type=jsystem\r\n    order=1\r\n    test_id=test_01\r\n \r\n\r\n    ]\r\n    }\r\n\r\n",
        "link": "https://stackoverflow.com/questions/31677800/json-file-parsing-using-jq",
        "title": "JSON file parsing using jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1438148323,
                "creation_date": 1438148323,
                "answer_id": 31691970,
                "question_id": 31688774,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You really should be working with data that has the same structure. Otherwise you&#39;re left with having to deal with weird corner cases.  `alternateName` should be an array of objects, or otherwise, replicate the root object with each of the `alternateName` objects.\r\n\r\nAnyway, here&#39;s how you can deal with the differing types.  Use the alternative operator (`//`) along with some filtering to deal with the different cases.  You could use the `arrays` filter to handle arrays and alternate assuming objects afterwards.\r\n\r\n    { uri, alternateName: .alternateName | (arrays[].alternateName // .alternateName) }\r\n        | &quot;\\(.uri)\\t\\(.alternateName)&quot;",
                "title": "jQ - query alternative JSON structures"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1503682426,
                "creation_date": 1503682426,
                "answer_id": 45886759,
                "question_id": 31688774,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a solution which uses a helper function to normalize the `.alternateName` values.\r\n\r\n    def vals:\r\n      if (.|type) == &quot;object&quot; then .[] else . end\r\n    ;      \r\n\r\n    &quot;\\(.uri)\\t\\(.alternateName[] | vals)&quot;",
                "title": "jQ - query alternative JSON structures"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1503682426,
        "creation_date": 1438125743,
        "last_edit_date": 1438126771,
        "question_id": 31688774,
        "body_markdown": "I have the following JSON-inline document:\r\n\r\n      {\r\n      &quot;a&quot;: &quot;Person&quot;,\r\n      &quot;alternateName&quot;: [\r\n         {\r\n           &quot;alternateName&quot;: &quot;1793 Di&#233;bolt&quot;\r\n         },\r\n         {\r\n           &quot;alternateName&quot;: &quot;XXX Di&#233;bolt&quot;\r\n         }\r\n      ],\r\n      &quot;uri&quot;: &quot;http://500051893&quot;\r\n      }\r\n      {\r\n        &quot;a&quot;: &quot;Person&quot;,\r\n        &quot;alternateName&quot;: {\r\n           &quot;alternateName&quot;: &quot;A1-53167&quot;\r\n         },\r\n        &quot;uri&quot;: &quot;http://vocab.getty.edu/ulan/500116327&quot;\r\n      }\r\n\r\nI want to get the values from all `alternateName` keys and output it as a TSV file.\r\n\r\nI can get the ones which have only one alternateName-object with:\r\n\r\n    jq -r &quot;[ .uri, .alternateName.alternateName ] | join(\\&quot;\\t\\&quot;)&quot;\r\n\r\nBut how can I get both: the ones with only have one alternateName-object and the ones where the first `alternateName` key has a dictionary with `alternateName` keys?",
        "link": "https://stackoverflow.com/questions/31688774/jq-query-alternative-json-structures",
        "title": "jQ - query alternative JSON structures"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 11,
                "is_accepted": false,
                "score": 9,
                "last_activity_date": 1438155616,
                "creation_date": 1438155616,
                "answer_id": 31694183,
                "question_id": 31694182,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Well I found out myself how to do it. If you have a better solution, you&#39;re more than welcome to give it here.\r\n\r\n    jq &#39;.nested=(.nested + {&quot;freshly&quot;: &quot;added&quot;})&#39;",
                "title": "How to modify a nested object with jq"
            },
            {
                "up_vote_count": 25,
                "is_accepted": true,
                "score": 25,
                "last_activity_date": 1438157065,
                "creation_date": 1438157065,
                "answer_id": 31694658,
                "question_id": 31694182,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Just assign the new value to the nested object.\r\n\r\n    .nested.freshly = &quot;added&quot;",
                "title": "How to modify a nested object with jq"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1582317845,
                "creation_date": 1582317845,
                "answer_id": 60345982,
                "question_id": 31694182,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can also do simply\r\n\r\n```\r\n.nested += {freshly: &quot;added&quot;}\r\n```\r\n\r\nThen you can add multiple nested keys at once",
                "title": "How to modify a nested object with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 17,
        "last_activity_date": 1582317845,
        "creation_date": 1438155616,
        "question_id": 31694182,
        "body_markdown": "Given this\r\n\r\n    {\r\n      &quot;some&quot;: &quot;property&quot;,\r\n      &quot;nested&quot;: {\r\n        &quot;hello&quot;: &quot;world&quot;\r\n      }\r\n    }\r\nI&#39;d like to get this result with jq\r\n\r\n    {\r\n      &quot;some&quot;: &quot;property&quot;,\r\n      &quot;nested&quot;: {\r\n        &quot;hello&quot;: &quot;world&quot;,\r\n        &quot;freshly&quot;: &quot;added&quot;\r\n      }\r\n    }\r\n\r\nSo how can I add the freshly added field ? I don&#39;t know how many properties are at root level (and I want to keep them all), I only know the name of the nested object (here &quot;nested&quot;), the name of the property I&#39;d like to add (here &quot;freshly&quot;) and its value.\r\n",
        "link": "https://stackoverflow.com/questions/31694182/how-to-modify-a-nested-object-with-jq",
        "title": "How to modify a nested object with jq"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1071094,
                    "reputation": 30287,
                    "user_id": 1070354,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/56ca246e6d24b9a09114ff4542bcc2b1?s=256&d=identicon&r=PG",
                    "display_name": "favoretti",
                    "link": "https://stackoverflow.com/users/1070354/favoretti"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1438248028,
                "post_id": 31719737,
                "comment_id": 51376370,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 4160322,
                    "reputation": 2344,
                    "user_id": 3410584,
                    "user_type": "registered",
                    "accept_rate": 48,
                    "profile_image": "https://i.sstatic.net/hVfv4.jpg?s=256",
                    "display_name": "ValLeNain",
                    "link": "https://stackoverflow.com/users/3410584/vallenain"
                },
                "reply_to_user": {
                    "account_id": 1071094,
                    "reputation": 30287,
                    "user_id": 1070354,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/56ca246e6d24b9a09114ff4542bcc2b1?s=256&d=identicon&r=PG",
                    "display_name": "favoretti",
                    "link": "https://stackoverflow.com/users/1070354/favoretti"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1438248160,
                "post_id": 31719737,
                "comment_id": 51376467,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "user_type": "does_not_exist",
                    "display_name": "user3899165"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1438261953,
                "post_id": 31719737,
                "comment_id": 51385596,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 4160322,
                    "reputation": 2344,
                    "user_id": 3410584,
                    "user_type": "registered",
                    "accept_rate": 48,
                    "profile_image": "https://i.sstatic.net/hVfv4.jpg?s=256",
                    "display_name": "ValLeNain",
                    "link": "https://stackoverflow.com/users/3410584/vallenain"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1438267524,
                "post_id": 31719737,
                "comment_id": 51389887,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 3647119,
                    "reputation": 6353,
                    "user_id": 3040064,
                    "user_type": "registered",
                    "accept_rate": 59,
                    "profile_image": "https://www.gravatar.com/avatar/41376ff41d79bdde5520b6249f9f8ca7?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Jason Hu",
                    "link": "https://stackoverflow.com/users/3040064/jason-hu"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1439612853,
                "post_id": 31719737,
                "comment_id": 51945130,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": -1,
                "last_activity_date": 1438283311,
                "creation_date": 1438283311,
                "answer_id": 31732107,
                "question_id": 31719737,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The only safe option you have is to generate the json string manually with the properties ordered in the way you want them. There is no guarantee that the order you set properties on an object be preserved.\r\n\r\nYou can do so with the help of this function:\r\n\r\n    def inorder(names): names as $names | . as $obj\r\n        | &quot;{\\($names | map(&quot;\\(@json):\\($obj[.])&quot;) | join(&quot;,&quot;))}&quot;\r\n        ;\r\n\r\nThen to use it:\r\n\r\n    inorder([&quot;prop1&quot;, &quot;prop3&quot;, &quot;prop2&quot;])\r\n\r\nKeep in mind that this will return a string.  You&#39;ll want to get the raw output to get it back as an object.",
                "title": "re-organize object fields with jq"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1632523568,
                "last_edit_date": 1632523568,
                "creation_date": 1439612614,
                "answer_id": 32021494,
                "question_id": 31719737,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "[The following is an update of the answer originally posted in August 2015 (!).]\r\n\r\nFor jq versions 1.4 and up, the simplest way to specify a particular order of keys explicitly is to use the\r\n\r\n   {foo, bar, ...}\r\n\r\nform for specifying objects.  E.g. if input.json has the JSON shown in the question, then:\r\n\r\n    jq -Mc &#39;{prop1, prop3, prop2}&#39; input.json\r\n\r\nproduces:\r\n\r\n    {&quot;prop1&quot;:1,&quot;prop3&quot;:true,&quot;prop2&quot;:{&quot;nested&quot;:0}}\r\n\r\nIn this case, only the ordering of the top-level keys is affected. \r\n\r\nThe OP indicated a need to normalize JSON so that a text-oriented `diff` can be used.  For such purposes, the normalization of objects no matter how deeply nested would typically be required.  For this, jq (versions 1.4 and up) has the -S command-line option.\r\n\r\n----\r\n[The original answer with updates follows.]\r\n \r\nThe following is a variation of &quot;inorder&quot; given above. The desired JSON object (not a stringified version) is constructed directly. This works with jq versions 1.4 and up, since (by default) the keys are effectively stored in order of creation.\r\n\r\n    def orderKeys(keys):\r\n      . as $in\r\n      | reduce keys[] as $key ({}; . + { ($key): $in[$key] });\r\n\r\n    # Example:\r\n    orderKeys( [&quot;prop1&quot;, &quot;prop3&quot;, &quot;prop2&quot;] )\r\n\r\nWith the above in a file named order-keys.jq, and using the JSON in the task description as input, the command:\r\n\r\n    $ jq -M -n -c -f order-keys.jq\r\n\r\nproduces:\r\n\r\n    {&quot;prop1&quot;:1,&quot;prop3&quot;:true,&quot;prop2&quot;:{&quot;nested&quot;:0}}\r\n\r\n",
                "title": "re-organize object fields with jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1632518845,
                "creation_date": 1632518845,
                "answer_id": 69321258,
                "question_id": 31719737,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Ok, answering my own followup question. Here&#39;s my hacky solution to include the &quot;rest&quot; of the properties (not specified in the order) at the end of the resulting object, so as to not lose any of the input:\r\n```\r\ndef orderKeys(orderedkeys):\r\n  . as $in\r\n  | reduce keys[] as $key ({}; if orderedkeys|contains([$key]) then . else . + { ($key): $in[$key] } end)\r\n  | . as $rest\r\n  | reduce orderedkeys[] as $key ({}; . + { ($key): $in[$key] })\r\n  | . + $rest;\r\n\r\n# Example:\r\norderKeys( [&quot;prop1&quot;, &quot;prop3&quot;, &quot;prop2&quot;] )\r\n```\r\nOn the input\r\n```\r\n{\r\n  &quot;prop1&quot;: 1,\r\n  &quot;otherprop&quot;: &quot;foo&quot;,\r\n  &quot;prop2&quot;: {\r\n    &quot;nested&quot;: 0\r\n  },\r\n  &quot;prop3&quot;: true\r\n}\r\n```\r\nthis produces\r\n```\r\n{\r\n  &quot;prop1&quot;: 1,\r\n  &quot;prop3&quot;: true,\r\n  &quot;prop2&quot;: {\r\n    &quot;nested&quot;: 0\r\n  },\r\n  &quot;otherprop&quot;: &quot;foo&quot;\r\n}\r\n```\r\n",
                "title": "re-organize object fields with jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1632524016,
                "creation_date": 1632524016,
                "answer_id": 69321793,
                "question_id": 31719737,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "In a followup question, @ManuelFahndrich asked \r\n\r\n&gt; Do you see a way to include properties not named in the keys by default?\r\n\r\nHere&#39;s a simple approach using `to_entries` and `from_entries` to perform &quot;object subtraction&quot;:\r\n```\r\n{prop1, prop3, prop2} as $first\r\n| $first + (to_entries - ($first|to_entries) | from_entries)\r\n```",
                "title": "re-organize object fields with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": 5,
        "last_activity_date": 1632524016,
        "creation_date": 1438247749,
        "question_id": 31719737,
        "body_markdown": "I was wondering if there is a way to re-organize the fields of an object using jq.\r\n\r\nI mean, given that\r\n\r\n    {\r\n      &quot;prop1&quot;: 1,\r\n      &quot;prop2&quot;: {\r\n        &quot;nested&quot;: 0\r\n      },\r\n      &quot;prop3&quot;: true\r\n    }\r\n\r\nI&#39;d like to get this\r\n\r\n    {\r\n      &quot;prop1&quot;: 1,\r\n      &quot;prop3&quot;: true,\r\n      &quot;prop2&quot;: {\r\n        &quot;nested&quot;: 0\r\n      }\r\n    }\r\n\r\nI want to choose the order of the fields (without any consideration about the type of the field or the alphabetical order, my choice only :) )\r\n\r\nThanks !",
        "link": "https://stackoverflow.com/questions/31719737/re-organize-object-fields-with-jq",
        "title": "re-organize object fields with jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1439225644,
                "last_edit_date": 1439225644,
                "creation_date": 1438398508,
                "answer_id": 31757796,
                "question_id": 31756724,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You can change the names of properties of objects if you use `with_entries(filter)`.  This converts an object to an array of key/value pairs and applies a filter to the pairs and converts back to an object.  So you would just want to update the key of those objects to your new names.\r\n\r\nDepending on which version of jq you&#39;re using, the next part can be tricky.  String replacement doesn&#39;t get introduced until jq 1.5.  If that was available, you could then do this:\r\n\r\n    {\r\n        nodes: .vertices | map(with_entries(\r\n            .key |= sub(&quot;^_+&quot;; &quot;&quot;)\r\n        )),\r\n        edges\r\n    }\r\n\r\nOtherwise if you&#39;re using jq 1.4, then you&#39;ll have to remove them manually.  A recursive function can help with that since the number of underscores varies.\r\n\r\n    def ltrimall(str): str as $str |\r\n        if startswith($str)\r\n            then ltrimstr($str) | ltrimall(str)\r\n            else .\r\n        end;\r\n    {\r\n        nodes: .vertices | map(with_entries(\r\n            .key |= ltrimall(&quot;_&quot;)\r\n        )),\r\n        edges\r\n    }",
                "title": "Transforming the name of key deeper in the JSON structure with jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1439152526,
                "creation_date": 1439152526,
                "answer_id": 31908592,
                "question_id": 31756724,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The following program works with jq 1.4 or jq 1.5.\r\nIt uses walk/1 to remove leading underscores from any key, no matter where it occurs in the input JSON.\r\n\r\nThe version of ltrim provided here uses recurse/1 for efficiency and portability, but any suitable substitute may be used.\r\n\r\n    def ltrim(c):\r\n      reduce recurse( if .[0:1] == c then .[1:] else null end) as $x \r\n        (null; $x);\r\n\r\n    # Apply f to composite entities recursively, and to atoms\r\n    def walk(f):\r\n     . as $in\r\n     | if type == &quot;object&quot; then\r\n          reduce keys[] as $key\r\n            ( {}; . + { ($key):  ($in[$key] | walk(f)) } ) | f\r\n      elif type == &quot;array&quot; then map( walk(f) ) | f\r\n      else f\r\n      end;\r\n\r\n    .vertices = .nodes\r\n    | del(.nodes)\r\n    | (.vertices |= walk(\r\n          if type == &quot;object&quot;\r\n          then with_entries( .key |= ltrim(&quot;_&quot;) )\r\n          else .\r\n          end ))\r\n",
                "title": "Transforming the name of key deeper in the JSON structure with jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1501788671,
                "creation_date": 1501788671,
                "answer_id": 45493049,
                "question_id": 31756724,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "From your example data it looks like you intend lots of little manipulations so I&#39;d break things out into stages like this:\r\n\r\n      .nodes = .vertices                     # \\ first take care of renaming\r\n    | del(.vertices)                         # / .vertices to .nodes\r\n\r\n    | .nodes = [ \r\n           .nodes[]                          # \\ then scan each node\r\n         | . as $n                           # /\r\n\r\n         | del(._type, .__eid)               # \\ whatever key-specific tweaks like \r\n         | .label = &quot;metric: \\(.name)&quot;       # / calculating .label you want can go here\r\n\r\n         | reduce keys[] as $k (             # \\\r\n             {};                             # | final reduce to handle renaming\r\n             .[$k | sub(&quot;^_+&quot;;&quot;&quot;)] = $n[$k]  # | any keys that start with _\r\n           )                                 # /\r\n      ]",
                "title": "Transforming the name of key deeper in the JSON structure with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1501788671,
        "creation_date": 1438385982,
        "last_edit_date": 1440398436,
        "question_id": 31756724,
        "body_markdown": "I have following json:\r\n\r\n    {\r\n      &quot;vertices&quot;: [\r\n        {\r\n          &quot;__cp&quot;: &quot;foo&quot;,\r\n          &quot;__type&quot;: &quot;metric&quot;,\r\n          &quot;__eid&quot;: &quot;foobar&quot;,\r\n          &quot;name&quot;: &quot;Undertow Metrics~Sessions Created&quot;,\r\n          &quot;_id&quot;: 45056,\r\n          &quot;_type&quot;: &quot;vertex&quot;\r\n        },\r\n        ...\r\n      ]\r\n      &quot;edges&quot;: [\r\n      ...\r\n\r\nand I would like to achieve this format:\r\n\r\n\r\n    {\r\n      &quot;nodes&quot;: [\r\n        {\r\n          &quot;cp&quot;: &quot;foo&quot;,\r\n          &quot;type&quot;: &quot;metric&quot;,\r\n          &quot;label&quot;: &quot;metric: Undertow Metrics~Sessions Created&quot;,\r\n          &quot;name&quot;: &quot;Undertow Metrics~Sessions Created&quot;,\r\n          &quot;id&quot;: 45056\r\n        },\r\n        ...\r\n      ]\r\n      &quot;edges&quot;: [\r\n      ...\r\n\r\nSo far I was able to create this expression:\r\n\r\n    jq &#39;{nodes: .vertices} | del(.nodes[].&quot;_type&quot;, .nodes[].&quot;__eid&quot;)&#39;\r\n\r\nI.e. rename &#39;vertices&#39; to &#39;nodes&#39; and remove &#39;_type&#39; and &#39;__eid&#39;, how can I rename a key nested deeper in the JSON?",
        "link": "https://stackoverflow.com/questions/31756724/transforming-the-name-of-key-deeper-in-the-json-structure-with-jq",
        "title": "Transforming the name of key deeper in the JSON structure with jq"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1438396968,
                "creation_date": 1438396968,
                "answer_id": 31757661,
                "question_id": 31756953,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Personally, I would have tried to do something like you did, to me that feels right from a functional perspective.\r\n\r\nBut there are other ways this could be expressed.  You could take advantage of the fact that when converting an array to entries, you get an array of index/value pairs.\r\n\r\n    to_entries | group_by(.key/2 | floor) | map(map(.value))\r\n\r\nOn the other hand, you could also just create slices of the array using a range of numbers.  I think this may perform better than recursing.\r\n\r\n    . as $arr | [ range(0; length/2) * 2 | $arr[.:.+2] ]",
                "title": "Most concise way to group pairs of elements in an array with jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1438835806,
                "last_edit_date": 1438835806,
                "creation_date": 1438835250,
                "answer_id": 31846856,
                "question_id": 31756953,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The following generalizes the task, works with jq 1.4, is highly performant with the optimizations in jq 1.5, and can be used to implement rho/1 (like R&#39;s &quot;dim(z) &lt;- c(3,5,100)&quot; and APL&#39;s &quot;A⍴B&quot;):\r\n\r\n    # Input: an array\r\n    # Output: a stream of arrays\r\n    # If the input is [] then the output stream is empty,\r\n    # otherwise it consists of arrays of length n, each array consisting\r\n    #  of successive elements from the input array, padded with nulls.\r\n    def takes(n):\r\n      def _takes:\r\n        if length == 0 then empty\r\n        elif length &lt; n then .[n-1] = null\r\n        else .[0:n], (.[n:] | _takes)\r\n        end;\r\n      _takes;\r\n\r\nUsing &quot;takes&quot;, one could fulfill the task using: *[takes(2)]*\r\n\r\nUsing &quot;rho&quot;, there are several possibilities, notably:\r\n\r\n    [rho( [ 2 ] )]\r\n\r\n    # or:\r\n\r\n    rho([3,2]) \r\n\r\n\r\nFor more about &quot;rho&quot;, see https://github.com/stedolan/jq/issues/829",
                "title": "Most concise way to group pairs of elements in an array with jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1501790353,
                "creation_date": 1501790353,
                "answer_id": 45493531,
                "question_id": 31756953,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Perhaps not the most concise way but here is a solution using **foreach** to gather and emit pairs of values.\r\n\r\n    [\r\n      foreach .[] as $x (\r\n          []                                  # init\r\n        ; if length&gt;1 then [] else . end      # update\r\n          | . + [$x]\r\n        ; if length&gt;1 then  . else empty end  # extract\r\n      )\r\n    ]\r\n",
                "title": "Most concise way to group pairs of elements in an array with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 3,
        "last_activity_date": 1501790353,
        "creation_date": 1438388077,
        "question_id": 31756953,
        "body_markdown": "I want to convert\r\n\r\n    [1,&quot;a&quot;,2,&quot;b&quot;,3,&quot;c&quot;]\r\n\r\nto\r\n\r\n    [[1,&quot;a&quot;],[2,&quot;b&quot;],[3,&quot;c&quot;]]\r\n\r\nThe best I&#39;ve come up with is (using 1.5)\r\n\r\n    [recurse(.[2:];length&gt;1)[0:2]]\r\n\r\nIs there a more concise or more performant or 1.4 compatible solution I could use instead?",
        "link": "https://stackoverflow.com/questions/31756953/most-concise-way-to-group-pairs-of-elements-in-an-array-with-jq",
        "title": "Most concise way to group pairs of elements in an array with jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1438455503,
                "last_edit_date": 1438455503,
                "creation_date": 1438450345,
                "answer_id": 31764343,
                "question_id": 31764035,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Yes, you could use `from_entries`. In jq 1.5rc1 and above, it is defined as taking `Key`/`Value` key names as well as `key`/`value`.\r\n\r\nTry something like:\r\n\r\n`jq &#39;.Subnets | map({SubnetId} + (.Tags | from_entries))&#39;`\r\n\r\nOn previous versions, you could modify the &quot;entries&quot; before passing them to `from_entries`:\r\n\r\n`jq &#39;.Subnets | map({SubnetId} + (.Tags | map({value: .Value, key: .Key}) | from_entries))&#39;`",
                "title": "Transforming nested array of objects using jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1503683063,
                "creation_date": 1503683063,
                "answer_id": 45886909,
                "question_id": 31764035,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a solution which only uses jq primitives.\r\n\r\n    [\r\n      .Subnets[]\r\n    | {SubnetId} + (.Tags[] | if .Key==&quot;Name&quot; then {Name:.Value} else empty end)\r\n    ]",
                "title": "Transforming nested array of objects using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 3,
        "last_activity_date": 1504628833,
        "creation_date": 1438448231,
        "last_edit_date": 1592644375,
        "question_id": 31764035,
        "body_markdown": "How can I transform the JSON input\n\n    {\n    &quot;Subnets&quot;: [\n        {\n            &quot;VpcId&quot;: &quot;vpc-xxx&quot;,\n            &quot;Tags&quot;: [\n                {\n                    &quot;Value&quot;: &quot;staging_subnet_private_a&quot;,\n                    &quot;Key&quot;: &quot;Name&quot;\n                }\n            ],\n            &quot;SubnetId&quot;: &quot;subnet-xxx&quot;\n        },\n        ...\n        ]\n    }\n\nto\n\n    [\n     {\n      &quot;SubnetId&quot;: &quot;subnet-xxx&quot;,\n      &quot;Name&quot;: &quot;staging_subnet_private_a&quot;\n     },\n     ...\n    ]\nusing [jq][1]? \n\nI have a working solution using `jq &#39;[.Subnets[] | {SubnetId, Name: .Tags[0] | .Value }]&#39;`, but this relies on the order of Tags (not good).\n\nCould I use `from_entires` or reduce maybe?\n\n  [1]: http://stedolan.github.io/jq/",
        "link": "https://stackoverflow.com/questions/31764035/transforming-nested-array-of-objects-using-jq",
        "title": "Transforming nested array of objects using jq"
    },
    {
        "tags": [
            "amazon-ec2",
            "aws-cli",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1438743415,
                "last_edit_date": 1438743415,
                "creation_date": 1438707871,
                "answer_id": 31815239,
                "question_id": 31814464,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "With jq 1.5:\r\n\r\n    $ jq -cs &#39;from_entries | del(.[&quot;aws:autoscaling:groupName&quot;])&#39; \r\n\r\nWith jq 1.3 or 1.4:\r\n\r\n    $ jq -M -c -s &#39;reduce .[] as $x\r\n       ([]; . + [{&quot;key&quot; : $x.Key, &quot;value&quot;: $x.Value}])\r\n     | from_entries\r\n     | del(.[&quot;aws:autoscaling:groupName&quot;])&#39;\r\n\r\nOn Windows, you&#39;ll need to modify the quoting, or put the jq commands into a file.\r\n\r\n",
                "title": "jq to parse aws ec2 instance tags"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1461676125,
                "creation_date": 1461676125,
                "answer_id": 36865914,
                "question_id": 31814464,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "I think @peak&#39;s comment about `sed` is important enough to get a separate answer.\r\n\r\n`jq` version 1.4 and lower cannot work with Amazon&#39;s key/value pairs natively using `from_entries` because Amazon upper-cases keys while `jq` expects lower-case keys. The `jq` team [addressed this](https://github.com/stedolan/jq/issues/592) with version 1.5.\r\n\r\nTo get the your EC2 instances&#39; tags as `key: value` pairs, instead of `{key, value}` entries, use:\r\n\r\n    aws ... | \\\r\n      sed -e &#39;s/&quot;Key&quot;:/&quot;key&quot;:/g&#39; -e &#39;s/&quot;Value&quot;:/&quot;value&quot;:/g&#39; | \\\r\n      jq &#39;.Reservations[]|.Instances[]|.Tags|from_entries&#39;\r\n",
                "title": "jq to parse aws ec2 instance tags"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1461676125,
        "creation_date": 1438705433,
        "question_id": 31814464,
        "body_markdown": "I need to convert this output\r\n\r\n    $ aws ec2 describe-instances --instance-ids i-xxxxxxxx | jq -r &#39;.Reservations[].Instances[].Tags[]&#39; | jq -s &#39;from_entries | del(..|.[&quot;aws:autoscaling:groupName&quot;]?)&#39;\r\n\r\n    {\r\n      &quot;Key&quot;: &quot;ssh_user&quot;,\r\n      &quot;Value&quot;: &quot;abc&quot;\r\n    }\r\n    {\r\n      &quot;Key&quot;: &quot;ssh_port&quot;,\r\n      &quot;Value&quot;: &quot;2200&quot;\r\n    }\r\n    {\r\n      &quot;Key&quot;: &quot;aws:autoscaling:groupName&quot;,\r\n      &quot;Value&quot;: &quot;ASG-Api&quot;\r\n    }\r\n    {\r\n      &quot;Key&quot;: &quot;Name&quot;,\r\n      &quot;Value&quot;: &quot;SV-V3-API&quot;\r\n    }\r\n\r\n\r\ninto this one using jq:\r\n\r\n    {\r\n     &quot;ssh_user&quot;:&quot;abc&quot;,\r\n     &quot;ssh_port&quot;:&quot;2200&quot;,\r\n     &quot;Name&quot;:&quot;SV-V3-API&quot;\r\n    }\r\n\r\nNote that I need to delete this key: ***aws:autoscaling:groupName***\r\n",
        "link": "https://stackoverflow.com/questions/31814464/jq-to-parse-aws-ec2-instance-tags",
        "title": "jq to parse aws ec2 instance tags"
    },
    {
        "tags": [
            "amazon-web-services",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "user_type": "does_not_exist",
                    "display_name": "user3899165"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1438718683,
                "post_id": 31817450,
                "comment_id": 51561769,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 100740,
                    "reputation": 79490,
                    "user_id": 271415,
                    "user_type": "registered",
                    "accept_rate": 91,
                    "profile_image": "https://www.gravatar.com/avatar/8648256cc53b261c5e1d266380a256fc?s=256&d=identicon&r=PG",
                    "display_name": "jarmod",
                    "link": "https://stackoverflow.com/users/271415/jarmod"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1438724777,
                "post_id": 31817450,
                "comment_id": 51564779,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1438718230,
                "creation_date": 1438718230,
                "answer_id": 31818158,
                "question_id": 31817450,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Okay, I&#39;m not sure if I understood what you want. This is what I think you are asking for; please correct me if I&#39;m wrong:\r\n\r\n&gt; In each `Reservation`, I want the `Instances` inside to be sorted by the `Value` of the `Tag` whose `Key` is `&quot;Name&quot;`\r\n\r\nAnd this is what would solve that problem:\r\n\r\n`jq &#39;.Reservations[].Instances |= sort_by(.Tags[] | select(.Key == &quot;Name&quot;).Value)&#39;`\r\n\r\nAlternatively, you may be asking for this:\r\n\r\n&gt; I want the `Reservations` to be sorted by the `Value` of the `Tag` whose `Key` is `&quot;Name&quot;` inside the `Instances`.\r\n\r\nWhich would be solved by this:\r\n\r\n`jq &#39;.Reservations |= sort_by(.Instances[].Tags[] | select(.Key == &quot;Name&quot;).Value)&#39;`\r\n\r\n(The behavior of this script is probably meaningless if there are several `Instances` in a `Reservation`)\r\n\r\nAs of getting the private DNS values out, just select those with something like:\r\n\r\n`.Reservations[].Instances[].PrivateDnsName`\r\n\r\nYou can also pipe that after the sorting script.",
                "title": "Sort EC2 Instances by Tag Name"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1438718230,
        "creation_date": 1438715734,
        "question_id": 31817450,
        "body_markdown": "So I&#39;m using the aws cli to retrieve a list of instances in addition to the jq tool. I do so with the following command.\r\n\r\n    aws ec2 describe-instances | jq &#39;.Reservations[].Instances[]&#39;\r\n\r\nWith the following example json response.\r\n\r\n    {\r\n        &quot;Reservations&quot;: [\r\n            {\r\n                &quot;OwnerId&quot;: &quot;1234&quot;, \r\n                &quot;ReservationId&quot;: &quot;r-124991k&quot;, \r\n                &quot;Groups&quot;: [], \r\n                &quot;Instances&quot;: [\r\n                    {\r\n                        &quot;Monitoring&quot;: {\r\n                            &quot;State&quot;: &quot;disabled&quot;\r\n                        }, \r\n                        &quot;PublicDnsName&quot;: &quot;&quot;, \r\n                        &quot;State&quot;: {\r\n                            &quot;Code&quot;: 16, \r\n                            &quot;Name&quot;: &quot;running&quot;\r\n                        }, \r\n                        &quot;EbsOptimized&quot;: false, \r\n                        &quot;LaunchTime&quot;: &quot;2015-07-31T16:48:01.000Z&quot;, \r\n                        &quot;PrivateIpAddress&quot;: &quot;11.123.104.123&quot;, \r\n                        &quot;ProductCodes&quot;: [], \r\n                        &quot;VpcId&quot;: &quot;vpc-sdfsdf9109&quot;, \r\n                        &quot;StateTransitionReason&quot;: &quot;&quot;, \r\n                        &quot;InstanceId&quot;: &quot;i-1223421&quot;, \r\n                        &quot;ImageId&quot;: &quot;ami-aklasd131&quot;, \r\n                        &quot;PrivateDnsName&quot;: &quot;private.dns.name&quot;, \r\n                        &quot;KeyName&quot;: &quot;testkey&quot;, \r\n                        &quot;SecurityGroups&quot;: [\r\n                            {\r\n                                &quot;GroupName&quot;: &quot;secur-grou&quot;, \r\n                                &quot;GroupId&quot;: &quot;sg-a3d234a&quot;\r\n                            }\r\n                        ], \r\n                        &quot;ClientToken&quot;: &quot;&quot;, \r\n                        &quot;SubnetId&quot;: &quot;subnet-57absfsdf&quot;, \r\n                        &quot;InstanceType&quot;: &quot;m3.large&quot;, \r\n                        &quot;NetworkInterfaces&quot;: [\r\n                            {\r\n                                &quot;Status&quot;: &quot;in-use&quot;, \r\n                                &quot;MacAddress&quot;: &quot;12:c3:f2:5c:5f:4d&quot;, \r\n                                &quot;SourceDestCheck&quot;: false, \r\n                                &quot;VpcId&quot;: &quot;vpc-sdfsdf9109&quot;, \r\n                                &quot;Description&quot;: &quot;&quot;, \r\n                                &quot;NetworkInterfaceId&quot;: &quot;eni-81b1234&quot;, \r\n                                &quot;PrivateIpAddresses&quot;: [\r\n                                    {\r\n                                        &quot;Primary&quot;: true, \r\n                                        &quot;PrivateIpAddress&quot;: &quot;11.123.104.123&quot;\r\n                                    }\r\n                                ], \r\n                                &quot;Attachment&quot;: {\r\n                                    &quot;Status&quot;: &quot;attached&quot;, \r\n                                    &quot;DeviceIndex&quot;: 0, \r\n                                    &quot;DeleteOnTermination&quot;: true, \r\n                                    &quot;AttachmentId&quot;: &quot;eni-attach-5asdf234&quot;, \r\n                                    &quot;AttachTime&quot;: &quot;2015-07-30T16:10:39.000Z&quot;\r\n                                }, \r\n                                &quot;Groups&quot;: [\r\n                                    {\r\n                                        &quot;GroupName&quot;: &quot;secur-grou&quot;, \r\n                                        &quot;GroupId&quot;: &quot;sg-a3d234a&quot;\r\n                                    }\r\n                                ], \r\n                                &quot;SubnetId&quot;: &quot;subnet-57absfsdf&quot;, \r\n                                &quot;OwnerId&quot;: &quot;1234&quot;, \r\n                                &quot;PrivateIpAddress&quot;: &quot;11.123.104.123&quot;\r\n                            }\r\n                        ], \r\n                        &quot;SourceDestCheck&quot;: false, \r\n                        &quot;Placement&quot;: {\r\n                            &quot;Tenancy&quot;: &quot;default&quot;, \r\n                            &quot;GroupName&quot;: &quot;&quot;, \r\n                            &quot;AvailabilityZone&quot;: &quot;us-east-1c&quot;\r\n                        }, \r\n                        &quot;Hypervisor&quot;: &quot;xen&quot;, \r\n                        &quot;BlockDeviceMappings&quot;: [\r\n                            {\r\n                                &quot;DeviceName&quot;: &quot;/dev/sda1&quot;, \r\n                                &quot;Ebs&quot;: {\r\n                                    &quot;Status&quot;: &quot;attached&quot;, \r\n                                    &quot;DeleteOnTermination&quot;: true, \r\n                                    &quot;VolumeId&quot;: &quot;vol-28c882&quot;, \r\n                                    &quot;AttachTime&quot;: &quot;2015-07-30T16:10:43.000Z&quot;\r\n                                }\r\n                            }, \r\n                            {\r\n                                &quot;DeviceName&quot;: &quot;/dev/sdb&quot;, \r\n                                &quot;Ebs&quot;: {\r\n                                    &quot;Status&quot;: &quot;attached&quot;, \r\n                                    &quot;DeleteOnTermination&quot;: true, \r\n                                    &quot;VolumeId&quot;: &quot;vol-3f1d5&quot;, \r\n                                    &quot;AttachTime&quot;: &quot;2015-07-30T16:10:43.000Z&quot;\r\n                                }\r\n                            }, \r\n                            {\r\n                                &quot;DeviceName&quot;: &quot;/dev/sdg&quot;, \r\n                                &quot;Ebs&quot;: {\r\n                                    &quot;Status&quot;: &quot;attached&quot;, \r\n                                    &quot;DeleteOnTermination&quot;: true, \r\n                                    &quot;VolumeId&quot;: &quot;vol-81c8b&quot;, \r\n                                    &quot;AttachTime&quot;: &quot;2015-07-30T16:10:43.000Z&quot;\r\n                                }\r\n                            }\r\n                        ], \r\n                        &quot;Architecture&quot;: &quot;x86_64&quot;, \r\n                        &quot;RootDeviceType&quot;: &quot;ebs&quot;, \r\n                        &quot;RootDeviceName&quot;: &quot;/dev/sda1&quot;, \r\n                        &quot;VirtualizationType&quot;: &quot;hvm&quot;, \r\n                        &quot;Tags&quot;: [\r\n                            {\r\n                                &quot;Value&quot;: &quot;apple&quot;, \r\n                                &quot;Key&quot;: &quot;Name&quot;\r\n                            }, \r\n                            {\r\n                                &quot;Value&quot;: &quot;tag&quot;, \r\n                                &quot;Key&quot;: &quot;extra&quot;\r\n                            }\r\n                        ], \r\n                        &quot;AmiLaunchIndex&quot;: 0\r\n                    }\r\n                ]\r\n            }, \r\n            {\r\n                &quot;OwnerId&quot;: &quot;1234&quot;, \r\n                &quot;ReservationId&quot;: &quot;r-2a72342&quot;, \r\n                &quot;Groups&quot;: [], \r\n                &quot;Instances&quot;: [\r\n                    {\r\n                        &quot;Monitoring&quot;: {\r\n                            &quot;State&quot;: &quot;disabled&quot;\r\n                        }, \r\n                        &quot;PublicDnsName&quot;: &quot;&quot;, \r\n                        &quot;State&quot;: {\r\n                            &quot;Code&quot;: 16, \r\n                            &quot;Name&quot;: &quot;running&quot;\r\n                        }, \r\n                        &quot;EbsOptimized&quot;: false, \r\n                        &quot;LaunchTime&quot;: &quot;2015-07-31T16:48:01.000Z&quot;, \r\n                        &quot;PrivateIpAddress&quot;: &quot;11.123.104.83&quot;, \r\n                        &quot;ProductCodes&quot;: [], \r\n                        &quot;VpcId&quot;: &quot;vpc-sdfsdf9109&quot;, \r\n                        &quot;StateTransitionReason&quot;: &quot;&quot;, \r\n                        &quot;InstanceId&quot;: &quot;i-f9271451&quot;, \r\n                        &quot;ImageId&quot;: &quot;ami-aklasd131&quot;, \r\n                        &quot;PrivateDnsName&quot;: &quot;private.name.here&quot;, \r\n                        &quot;KeyName&quot;: &quot;testkey&quot;, \r\n                        &quot;SecurityGroups&quot;: [\r\n                            {\r\n                                &quot;GroupName&quot;: &quot;secur-grou&quot;, \r\n                                &quot;GroupId&quot;: &quot;sg-a3d234a&quot;\r\n                            }\r\n                        ], \r\n                        &quot;ClientToken&quot;: &quot;&quot;, \r\n                        &quot;SubnetId&quot;: &quot;subnet-5llqjwdf&quot;, \r\n                        &quot;InstanceType&quot;: &quot;m3.large&quot;, \r\n                        &quot;NetworkInterfaces&quot;: [\r\n                            {\r\n                                &quot;Status&quot;: &quot;in-use&quot;, \r\n                                &quot;MacAddress&quot;: &quot;12:ea:06:8b:ff:86&quot;, \r\n                                &quot;SourceDestCheck&quot;: false, \r\n                                &quot;VpcId&quot;: &quot;vpc-sdfsdf9109&quot;, \r\n                                &quot;Description&quot;: &quot;&quot;, \r\n                                &quot;NetworkInterfaceId&quot;: &quot;eni-82kjs91&quot;, \r\n                                &quot;PrivateIpAddresses&quot;: [\r\n                                    {\r\n                                        &quot;Primary&quot;: true, \r\n                                        &quot;PrivateIpAddress&quot;: &quot;11.123.104.13&quot;\r\n                                    }\r\n                                ], \r\n                                &quot;Attachment&quot;: {\r\n                                    &quot;Status&quot;: &quot;attached&quot;, \r\n                                    &quot;DeviceIndex&quot;: 0, \r\n                                    &quot;DeleteOnTermination&quot;: true, \r\n                                    &quot;AttachmentId&quot;: &quot;eni-attach-35312341&quot;, \r\n                                    &quot;AttachTime&quot;: &quot;2015-07-30T17:29:00.000Z&quot;\r\n                                }, \r\n                                &quot;Groups&quot;: [\r\n                                    {\r\n                                        &quot;GroupName&quot;: &quot;secur-grou&quot;, \r\n                                        &quot;GroupId&quot;: &quot;sg-a3d234a&quot;\r\n                                    }\r\n                                ], \r\n                                &quot;SubnetId&quot;: &quot;subnet-57absfsdf&quot;, \r\n                                &quot;OwnerId&quot;: &quot;1234&quot;, \r\n                                &quot;PrivateIpAddress&quot;: &quot;11.123.104.83&quot;\r\n                            }\r\n                        ], \r\n                        &quot;SourceDestCheck&quot;: false, \r\n                        &quot;Placement&quot;: {\r\n                            &quot;Tenancy&quot;: &quot;default&quot;, \r\n                            &quot;GroupName&quot;: &quot;&quot;, \r\n                            &quot;AvailabilityZone&quot;: &quot;us-east-1c&quot;\r\n                        }, \r\n                        &quot;Hypervisor&quot;: &quot;xen&quot;, \r\n                        &quot;BlockDeviceMappings&quot;: [\r\n                            {\r\n                                &quot;DeviceName&quot;: &quot;/dev/sda1&quot;, \r\n                                &quot;Ebs&quot;: {\r\n                                    &quot;Status&quot;: &quot;attached&quot;, \r\n                                    &quot;DeleteOnTermination&quot;: true, \r\n                                    &quot;VolumeId&quot;: &quot;vol-ee1c21&quot;, \r\n                                    &quot;AttachTime&quot;: &quot;2015-07-30T17:29:02.000Z&quot;\r\n                                }\r\n                            }, \r\n                            {\r\n                                &quot;DeviceName&quot;: &quot;/dev/sdb&quot;, \r\n                                &quot;Ebs&quot;: {\r\n                                    &quot;Status&quot;: &quot;attached&quot;, \r\n                                    &quot;DeleteOnTermination&quot;: true, \r\n                                    &quot;VolumeId&quot;: &quot;vol-13awer&quot;, \r\n                                    &quot;AttachTime&quot;: &quot;2015-07-30T17:29:02.000Z&quot;\r\n                                }\r\n                            }, \r\n                            {\r\n                                &quot;DeviceName&quot;: &quot;/dev/sdg&quot;, \r\n                                &quot;Ebs&quot;: {\r\n                                    &quot;Status&quot;: &quot;attached&quot;, \r\n                                    &quot;DeleteOnTermination&quot;: true, \r\n                                    &quot;VolumeId&quot;: &quot;vol-3111&quot;, \r\n                                    &quot;AttachTime&quot;: &quot;2015-07-30T17:29:02.000Z&quot;\r\n                                }\r\n                            }\r\n                        ], \r\n                        &quot;Architecture&quot;: &quot;x86_64&quot;, \r\n                        &quot;RootDeviceType&quot;: &quot;ebs&quot;, \r\n                        &quot;RootDeviceName&quot;: &quot;/dev/sda1&quot;, \r\n                        &quot;VirtualizationType&quot;: &quot;hvm&quot;, \r\n                        &quot;Tags&quot;: [\r\n                            {\r\n                                &quot;Value&quot;: &quot;banana&quot;, \r\n                                &quot;Key&quot;: &quot;Name&quot;\r\n                            }, \r\n                            {\r\n                                &quot;Value&quot;: &quot;tag&quot;, \r\n                                &quot;Key&quot;: &quot;extra&quot;\r\n                            }\r\n                        ], \r\n                        &quot;AmiLaunchIndex&quot;: 0\r\n                    }\r\n                ]\r\n            }\r\n        ]\r\n    }\r\n\r\nBut for the instances that are returned I would like them to be sorted by their Tag Name.  I&#39;ve tried the following.\r\n\r\n    jq &#39;.Reservations[]|=sort_by(.Instances[].Tags[.Key=&quot;Name&quot;].Value)&#39;\r\n\r\nBut jq complains with several error messages.  Is there an easy way to sort the json by Name tag and then get the PrivateDNS entry in that sorted order?",
        "link": "https://stackoverflow.com/questions/31817450/sort-ec2-instances-by-tag-name",
        "title": "Sort EC2 Instances by Tag Name"
    },
    {
        "tags": [
            "arrays",
            "json",
            "indexof",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1498966562,
                "last_edit_date": 1498966562,
                "creation_date": 1438798410,
                "answer_id": 31839892,
                "question_id": 31836961,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "    map(select(.tags | index(&quot;one&quot;)) | .id)\r\n\r\nSince your problem description indicates you want to check if the array contains &quot;one&quot;, it&#39;s simplest to use *index*.\r\n\r\n### UPDATE\r\n\r\nOn Jan 30, 2017, a builtin named `IN` was added for efficiently testing whether a JSON entity is contained in a stream. It can also be used for efficiently testing membership in an array. In the present case, the relevant usage would be:\r\n\r\n    map(select(.tags as $tags | &quot;one&quot; | IN($tags[])) | .id)\r\n\r\nIf your jq does not have `IN/1`, then so long as your jq has `first/1`, you can use this equivalent definition:\r\n\r\n    def IN(s): . as $in | first(if (s == $in) then true else empty end) // false;\r\n\r\n(In practice, `index/1` is usually fast enough, but its implementation currently (jq 1.5 and versions through at least July 2017) is suboptimal.)\r\n\r\n",
                "title": "Getting a list of keys based on another property in json with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1498966661,
        "creation_date": 1438789194,
        "last_edit_date": 1498966661,
        "question_id": 31836961,
        "body_markdown": "I&#39;m trying to create a jq filter for JSON, similar to https://stackoverflow.com/questions/26701538/how-to-filter-an-array-of-objects-based-on-values-in-an-inner-array-with-jq - but even using that as a basis doesn&#39;t seem to be giving me the results I want.\r\n\r\nHere&#39;s my example json\r\n\r\n    [{&quot;id&quot;:&quot;0001&quot;,&quot;tags&quot;:[&quot;one&quot;,&quot;two&quot;]},{&quot;id&quot;:&quot;0002&quot;, &quot;tags&quot;:[&quot;two&quot;]}]\r\n\r\nI want to return a list of IDs where tags contains &quot;one&quot; (not partial string match, full element match).\r\n\r\nI have tried some variations, but can&#39;t get the filter right.\r\n\r\n    . - map(select(.resources[] | contains(&quot;one&quot;))) | .[] .id\r\n\r\nReturns `&quot;0001&quot;,&quot;0002&quot;`\r\n\r\nHave also tried `... .resources[].one)) | ...` but always get full list when trying to filter by &quot;one&quot; and expecting to only get `0001`\r\n\r\nWhere am I filtering wrong? (have about 30 minutes experience with jq, so please excuse my ignorance if it&#39;s something obvious :)\r\n     \r\n ",
        "link": "https://stackoverflow.com/questions/31836961/getting-a-list-of-keys-based-on-another-property-in-json-with-jq",
        "title": "Getting a list of keys based on another property in json with jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1438986406,
                "creation_date": 1438986406,
                "answer_id": 31887509,
                "question_id": 31887253,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Since you&#39;re translating string values, you should be able to use a json object to hold the mappings.  Then mapping would be trivial.\r\n\r\n    $ jq --arg mapping &#39;{&quot;yes&quot;:&quot;10&quot;,&quot;no&quot;:&quot;0&quot;,&quot;maybe&quot;:&quot;5&quot;}&#39;\r\n        &#39;map(.value |= ($mapping | fromjson)[.])&#39; data.json",
                "title": "Value map with JQ"
            },
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1439096580,
                "last_edit_date": 1439096580,
                "creation_date": 1439012732,
                "answer_id": 31890081,
                "question_id": 31887253,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "If one wants to avoid having to specify the mapping on the command line, then the following two variants may be of interest.  \r\n\r\nThe first variant can be used with jq 1.3, jq 1.4 and jq 1.5:\r\n\r\n    def mapping: {&quot;yes&quot;:&quot;10&quot;,&quot;no&quot;:&quot;0&quot;,&quot;maybe&quot;:&quot;5&quot;};\r\n    map(.value |=  mapping[.])\r\n\r\nThe next variant uses the --argfile option (available since jq 1.4), and is of interest if the mapping object is available in a file:\r\n\r\n    jq --argfile mapping mapping.jq &#39;map(.value |= $mapping[.])&#39; data.json\r\n\r\nFinally, in jq 1.5, other alternatives based on *import* are also available (!).",
                "title": "Value map with JQ"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1503685057,
                "creation_date": 1503685057,
                "answer_id": 45887356,
                "question_id": 31887253,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a solution which uses an &quot;inline&quot; object since the mapping is small:\r\n\r\n    map(.value = {&quot;yes&quot;:&quot;10&quot;,&quot;no&quot;:&quot;0&quot;,&quot;maybe&quot;:&quot;5&quot;}[.value])\r\n\r\nwhich can be shorted with `|=` as in [peak](https://stackoverflow.com/users/997358/peak)&#39;s solution to:\r\n\r\n    map(.value |= {&quot;yes&quot;:&quot;10&quot;,&quot;no&quot;:&quot;0&quot;,&quot;maybe&quot;:&quot;5&quot;}[.])",
                "title": "Value map with JQ"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1720782009,
                "creation_date": 1720782009,
                "answer_id": 78739991,
                "question_id": 31887253,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "using a jq custom function to translate a value of an array of objects:\r\n\r\n```bash\r\njq &#39;def fnYN:\r\n  if   . == true  or . == &quot;true&quot;  then &quot;yes&quot;\r\n  elif . == false or . == &quot;false&quot; then &quot;no&quot;\r\n  else &quot;unknown&quot;\r\nend;\r\n. | map(.value |= fnYN)\r\n| [  .[] | { id, value }  ]\r\n&#39;\r\n```\r\n\r\ninput:\r\n\r\n```json\r\n[\r\n    {&quot;id&quot;:1, &quot;value&quot;:true},\r\n    {&quot;id&quot;:2, &quot;value&quot;:&quot;false&quot;},\r\n    {&quot;id&quot;:3, &quot;value&quot;:&quot;maybe&quot;}\r\n]\r\n```\r\n\r\nresult:\r\n\r\n```json\r\n[\r\n  {&quot;id&quot;: 1, &quot;value&quot;: &quot;yes&quot;},\r\n  {&quot;id&quot;: 2, &quot;value&quot;: &quot;no&quot;},\r\n  {&quot;id&quot;: 3, &quot;value&quot;: &quot;unknown&quot;}\r\n]\r\n```",
                "title": "Value map with JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": 4,
        "last_activity_date": 1720782009,
        "creation_date": 1438984776,
        "last_edit_date": 1504624433,
        "question_id": 31887253,
        "body_markdown": "I&#39;ve a large JSON file where I&#39;d like to transform some values based on some kind of mapping.\r\n\r\nThe data I have looks like:\r\n\r\n    [\r\n        {&quot;id&quot;:1, &quot;value&quot;:&quot;yes&quot;},\r\n        {&quot;id&quot;:2, &quot;value&quot;:&quot;no&quot;},\r\n        {&quot;id&quot;:3, &quot;value&quot;:&quot;maybe&quot;}\r\n    ]\r\n\r\nAnd I&#39;d like to transform that into a list like this:\r\n\r\n    [\r\n        {&quot;id&quot;:1, &quot;value&quot;:&quot;10&quot;},\r\n        {&quot;id&quot;:2, &quot;value&quot;:&quot;0&quot;},\r\n        {&quot;id&quot;:3, &quot;value&quot;:&quot;5&quot;}\r\n    ]\r\n\r\nWith the fixed mapping:\r\n\r\n    yes =&gt; 10\r\n    no =&gt; 0\r\n    maybe =&gt; 5\r\n\r\nMy current solution is based on a simple `if-elif-else` combination like this:\r\n\r\n    cat data.json| jq &#39;.data[] | .value = (if .value == &quot;yes&quot; then &quot;10&quot; elif .value == &quot;maybe&quot; then &quot;5&quot;  else &quot;0&quot; end)&#39;\r\n\r\nBut this is really ugly and I&#39;d love to have a more direct way to express the mapping.\r\n\r\nThanks for your help\r\n ",
        "link": "https://stackoverflow.com/questions/31887253/value-map-with-jq",
        "title": "Value map with JQ"
    },
    {
        "tags": [
            "csv",
            "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": 1439149202,
                "post_id": 31908071,
                "comment_id": 51730060,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 1938048,
                    "reputation": 207858,
                    "user_id": 1745001,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/99a3ebae89496eb16afe453aae97f5be?s=256&d=identicon&r=PG",
                    "display_name": "Ed Morton",
                    "link": "https://stackoverflow.com/users/1745001/ed-morton"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1439222803,
                "post_id": 31908071,
                "comment_id": 51761037,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1439149071,
                "creation_date": 1439149071,
                "answer_id": 31908119,
                "question_id": 31908071,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "If in this command...\r\n\r\n    awk -F&quot;,&quot; &#39;BEGIN { OFS = &quot;,&quot; }  ; {$6=$(date) OFS $6; print}&#39;\r\n\r\n...you are trying to assign to $6 the output of the `date` command, that won&#39;t work.  `$(command)` is Bourne shell syntax and won&#39;t work in `awk`.  The easiest way to do what you want is probably:\r\n\r\n    awk -v date=&quot;$(date)&quot; -F&quot;,&quot; &#39;BEGIN { OFS = &quot;,&quot; }  ; {$6=date; print}&#39;\r\n\r\nThis assigns the output of `date` to the `awk` variable `date`, which can then be used in your `awk` script.\r\n\r\nIf that&#39;s *not* what you&#39;re trying to do, please update your question to show both some sample input as well as an example of what you would like your output to look like.",
                "title": "Using AWK to add DATE to last column of CSV"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1439152288,
                "creation_date": 1439152288,
                "answer_id": 31908566,
                "question_id": 31908071,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "I know you asked for an Awk command, but since you&#39;re already using jq to generate the CSV file, you might as well do it there:\r\n\r\n```cat file.json | \r\njq --arg date &quot;$(date)&quot; -r &#39;\r\n    .pagedEntities._embedded.teamActivityList | \r\n    [.[].teamName, .[].rank, .[].average, .[].total, $date] | \r\n    @csv&#39;```\r\n\r\nThis also saves you from the pitfalls of using tools that don&#39;t understand the language they&#39;re dealing with, as is the case with Awk and CSV; as an example, your script will break if any of the CSV entries is quoted and has a comma in it.",
                "title": "Using AWK to add DATE to last column of CSV"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1503685846,
                "creation_date": 1503685846,
                "answer_id": 45887527,
                "question_id": 31908071,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a solution which builds on [Santiago](https://stackoverflow.com/users/3899165/santiago-lapresta)&#39;s approach but uses jq&#39;s **now** and **strftime** functions instead of using the unix `date` command.\r\n\r\n    jq -r &#39;\r\n         (now|strftime(&quot;%c&quot;)) as $date\r\n       | .pagedEntities._embedded.teamActivityList\r\n       | [.[].teamName, .[].rank, .[].average, .[].total, $date]\r\n       | @csv\r\n    &#39; file.json\r\n",
                "title": "Using AWK to add DATE to last column of CSV"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1503685846,
        "creation_date": 1439148795,
        "last_edit_date": 1439149095,
        "question_id": 31908071,
        "body_markdown": "As a total bash newbie, I&#39;m struggling to construct an AWK statement that prints the output as a DATE. Here is what I&#39;ve been trying. Any ideas on how to make the $6 = $date?\r\n\r\n    cat file.json | \r\n    jq -r &#39;.pagedEntities._embedded.teamActivityList | \r\n      [.[].teamName, .[].rank, .[].average, .[].total] | \r\n      @csv&#39; | \r\n    awk -F&quot;,&quot; &#39;BEGIN { OFS = &quot;,&quot; }  ; {$6=$(date) OFS $6; print}&#39;",
        "link": "https://stackoverflow.com/questions/31908071/using-awk-to-add-date-to-last-column-of-csv",
        "title": "Using AWK to add DATE to last column of CSV"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 40,
                "is_accepted": false,
                "score": 40,
                "last_activity_date": 1439193062,
                "creation_date": 1439193062,
                "answer_id": 31914251,
                "question_id": 31912454,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Use the `type` function:\r\n\r\n&gt; `type`  \r\n&gt; The type function returns the type of its argument as a string,\r\n&gt; which is one of null, boolean, number, string, array or object.\r\n\r\nExample 1:\r\n\r\n    echo &#39;[0, false, [], {}, null, &quot;hello&quot;]&#39; | jq &#39;map(type)&#39;\r\n    [\r\n      &quot;number&quot;,\r\n      &quot;boolean&quot;,\r\n      &quot;array&quot;,\r\n      &quot;object&quot;,\r\n      &quot;null&quot;,\r\n      &quot;string&quot;\r\n    ]\r\n\r\nExample 2:\r\n\r\n    echo &#39;[0,1]&#39; | jq &#39;if type==&quot;array&quot; then &quot;yes&quot; else &quot;no&quot; end&#39;\r\n    &quot;yes&quot;\r\n\r\nExample 3:\r\n\r\n    echo &#39;{&quot;0&quot;:0,&quot;1&quot;:1}&#39; | jq &#39;if type==&quot;array&quot; then &quot;yes&quot; else &quot;no&quot; end&#39;\r\n    &quot;no&quot;",
                "title": "How check if there is an array or an object in jq?"
            },
            {
                "up_vote_count": 18,
                "is_accepted": false,
                "score": 17,
                "last_activity_date": 1559522282,
                "last_edit_date": 1559522282,
                "creation_date": 1559513903,
                "answer_id": 56419345,
                "question_id": 31912454,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I have fields that are sometimes strings sometimes arrays and I want to iterate over them.   This handles this case:\r\n\r\n```\r\n... | if type==&quot;string&quot; then [.] else . end | .[] | ...\r\n```\r\n",
                "title": "How check if there is an array or an object in jq?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1726873485,
                "creation_date": 1726873485,
                "answer_id": 79008471,
                "question_id": 31912454,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "A more concise, but probably slightly slower:\r\n\r\n```javascript\r\n... | [.] | flatten(1) | ...\r\n```\r\nSo, if it&#39;s not an array, it now is. If it is, strip the layer off we just added\r\n\r\n",
                "title": "How check if there is an array or an object in jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 34,
        "last_activity_date": 1726873485,
        "creation_date": 1439186044,
        "question_id": 31912454,
        "body_markdown": "For example, I want to extract the values from a key, but that key sometimes contains an object (I mean just one value) or sometimes contains an array (i mean multiples values). HOw check if there is an array or there is an object? thanks.",
        "link": "https://stackoverflow.com/questions/31912454/how-check-if-there-is-an-array-or-an-object-in-jq",
        "title": "How check if there is an array or an object in jq?"
    },
    {
        "tags": [
            "json",
            "diff",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 54,
                "is_accepted": true,
                "score": 53,
                "last_activity_date": 1484843969,
                "last_edit_date": 1484843969,
                "creation_date": 1439267304,
                "answer_id": 31933234,
                "question_id": 31930041,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Since jq&#39;s comparison already compares objects without taking into account key ordering, all that&#39;s left is to sort all lists inside the object before comparing them. Assuming your two files are named `a.json` and `b.json`, on the latest jq nightly:\r\n\r\n    jq --argfile a a.json --argfile b b.json -n &#39;($a | (.. | arrays) |= sort) as $a | ($b | (.. | arrays) |= sort) as $b | $a == $b&#39;\r\n\r\nThis program should return &quot;true&quot; or &quot;false&quot; depending on whether or not the objects are equal using the definition of equality you ask for.\r\n\r\nEDIT: The `(.. | arrays) |= sort` construct doesn&#39;t actually work as expected on some edge cases. [This GitHub issue](https://github.com/stedolan/jq/issues/893) explains why and provides some alternatives, such as:\r\n\r\n    def post_recurse(f): def r: (f | select(. != null) | r), .; r; def post_recurse: post_recurse(.[]?); (post_recurse | arrays) |= sort\r\n\r\nApplied to the jq invocation above:\r\n\r\n    jq --argfile a a.json --argfile b b.json -n &#39;def post_recurse(f): def r: (f | select(. != null) | r), .; r; def post_recurse: post_recurse(.[]?); ($a | (post_recurse | arrays) |= sort) as $a | ($b | (post_recurse | arrays) |= sort) as $b | $a == $b&#39;",
                "title": "Using jq or alternative command line tools to compare JSON files"
            },
            {
                "up_vote_count": 8,
                "is_accepted": false,
                "score": 8,
                "last_activity_date": 1508240509,
                "last_edit_date": 1508240509,
                "creation_date": 1439276946,
                "answer_id": 31935351,
                "question_id": 31930041,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a solution using the generic function *walk/1*: \r\n\r\n    # Apply f to composite entities recursively, and to atoms\r\n    def walk(f):\r\n      . as $in\r\n      | if type == &quot;object&quot; then\r\n          reduce keys[] as $key\r\n            ( {}; . + { ($key):  ($in[$key] | walk(f)) } ) | f\r\n      elif type == &quot;array&quot; then map( walk(f) ) | f\r\n      else f\r\n      end;\r\n\r\n    def normalize: walk(if type == &quot;array&quot; then sort else . end);\r\n\r\n    # Test whether the input and argument are equivalent\r\n    # in the sense that ordering within lists is immaterial:\r\n    def equiv(x): normalize == (x | normalize);\r\n\r\n\r\nExample:\r\n\r\n    {&quot;a&quot;:[1,2,[3,4]]} | equiv( {&quot;a&quot;: [[4,3], 2,1]} )\r\n\r\nproduces:\r\n\r\n    true\r\n\r\nAnd wrapped up as a bash script:\r\n\r\n    #!/bin/bash\r\n    \r\n    JQ=/usr/local/bin/jq\r\n    BN=$(basename $0)\r\n    \r\n    function help {\r\n      cat &lt;&lt;EOF\r\n    \r\n    Syntax: $0 file1 file2\r\n    \r\n    The two files are assumed each to contain one JSON entity.  This\r\n    script reports whether the two entities are equivalent in the sense\r\n    that their normalized values are equal, where normalization of all\r\n    component arrays is achieved by recursively sorting them, innermost first.\r\n    \r\n    This script assumes that the jq of interest is $JQ if it exists and\r\n    otherwise that it is on the PATH.\r\n    \r\n    EOF\r\n      exit\r\n    }\r\n    \r\n    if [ ! -x &quot;$JQ&quot; ] ; then JQ=jq ; fi\r\n    \r\n    function die     { echo &quot;$BN: $@&quot; &gt;&amp;2 ; exit 1 ; }\r\n    \r\n    if [ $# != 2 -o &quot;$1&quot; = -h  -o &quot;$1&quot; = --help ] ; then help ; exit ; fi\r\n    \r\n    test -f &quot;$1&quot; || die &quot;unable to find $1&quot;\r\n    test -f &quot;$2&quot; || die &quot;unable to find $2&quot;\r\n    \r\n    $JQ -r -n --argfile A &quot;$1&quot; --argfile B &quot;$2&quot; -f &lt;(cat&lt;&lt;&quot;EOF&quot;\r\n    # Apply f to composite entities recursively, and to atoms\r\n    def walk(f):\r\n      . as $in\r\n      | if type == &quot;object&quot; then\r\n          reduce keys[] as $key\r\n            ( {}; . + { ($key):  ($in[$key] | walk(f)) } ) | f\r\n      elif type == &quot;array&quot; then map( walk(f) ) | f\r\n      else f\r\n      end;\r\n    \r\n    def normalize: walk(if type == &quot;array&quot; then sort else . end);\r\n    \r\n    # Test whether the input and argument are equivalent\r\n    # in the sense that ordering within lists is immaterial:\r\n    def equiv(x): normalize == (x | normalize);\r\n    \r\n    if $A | equiv($B) then empty else &quot;\\($A) is not equivalent to \\($B)&quot; end\r\n    \r\n    EOF\r\n    )\r\n\r\nPOSTSCRIPT: walk/1 is a built-in in versions of jq &gt; 1.5, and can therefore be omitted if your jq includes it, but there is no harm in including it redundantly in a jq script.\r\n\r\nPOST-POSTSCRIPT: The builtin version of `walk` has recently been changed so that it no longer sorts the keys within an object. Specifically, it uses `keys_unsorted`. For the task at hand, the version using `keys` should be used.\r\n",
                "title": "Using jq or alternative command line tools to compare JSON files"
            },
            {
                "up_vote_count": 292,
                "is_accepted": false,
                "score": 289,
                "last_activity_date": 1621293356,
                "last_edit_date": 1621293356,
                "creation_date": 1463014337,
                "answer_id": 37175540,
                "question_id": 31930041,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If your shell supports process substitution (Bash-style follows, see [docs][1]):\r\n\r\n    diff &lt;(jq --sort-keys . A.json) &lt;(jq --sort-keys . B.json)\r\n\r\nObjects key order will be ignored, but array order will still matter. It is possible to work-around that, if desired, by sorting array values in some other way, or making them set-like (e.g. `[&quot;foo&quot;, &quot;bar&quot;]` → `{&quot;foo&quot;: null, &quot;bar&quot;: null}`; this will also remove duplicates).\r\n\r\nAlternatively, substitute `diff` for some other comparator, e.g. `cmp`, `colordiff`, or `vimdiff`, depending on your needs. If all you want is a yes or no answer, consider using `cmp` and passing `--compact-output` to `jq` to not format the output for a potential small performance increase.\r\n\r\n  [1]: https://www.gnu.org/software/bash/manual/bash.html#Process-Substitution",
                "title": "Using jq or alternative command line tools to compare JSON files"
            },
            {
                "up_vote_count": 125,
                "is_accepted": false,
                "score": 123,
                "last_activity_date": 1480996416,
                "last_edit_date": 1480996416,
                "creation_date": 1480972695,
                "answer_id": 40983522,
                "question_id": 31930041,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Use [`jd`](https://github.com/josephburnett/jd#command-line-usage) with the `-set` option:\r\n\r\nNo output means no difference.\r\n\r\n    $ jd -set A.json B.json\r\n\r\nDifferences are shown as an @ path and + or -.\r\n\r\n    $ jd -set A.json C.json\r\n    \r\n    @ [&quot;People&quot;,{}]\r\n    + &quot;Carla&quot;\r\n\r\nThe output diffs can also be used as patch files with the `-p` option.\r\n\r\n    $ jd -set -o patch A.json C.json; jd -set -p patch B.json\r\n    \r\n    {&quot;City&quot;:&quot;Boston&quot;,&quot;People&quot;:[&quot;John&quot;,&quot;Carla&quot;,&quot;Bryan&quot;],&quot;State&quot;:&quot;MA&quot;}\r\n\r\nhttps://github.com/josephburnett/jd#command-line-usage",
                "title": "Using jq or alternative command line tools to compare JSON files"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1538807698,
                "creation_date": 1538807698,
                "answer_id": 52676356,
                "question_id": 31930041,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Perhaps you could use this sort and diff tool: http://novicelab.org/jsonsortdiff/ which first sorts the objects semantically and then compares it. It is based on https://www.npmjs.com/package/jsonabc",
                "title": "Using jq or alternative command line tools to compare JSON files"
            },
            {
                "up_vote_count": 15,
                "is_accepted": false,
                "score": 15,
                "last_activity_date": 1567632000,
                "creation_date": 1567632000,
                "answer_id": 57795761,
                "question_id": 31930041,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Pulling in the best from the top two answers to get a `jq` based json diff:\r\n\r\n```\r\ndiff \\\r\n  &lt;(jq -S &#39;def post_recurse(f): def r: (f | select(. != null) | r), .; r; def post_recurse: post_recurse(.[]?); (. | (post_recurse | arrays) |= sort)&#39; &quot;$original_json&quot;) \\\r\n  &lt;(jq -S &#39;def post_recurse(f): def r: (f | select(. != null) | r), .; r; def post_recurse: post_recurse(.[]?); (. | (post_recurse | arrays) |= sort)&#39; &quot;$changed_json&quot;)\r\n```\r\n\r\nThis takes the elegant array sorting solution from https://stackoverflow.com/a/31933234/538507 (which allows us to treat arrays as sets) and the clean bash redirection into `diff` from https://stackoverflow.com/a/37175540/538507 This addresses the case where you want a diff of two json files and the order of the array contents is not relevant.",
                "title": "Using jq or alternative command line tools to compare JSON files"
            },
            {
                "up_vote_count": 11,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1572867477,
                "creation_date": 1572867477,
                "answer_id": 58692653,
                "question_id": 31930041,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "There&#39;s an answer for this [here](https://stackoverflow.com/a/17194704/3029403) that would be useful. \r\n\r\nEssentially you can use the Git `diff` functionality (even for non-Git tracked files) which also includes colour in the output:\r\n\r\n`git diff --no-index payload_1.json payload_2.json`",
                "title": "Using jq or alternative command line tools to compare JSON files"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1575999492,
                "creation_date": 1575999492,
                "answer_id": 59272710,
                "question_id": 31930041,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "One more tool for those to which the previous answers are not a good fit, you can try [jdd][1].\r\n\r\nIt&#39;s HTML based so you can either use it online at [www.jsondiff.com][2] or, if you prefer running it locally, just download the project and open the index.html.\r\n\r\n\r\n\r\n\r\n  [1]: https://github.com/zgrossbart/jdd\r\n  [2]: http://www.jsondiff.com/",
                "title": "Using jq or alternative command line tools to compare JSON files"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1630688292,
                "creation_date": 1630688292,
                "answer_id": 69048391,
                "question_id": 31930041,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "In [JSONiq][1], you can simply use the deep-equal function:\r\n\r\n    deep-equal(\r\n      {\r\n        &quot;People&quot;: [&quot;John&quot;, &quot;Bryan&quot;, &quot;Carla&quot;],\r\n        &quot;City&quot;: &quot;Boston&quot;,\r\n        &quot;State&quot;: &quot;MA&quot;\r\n      },\r\n      {\r\n        &quot;People&quot;: [&quot;Bryan&quot;, &quot;John&quot;],\r\n        &quot;State&quot;: &quot;MA&quot;,\r\n        &quot;City&quot;: &quot;Boston&quot;\r\n      }\r\n    )\r\n\r\nwhich returns\r\n\r\n    false\r\n    \r\nYou can also read from files (locally or an HTTP URL also works) like so:\r\n\r\n    deep-equal(\r\n      json-doc(&quot;path to doc A.json&quot;),\r\n      json-doc(&quot;path to doc B.json&quot;)\r\n    )\r\n\r\nA possible implementation is [RumbleDB][2].\r\n\r\nHowever, you need to be aware that it is not quite correct that the first two documents are the same: [JSON][4] defines arrays as ordered lists of values.\r\n\r\n    [&quot;Bryan&quot;, &quot;John&quot;]\r\n\r\nis not the same as:\r\n\r\n    [&quot;John&quot;, &quot;Bryan&quot;]\r\n\r\n  [1]: https://jsoniq.org\r\n  [2]: https://rumbledb.org/\r\n  [3]: https://zorba.io\r\n  [4]: https://json.org",
                "title": "Using jq or alternative command line tools to compare JSON files"
            }
        ],
        "is_answered": true,
        "answer_count": 9,
        "score": 211,
        "last_activity_date": 1739024298,
        "creation_date": 1439244684,
        "last_edit_date": 1556484711,
        "question_id": 31930041,
        "body_markdown": "Are there any command line utilities that can be used to find if two JSON files are identical with invariance to within-dictionary-key and within-list-element ordering?\r\n\r\nCould this be done with [`jq`][1] or some other equivalent tool?\r\n\r\n## Examples:\r\n\r\nThese two JSON files are identical\r\n\r\n`A`:\r\n\r\n    {\r\n      &quot;People&quot;: [&quot;John&quot;, &quot;Bryan&quot;],\r\n      &quot;City&quot;: &quot;Boston&quot;,\r\n      &quot;State&quot;: &quot;MA&quot;\r\n    }\r\n`B`:\r\n\r\n    {\r\n      &quot;People&quot;: [&quot;Bryan&quot;, &quot;John&quot;],\r\n      &quot;State&quot;: &quot;MA&quot;,\r\n      &quot;City&quot;: &quot;Boston&quot;\r\n    }\r\n\r\nbut these two JSON files are different:\r\n\r\n`A`:\r\n\r\n    {\r\n      &quot;People&quot;: [&quot;John&quot;, &quot;Bryan&quot;, &quot;Carla&quot;],\r\n      &quot;City&quot;: &quot;Boston&quot;,\r\n      &quot;State&quot;: &quot;MA&quot;\r\n    }\r\n`C`:\r\n\r\n    {\r\n      &quot;People&quot;: [&quot;Bryan&quot;, &quot;John&quot;],\r\n      &quot;State&quot;: &quot;MA&quot;,\r\n      &quot;City&quot;: &quot;Boston&quot;\r\n    }\r\n\r\nThat would be:\r\n\r\n    $ some_diff_command A.json B.json\r\n\r\n    $ some_diff_command A.json C.json\r\n    The files are not structurally identical\r\n\r\n\r\n  [1]: http://stedolan.github.io/jq/",
        "link": "https://stackoverflow.com/questions/31930041/using-jq-or-alternative-command-line-tools-to-compare-json-files",
        "title": "Using jq or alternative command line tools to compare JSON files"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1439290367,
                "creation_date": 1439290367,
                "answer_id": 31939819,
                "question_id": 31935170,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "I&#39;m not sure I understand the question, but I think you want to do a boolean `or` of the results you get with your existing jq program. This is how you&#39;d do it:\r\n\r\n`jq &#39;[.result[].downlaodable or .result[].playable] | any&#39;`\r\n\r\nThis should just output: `true`",
                "title": "Combine all boolean response of JSON objects to one with Jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1439290367,
        "creation_date": 1439276403,
        "last_edit_date": 1439280030,
        "question_id": 31935170,
        "body_markdown": "i have huge json data, in every object has download_able and playable attribute which is boolean type. \r\n\r\nSo i try to compare each other every objects attribute and get only one response.\r\n\r\n`jq &#39;.result[].downlaodable or .result[].playable&#39;` response me like that\r\n\r\n    true\r\n    true\r\n    true\r\n\r\nI want to compare these response again and i have to get one response. \r\n\r\nBut i can&#39;t do that. How can i do that? ",
        "link": "https://stackoverflow.com/questions/31935170/combine-all-boolean-response-of-json-objects-to-one-with-jq",
        "title": "Combine all boolean response of JSON objects to one with Jq"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 57200,
                    "reputation": 158728,
                    "user_id": 171318,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/ePRKy.jpg?s=256",
                    "display_name": "hek2mgl",
                    "link": "https://stackoverflow.com/users/171318/hek2mgl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1439397140,
                "post_id": 31969719,
                "comment_id": 51848537,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 1603076,
                    "reputation": 63,
                    "user_id": 1483747,
                    "user_type": "registered",
                    "accept_rate": 20,
                    "profile_image": "https://www.gravatar.com/avatar/bf0a2deee8065f3ffa39f2cb5d6d5d02?s=256&d=identicon&r=PG",
                    "display_name": "user1483747",
                    "link": "https://stackoverflow.com/users/1483747/user1483747"
                },
                "reply_to_user": {
                    "account_id": 57200,
                    "reputation": 158728,
                    "user_id": 171318,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/ePRKy.jpg?s=256",
                    "display_name": "hek2mgl",
                    "link": "https://stackoverflow.com/users/171318/hek2mgl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1439397489,
                "post_id": 31969719,
                "comment_id": 51848733,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 57200,
                    "reputation": 158728,
                    "user_id": 171318,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/ePRKy.jpg?s=256",
                    "display_name": "hek2mgl",
                    "link": "https://stackoverflow.com/users/171318/hek2mgl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1439397891,
                "post_id": 31969719,
                "comment_id": 51848976,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 1603076,
                    "reputation": 63,
                    "user_id": 1483747,
                    "user_type": "registered",
                    "accept_rate": 20,
                    "profile_image": "https://www.gravatar.com/avatar/bf0a2deee8065f3ffa39f2cb5d6d5d02?s=256&d=identicon&r=PG",
                    "display_name": "user1483747",
                    "link": "https://stackoverflow.com/users/1483747/user1483747"
                },
                "reply_to_user": {
                    "account_id": 57200,
                    "reputation": 158728,
                    "user_id": 171318,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/ePRKy.jpg?s=256",
                    "display_name": "hek2mgl",
                    "link": "https://stackoverflow.com/users/171318/hek2mgl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1439399950,
                "post_id": 31969719,
                "comment_id": 51850132,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": -1,
                "last_activity_date": 1439416118,
                "last_edit_date": 1439416118,
                "creation_date": 1439401656,
                "answer_id": 31972070,
                "question_id": 31969719,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You should use the following syntax:\r\n\r\n    array[$i]=$(cat json.txt | jq &#39;.children[&#39;${i}&#39;]&#39;)\r\n\r\n",
                "title": "How to do parse json array dynamically in shell script using jq too in shell script"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1439401734,
                "creation_date": 1439401734,
                "answer_id": 31972099,
                "question_id": 31969719,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You&#39;re using single quotes around the jq program. Shells do not interpolate variables inside single quotes; this is intentional and the jq manual recommends using single quotes around programs for this reason.\r\n\r\nAn argument syntax is provided by jq for this purpose. This syntax allows you to set jq variables to the value of shell variables. You could replace your current jq invocation with this:\r\n\r\n`array[$i]=$(cat json.txt | jq --arg i $i &#39;.children[$i | tonumber]&#39;)`",
                "title": "How to do parse json array dynamically in shell script using jq too in shell script"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1439404024,
                "creation_date": 1439404024,
                "answer_id": 31972746,
                "question_id": 31969719,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "It looks like you&#39;re just trying to set the children to a bash array variable.\r\n\r\nYou don&#39;t need to loop, just set the array directly.\r\n\r\n    $ IFS=$&#39;\\n&#39;; array=($(jq -c &#39;.children[]&#39; json.txt))",
                "title": "How to do parse json array dynamically in shell script using jq too in shell script"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1439416118,
        "creation_date": 1439393709,
        "last_edit_date": 1439396978,
        "question_id": 31969719,
        "body_markdown": "Suppose I have the following json in a file json.txt\r\n\r\n    {\r\n      &quot;first_name&quot;: &quot;John&quot;,\r\n      &quot;last_name&quot;: &quot;Smith&quot;,\r\n      &quot;things_carried&quot;: [\r\n        &quot;apples&quot;,\r\n        &quot;hat&quot;,\r\n        &quot;harmonica&quot;\r\n      ],\r\n      &quot;children&quot;: [\r\n        {\r\n          &quot;first_name&quot;: &quot;Bobby Sue&quot;,\r\n          &quot;last_name&quot;: &quot;Smith&quot;\r\n        },\r\n        {\r\n          &quot;first_name&quot;: &quot;John Jr&quot;,\r\n          &quot;last_name&quot;: &quot;Smith&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\nIn shell script I had written the logic to find the size of children array using jq tool .\r\n\r\n    size=cat json.txt | jq &#39;.children | length&#39;    \r\n    i=0\r\n\r\n    while [ $i -le $size ]    \r\n    do\r\n        array[$i]=$(cat json.txt | jq &#39;.children[$i]&#39;)\r\n        i=`expr $i + 1`\r\n    done\r\n\r\nOn running this it gives the following error - \r\n\r\n    .children[$i]          1 compile error\r\n\r\nIt seems that it is not able to replace the variable i in the children[] array , as because if we give the expression -\r\n\r\n    array[$i]=$(cat json.txt | jq &#39;.children[0]&#39;) \r\n\r\nit runs well .\r\n\r\nCan someone help me .\r\n\r\n\r\n \r\n",
        "link": "https://stackoverflow.com/questions/31969719/how-to-do-parse-json-array-dynamically-in-shell-script-using-jq-too-in-shell-scr",
        "title": "How to do parse json array dynamically in shell script using jq too in shell script"
    },
    {
        "tags": [
            "json",
            "environment-variables",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 16,
                "is_accepted": false,
                "score": 16,
                "last_activity_date": 1439427152,
                "last_edit_date": 1439427152,
                "creation_date": 1439421096,
                "answer_id": 31976939,
                "question_id": 31976186,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "This works for me:\r\n\r\n    python -c &#39;import json, os;print(json.dumps(dict(os.environ)))&#39;\r\n\r\nIt&#39;s pretty simple; the main complication is that `os.environ` is a dict-like object, but it is not actually a dict, so you have to convert it to a dict before you feed it to the json serializer.\r\n\r\nAdding parentheses around the print statement lets it work in both Python 2 and 3, so it should work for the forseeable future on most *nix systems (especially since Python comes by default on any major distro).",
                "title": "Output UNIX environment as JSON"
            },
            {
                "up_vote_count": 33,
                "is_accepted": true,
                "score": 33,
                "last_activity_date": 1439431669,
                "creation_date": 1439431669,
                "answer_id": 31978374,
                "question_id": 31976186,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Using jq 1.5 (e.g. jq 1.5rc2 -- see http://stedolan.github.io/jq):\r\n\r\n    $ jq -n env\r\n\r\n",
                "title": "Output UNIX environment as JSON"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1674069851,
                "creation_date": 1674069851,
                "answer_id": 75164317,
                "question_id": 31976186,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "@Alexander Trauzzi asked: &quot;Wondering if anyone knows how to do this, but only passing a subset of the current environment&#39;s variables?&quot;\r\n\r\nI just found the way to do this:\r\n```bash\r\njq -n &#39;env | {USER, HOME, PS1}&#39;\r\n```",
                "title": "Output UNIX environment as JSON"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 17,
        "last_activity_date": 1674069851,
        "creation_date": 1439417018,
        "last_edit_date": 1439530752,
        "question_id": 31976186,
        "body_markdown": "I&#39;d like a unix one-liner that will output the current execution environment as a JSON structure like: { &quot;env-var&quot; : &quot;env-value&quot;, ... etc ... }\r\n\r\nThis kinda works:\r\n\r\n    (echo &quot;{&quot;; printenv | sed &#39;s/\\&quot;/\\\\\\&quot;/g&#39; | sed -n &#39;s|\\(.*\\)=\\(.*\\)|&quot;\\1&quot;=&quot;\\2&quot;|p&#39; | grep -v &#39;^$&#39; | paste -s -d&quot;,&quot; -; echo &quot;}&quot;)\r\n\r\nbut has some extra lines and I think won&#39;t work if the environment values or variables have &#39;=&#39; or newlines in them.\r\n\r\nWould prefer pure bash/sh, but compact python / perl / ruby / etc one-liners would also be appreciated.\r\n",
        "link": "https://stackoverflow.com/questions/31976186/output-unix-environment-as-json",
        "title": "Output UNIX environment as JSON"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1439448827,
                "creation_date": 1439448827,
                "answer_id": 31981400,
                "question_id": 31981270,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Change your filter to generate the results once.\r\n\r\n    .result[] | .downloadable or .playable",
                "title": "For loop for every object Jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1439448854,
        "creation_date": 1439448402,
        "last_edit_date": 1439448854,
        "question_id": 31981270,
        "body_markdown": "I&#39;m trying to compare two attributes on every object. This is the code i use for this problem:\r\n\r\n`(.result[].downlaodable or .result[].playable)` but this time jq does cartesian product. If i have 3 object, jq turns me 9 object.\r\n\r\nI have to convert it to something like this:  \r\n`(.result[1].downlaodable or .result[1].playable)`\r\n`(.result[2].downlaodable or .result[2].playable)`\r\n`(.result[3].downlaodable or .result[3].playable)`\r\n\r\nHow can i do that?",
        "link": "https://stackoverflow.com/questions/31981270/for-loop-for-every-object-jq",
        "title": "For loop for every object Jq"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1440000760,
                "last_edit_date": 1440000760,
                "creation_date": 1439965866,
                "answer_id": 32088048,
                "question_id": 32086615,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "I removed the extra pair of brackets around your JSON object in order to make it a valid JSON. So, starting with this:\r\n\r\n    {\r\n      &quot;key1&quot;: [ &quot;value1&quot;, &quot;value2&quot; ],\r\n      &quot;key2&quot;: [ &quot;value3&quot; ]\r\n    }\r\n\r\nWe apply `to_entries`, which gives us this:\r\n\r\n    [\r\n      {\r\n        &quot;key&quot;: &quot;key1&quot;,\r\n        &quot;value&quot;: [ &quot;value1&quot;, &quot;value2&quot; ]\r\n      },\r\n      {\r\n        &quot;key&quot;: &quot;key2&quot;,\r\n        &quot;value&quot;: [ &quot;value3&quot; ]\r\n      }\r\n    ]\r\n\r\nThen, we `map` each of those entries and we spread (`[]`) the `.value` array, creating a separate object for each of its elements (`map({key, value: .value[]})`). This gives us:\r\n\r\n    [\r\n      {\r\n        &quot;key&quot;: &quot;key1&quot;,\r\n        &quot;value&quot;: &quot;value1&quot;\r\n      },\r\n      {\r\n        &quot;key&quot;: &quot;key1&quot;,\r\n        &quot;value&quot;: &quot;value2&quot;\r\n      },\r\n      {\r\n        &quot;key&quot;: &quot;key2&quot;,\r\n        &quot;value&quot;: &quot;value3&quot;\r\n      }\r\n    ]\r\n\r\nAfter that, for each of those objects, we want an array with its values, since that&#39;s what the `@csv` filter expects. That&#39;s just mapping to an array object, as in `map([.key, .value])`, which gives us:\r\n\r\n    [\r\n      [ &quot;key1&quot;, &quot;value1&quot; ],\r\n      [ &quot;key1&quot;, &quot;value2&quot; ],\r\n      [ &quot;key2&quot;, &quot;value3&quot; ]\r\n    ]\r\n\r\nAnd, finally, we spread (`[]`) the array of arrays (since `@csv` expects individual arrays) and we pipe `@csv` to it. The full script looks as follows:\r\n\r\n    jq -r &#39;to_entries | map({key, value: .value[]}) | map([.key, .value])[] | @csv&#39; test.json\r\n\r\nAnd its output:\r\n\r\n    &quot;key1&quot;,&quot;value1&quot;  \r\n    &quot;key1&quot;,&quot;value2&quot;  \r\n    &quot;key2&quot;,&quot;value3&quot;\r\n\r\n\r\n",
                "title": "Converting json map to csv using jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1439973771,
                "last_edit_date": 1439973771,
                "creation_date": 1439973130,
                "answer_id": 32090357,
                "question_id": 32086615,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You can skip a few steps building up the rows.\r\n\r\n    $ jq -r &#39;to_entries[] | { key, value: .value[] } | [ .key, .value ] | @csv&#39;\r\n\r\nIn jq 1.5, you can utilize the new `combinations` filter to generate combinations of the keys and values.\r\n\r\n    $ jq -r &#39;to_entries[] | [ [.key], .value ] | combinations | @csv&#39;",
                "title": "Converting json map to csv using jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1501792502,
                "creation_date": 1501792502,
                "answer_id": 45494058,
                "question_id": 32086615,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a short solution using just jq&#39;s `[]` operator and `\\()` string interpolation.  Use along with the jq `-r` flag to avoid extra quotes in final output.\r\n\r\n      . as $v\r\n    | keys[]\r\n    | &quot;\\(.), \\($v[.][])&quot;\r\n",
                "title": "Converting json map to csv using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 2,
        "last_activity_date": 1501792502,
        "creation_date": 1439958726,
        "last_edit_date": 1440143566,
        "question_id": 32086615,
        "body_markdown": "input\r\n\r\n    {&quot;key1&quot;: [&quot;value1&quot;, &quot;value2&quot;], &quot;key2&quot;: [&quot;value3&quot;]}\r\n\r\n\r\nDesired output\r\n\r\n    key1, value1\r\n    key1, value2\r\n    key2, value3\r\n\r\nHaving a hard time figuring out jq command to achieve this... I have tried map, as, to_entries filters in various combinations but no luck.",
        "link": "https://stackoverflow.com/questions/32086615/converting-json-map-to-csv-using-jq",
        "title": "Converting json map to csv using jq"
    },
    {
        "tags": [
            "json",
            "linux",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 94756,
                    "reputation": 81440,
                    "user_id": 258523,
                    "user_type": "registered",
                    "accept_rate": 83,
                    "profile_image": "https://www.gravatar.com/avatar/f2c517550a86045c885bc36eca722b9d?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Etan Reisner",
                    "link": "https://stackoverflow.com/users/258523/etan-reisner"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1440095415,
                "post_id": 32125603,
                "comment_id": 52142976,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 28375,
                    "reputation": 1295,
                    "user_id": 75772,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://i.sstatic.net/r7Egf.jpg?s=256",
                    "display_name": "Ryan Bolger",
                    "link": "https://stackoverflow.com/users/75772/ryan-bolger"
                },
                "reply_to_user": {
                    "account_id": 94756,
                    "reputation": 81440,
                    "user_id": 258523,
                    "user_type": "registered",
                    "accept_rate": 83,
                    "profile_image": "https://www.gravatar.com/avatar/f2c517550a86045c885bc36eca722b9d?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Etan Reisner",
                    "link": "https://stackoverflow.com/users/258523/etan-reisner"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1440096143,
                "post_id": 32125603,
                "comment_id": 52143409,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 94756,
                    "reputation": 81440,
                    "user_id": 258523,
                    "user_type": "registered",
                    "accept_rate": 83,
                    "profile_image": "https://www.gravatar.com/avatar/f2c517550a86045c885bc36eca722b9d?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Etan Reisner",
                    "link": "https://stackoverflow.com/users/258523/etan-reisner"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1440096232,
                "post_id": 32125603,
                "comment_id": 52143461,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1440096663,
                "last_edit_date": 1440096663,
                "creation_date": 1440096138,
                "answer_id": 32125945,
                "question_id": 32125603,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Instead of calling `jq` again on each array element, just fetch the name with the first call that feeds the loop.\r\n\r\n     while read -r job; do\r\n         echo &quot;$job&quot;\r\n     done &lt; &lt;(jq -c &#39;.[].name&#39; &lt; jobs)\r\n\r\n(and use `read -r` as suggested by Etan).\r\n\r\n---\r\n\r\nIf you need multiple variables, try (for example)\r\n\r\n    while read -r id\r\n          read -r job; do\r\n        echo &quot;$id: $job&quot;\r\n    done &lt; &lt;(jq -c &#39;.[]|.id,.name&#39; &lt; jobs)",
                "title": "Processing json array with jq and quoted values"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1455326113,
                "last_edit_date": 1455326113,
                "creation_date": 1455324815,
                "answer_id": 35374720,
                "question_id": 32125603,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "This can be done in one line\r\n\r\nTo review, the json file content (file name is jobs):    \r\n`[\r\n  {\r\n    &quot;id&quot;: &quot;1a-2b&quot;,\r\n    &quot;name&quot;: &quot;my job name&quot;,\r\n    &quot;description&quot;: &quot;my job description&quot;\r\n  },\r\n  {\r\n    &quot;id&quot;: &quot;3c-4d&quot;,\r\n    &quot;name&quot;: &quot;my \\&quot;quoted\\&quot; job name&quot;,\r\n    &quot;description&quot;: &quot;my \\&quot;quoted\\&quot; job description&quot;\r\n  }\r\n]`\r\n\r\njq one liner `jq &#39;.[] | (.name)&#39; jobs`\r\n\r\nAnd the output:\r\n\r\n`&quot;my job name&quot;\r\n&quot;my \\&quot;quoted\\&quot; job name&quot;`",
                "title": "Processing json array with jq and quoted values"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1455326113,
        "creation_date": 1440094975,
        "question_id": 32125603,
        "body_markdown": "I&#39;m attempting to write a script that does some processing on an array of json objects.  A simplified version of the source json looks like this. Note the escaped double quotes in the second object.\r\n\r\n    [\r\n      {\r\n        &quot;id&quot;: &quot;1a-2b&quot;,\r\n        &quot;name&quot;: &quot;my job name&quot;,\r\n        &quot;description&quot;: &quot;my job description&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: &quot;3c-4d&quot;,\r\n        &quot;name&quot;: &quot;my \\&quot;quoted\\&quot; job name&quot;,\r\n        &quot;description&quot;: &quot;my \\&quot;quoted\\&quot; job description&quot;\r\n      }\r\n    ]\r\n\r\nMy script currently attempts to iterate through the source using a &#39;while read&#39; idiom I found elsewhere in my searches that looks like this.\r\n\r\n    while read job; do\r\n\r\n      # fetch individual values into variables\r\n      jobname=`echo $job | jq -r &#39;.name&#39;`\r\n\r\n      # do processing on the individual values\r\n      echo $jobname\r\n\r\n    done &lt; &lt;(cat jobs | jq -c &#39;.[]&#39;)\r\n\r\nThe problem seems to be that the escaped quotes get unescaped in the compact output and subsequently the $job variable.  So when I reprocess the individual object with jq inside the loop, I get a jq parse error on each object that has quoted values.\r\n\r\nI&#39;m currently using jq 1.4 and I&#39;ve been trying various combinations of tojson/fromjson/@sh/tostring, but haven&#39;t found the right combination yet.  I&#39;m not opposed to moving to jq 1.5 if it has a feature that will make this easier.  I&#39;m also not married to the &#39;while read&#39; idiom if there is a smarter way to do what I&#39;m trying to do.",
        "link": "https://stackoverflow.com/questions/32125603/processing-json-array-with-jq-and-quoted-values",
        "title": "Processing json array with jq and quoted values"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6663049,
                    "reputation": 225,
                    "user_id": 5141502,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/gremL.jpg?s=256",
                    "display_name": "brian",
                    "link": "https://stackoverflow.com/users/5141502/brian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1440350781,
                "post_id": 32167453,
                "comment_id": 52225487,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 6663049,
                    "reputation": 225,
                    "user_id": 5141502,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/gremL.jpg?s=256",
                    "display_name": "brian",
                    "link": "https://stackoverflow.com/users/5141502/brian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1440351404,
                "post_id": 32167453,
                "comment_id": 52225704,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1440347165,
                "last_edit_date": 1440347165,
                "creation_date": 1440343738,
                "answer_id": 32168331,
                "question_id": 32167453,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "There&#39;s more than one way to skin a cat, as they say, but perhaps this will give you some ideas:\r\n\r\n    .widgets[]\r\n    | select(.name==&quot;foo&quot;)\r\n    | select(.properties | index(&quot;cat&quot;) | not)\r\n    | .properties += [&quot;cat&quot;]\r\n\r\nWith your input, the result is:\r\n\r\n    {\r\n      &quot;name&quot;: &quot;foo&quot;,\r\n      &quot;properties&quot;: [\r\n        &quot;baz&quot;,\r\n        &quot;cat&quot;\r\n      ]\r\n    }\r\n\r\nThe following may be closer to what you&#39;re looking for:\r\n\r\n    .widgets |= [ .[] | if .properties|index(&quot;cat&quot;)|not\r\n                        then .properties += [&quot;cat&quot;]\r\n                        else .\r\n                        end]\r\n\r\n\r\n",
                "title": "Conditionally add element to json array using jq"
            },
            {
                "up_vote_count": 11,
                "is_accepted": true,
                "score": 10,
                "last_activity_date": 1666797677,
                "last_edit_date": 1666797677,
                "creation_date": 1440346475,
                "answer_id": 32168750,
                "question_id": 32167453,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "[**THIS IS NOT WORKING. READ BELOW.**]\r\n\r\nThere are many ways to do this.\r\n\r\nAssuming elements of the array are supposed to be unique, which your use case strongly implies, you can just pass the resulting array after the addition through the `unique` filter.\r\n\r\n    $ cat foo.json | jq &#39;.widgets[] | select(.name==&quot;foo&quot;).properties |= (.+ [&quot;cat&quot;] | unique)&#39;\r\n\r\nThere are a few problems here.\r\n\r\nOne is that the resulting output is partial as it is missing the container object.\r\n\r\nAnother one is that the edited array looses the commas separating the objects thus becoming illegal JSON.\r\n\r\nThe actual result from the above command is:\r\n\r\n    {\r\n      &quot;name&quot;: &quot;foo&quot;,\r\n      &quot;properties&quot;: [\r\n        &quot;baz&quot;,\r\n        &quot;cat&quot;\r\n      ]\r\n    }\r\n    {\r\n      &quot;name&quot;: &quot;bar&quot;\r\n    }\r\n",
                "title": "Conditionally add element to json array using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 9,
        "last_activity_date": 1666797677,
        "creation_date": 1440338482,
        "question_id": 32167453,
        "body_markdown": "I&#39;m adding strings to a JSON array using jq, and it works great, but I&#39;d like to only add strings that do not already exist. I&#39;ve experimented with unique, has, not, etc. I&#39;m missing a piece or two to the puzzle.\r\n\r\nHere&#39;s my starting json file, foo.json:\r\n\r\n    {\r\n      &quot;widgets&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;foo&quot;,\r\n          &quot;properties&quot;: [\r\n            &quot;baz&quot;\r\n          ]\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;bar&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\nHere&#39;s the jq command I&#39;ve constructed that adds the string, even if it already exists:\r\n\r\n    $ cat foo.json | jq &#39;.widgets[] | select(.name==&quot;foo&quot;).properties |= .+ [&quot;cat&quot;]&#39;\r\n\r\n\r\nHere&#39;s the latest iteration of my attempt.\r\n\r\n    $ cat foo.json | jq &#39;.widgets[] | select(.name==&quot;foo&quot;).properties | has(&quot;cat&quot;) | not | .properties += [&quot;cat&quot;]&#39;\r\n    jq: error: Cannot check whether array has a string key\r\n\r\n",
        "link": "https://stackoverflow.com/questions/32167453/conditionally-add-element-to-json-array-using-jq",
        "title": "Conditionally add element to json array using jq"
    },
    {
        "tags": [
            "json",
            "bash",
            "elasticsearch",
            "jq",
            "elasticsearch-api"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1440349917,
                "creation_date": 1440349917,
                "answer_id": 32169281,
                "question_id": 32168795,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "*fromjson* is your friend.  For example:\r\n    \r\n\r\n    def data: {\r\n      &quot;_index&quot;: &quot;kibana-int&quot;,\r\n      &quot;_type&quot;: &quot;dashboard&quot;,\r\n      &quot;_id&quot;: &quot;my_Dashboard&quot;,\r\n      &quot;_version&quot;: 5,\r\n      &quot;found&quot;: true,\r\n      &quot;_source&quot;: {\r\n        &quot;user&quot;: &quot;guest&quot;,\r\n        &quot;group&quot;: &quot;guest&quot;,\r\n        &quot;title&quot;: &quot;my_Dashboard&quot;,\r\n        &quot;dashboard&quot;: &quot;{ \\&quot;title\\&quot;: \\&quot;My Dashboard\\&quot;, \\&quot;services\\&quot;: { \\&quot;query\\&quot;: { \\&quot;list\\&quot;: { \\&quot;0\\&quot;: \\&quot;foobar\\&quot; }}}}&quot;\r\n      }\r\n    };\r\n    \r\n    data | ._source.dashboard | fromjson\r\n\r\nOutput:\r\n\r\n    $ jq -n -f elastic.jq\r\n    {\r\n      &quot;title&quot;: &quot;My Dashboard&quot;,\r\n      &quot;services&quot;: {\r\n        &quot;query&quot;: {\r\n          &quot;list&quot;: {\r\n            &quot;0&quot;: &quot;foobar&quot;\r\n          }\r\n        }\r\n      }\r\n    }\r\n\r\n\r\n\r\n    ",
                "title": "ElasticSearch api parse nested string json dashboard"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1440377086,
        "creation_date": 1440346818,
        "last_edit_date": 1440377086,
        "question_id": 32168795,
        "body_markdown": "I am using ElasticSearch GET to get the json file of a dashbaord:\r\nfor example: http://ES_IP:9200/kibana-int/dashboard/my_Dashboard/\r\n\r\nThis returns me a json file like:\r\n\r\n    {&quot;_index&quot;:&quot;kibana-int&quot;,&quot;_type&quot;:&quot;dashboard&quot;,&quot;_id&quot;:&quot;my_Dashboard&quot;,&quot;_version&quot;:5,&quot;found&quot;:true,&quot;_source&quot;:{ &quot;user&quot;:&quot;guest&quot;, &quot;group&quot;:&quot;guest&quot;, &quot;title&quot;:&quot;my_Dashboard&quot;, &quot;dashboard&quot;:&quot;{ \\&quot;title\\&quot;: \\&quot;My Dashboard\\&quot;, \\&quot;services\\&quot;: { \\&quot;query\\&quot;: { \\&quot;list\\&quot;: { \\&quot;0\\&quot;: { \\&quot;id\\&quot;: 0, \\&quot;type\\&quot;: \\&quot;lucene\\&quot;, \\&quot;query\\&quot;: \\&quot;type:dh AND severity:ERROR AND (response.baseUrl:\\&quot;/rm/recordings/*\\&quot; OR request.baseUrl:\\&quot;/rm/recordings/*\\&quot;)\\&quot;, \\&quot;alias\\&quot;: \\&quot;DH errors rcc\\&quot;,.......\r\n\r\nHere is where I need your help, how can I get the value of the key &quot;dashboard&quot; but without the escaped &#39;\\&#39; character in the key/val pair not affecting the escaped that are part of the values?\r\n\r\nThe output that I need should be something like:\r\n\r\n    { &quot;title&quot;: &quot;My Dashboard&quot;, &quot;services&quot;: { &quot;query&quot;: { &quot;list&quot;: { &quot;0&quot;: { &quot;id&quot;: 0, &quot;type&quot;: &quot;lucene&quot;, &quot;query&quot;: &quot;type:dh AND severity:ERROR AND (response.baseUrl:\\&quot;/rm/recordings/*\\&quot; OR request.baseUrl:\\&quot;/rm/recordings/*\\&quot;)&quot;, &quot;alias&quot;: &quot;DH errors rcc&quot;,.......\r\n\r\nPay attention in the query key, in its value, there are some \\&quot; that shouldn&#39;t be affected, since they are part of the value.\r\n\r\nI need that output to then parse that json with jq in a some bash script I have.\r\n\r\nDoes ElasticSearch api have some filter to provide me that output?\r\nOr do you know another external method to get what I need?\r\n\r\nThanks a lot for the help. \r\n\r\n",
        "link": "https://stackoverflow.com/questions/32168795/elasticsearch-api-parse-nested-string-json-dashboard",
        "title": "ElasticSearch api parse nested string json dashboard"
    },
    {
        "tags": [
            "javascript",
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1440399630,
                "creation_date": 1440399630,
                "answer_id": 32176166,
                "question_id": 32176017,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The correct method is to use `map()`:\r\n\r\n    .[1:999999999999] | map({population:.[0], state_name:.[1], state_code:.[2]})",
                "title": "Using jq to access nested arrays"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1440400220,
                "creation_date": 1440400220,
                "answer_id": 32176335,
                "question_id": 32176017,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The proposed answer can be improved in two respects:\r\n\r\n(1) Instead of the *.[1:999999999999]* hack, you can simply write *.[1:]*.\r\n\r\n(2) The stated goal is to produce a sequence (i.e. stream) of objects, rather than an array of objects. This can be accomplished as follows:\r\n\r\n    \r\n    .[1:][] | {population:.[0], state_name:.[1], state_code:.[2]}\r\n\r\n",
                "title": "Using jq to access nested arrays"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1440400220,
        "creation_date": 1440399012,
        "question_id": 32176017,
        "body_markdown": "Given this data (it&#39;s directly from the census.gov api):\r\n\r\n    [[&quot;P0010001&quot;,&quot;NAME&quot;,&quot;state&quot;],\r\n    [&quot;4779736&quot;,&quot;Alabama&quot;,&quot;01&quot;],\r\n    [&quot;710231&quot;,&quot;Alaska&quot;,&quot;02&quot;],\r\n    [&quot;6392017&quot;,&quot;Arizona&quot;,&quot;04&quot;],\r\n    [&quot;2915918&quot;,&quot;Arkansas&quot;,&quot;05&quot;],\r\n    [&quot;37253956&quot;,&quot;California&quot;,&quot;06&quot;],\r\n    [&quot;5029196&quot;,&quot;Colorado&quot;,&quot;08&quot;],\r\n    [&quot;3574097&quot;,&quot;Connecticut&quot;,&quot;09&quot;],\r\n    [&quot;897934&quot;,&quot;Delaware&quot;,&quot;10&quot;],\r\n    [&quot;601723&quot;,&quot;District of Columbia&quot;,&quot;11&quot;],\r\n    [&quot;18801310&quot;,&quot;Florida&quot;,&quot;12&quot;],\r\n    [&quot;9687653&quot;,&quot;Georgia&quot;,&quot;13&quot;],\r\n    [&quot;1360301&quot;,&quot;Hawaii&quot;,&quot;15&quot;],\r\n    [&quot;1567582&quot;,&quot;Idaho&quot;,&quot;16&quot;],\r\n    [&quot;12830632&quot;,&quot;Illinois&quot;,&quot;17&quot;],\r\n    [&quot;6483802&quot;,&quot;Indiana&quot;,&quot;18&quot;],\r\n    [&quot;3046355&quot;,&quot;Iowa&quot;,&quot;19&quot;],\r\n    [&quot;2853118&quot;,&quot;Kansas&quot;,&quot;20&quot;],\r\n    [&quot;4339367&quot;,&quot;Kentucky&quot;,&quot;21&quot;],\r\n    [&quot;4533372&quot;,&quot;Louisiana&quot;,&quot;22&quot;],\r\n    [&quot;1328361&quot;,&quot;Maine&quot;,&quot;23&quot;],\r\n    [&quot;5773552&quot;,&quot;Maryland&quot;,&quot;24&quot;],\r\n    [&quot;6547629&quot;,&quot;Massachusetts&quot;,&quot;25&quot;],\r\n    [&quot;9883640&quot;,&quot;Michigan&quot;,&quot;26&quot;],\r\n    [&quot;5303925&quot;,&quot;Minnesota&quot;,&quot;27&quot;],\r\n    [&quot;2967297&quot;,&quot;Mississippi&quot;,&quot;28&quot;],\r\n    [&quot;5988927&quot;,&quot;Missouri&quot;,&quot;29&quot;],\r\n    [&quot;989415&quot;,&quot;Montana&quot;,&quot;30&quot;],\r\n    [&quot;1826341&quot;,&quot;Nebraska&quot;,&quot;31&quot;],\r\n    [&quot;2700551&quot;,&quot;Nevada&quot;,&quot;32&quot;],\r\n    [&quot;1316470&quot;,&quot;New Hampshire&quot;,&quot;33&quot;],\r\n    [&quot;8791894&quot;,&quot;New Jersey&quot;,&quot;34&quot;],\r\n    [&quot;2059179&quot;,&quot;New Mexico&quot;,&quot;35&quot;],\r\n    [&quot;19378102&quot;,&quot;New York&quot;,&quot;36&quot;],\r\n    [&quot;9535483&quot;,&quot;North Carolina&quot;,&quot;37&quot;],\r\n    [&quot;672591&quot;,&quot;North Dakota&quot;,&quot;38&quot;],\r\n    [&quot;11536504&quot;,&quot;Ohio&quot;,&quot;39&quot;],\r\n    [&quot;3751351&quot;,&quot;Oklahoma&quot;,&quot;40&quot;],\r\n    [&quot;3831074&quot;,&quot;Oregon&quot;,&quot;41&quot;],\r\n    [&quot;12702379&quot;,&quot;Pennsylvania&quot;,&quot;42&quot;],\r\n    [&quot;1052567&quot;,&quot;Rhode Island&quot;,&quot;44&quot;],\r\n    [&quot;4625364&quot;,&quot;South Carolina&quot;,&quot;45&quot;],\r\n    [&quot;814180&quot;,&quot;South Dakota&quot;,&quot;46&quot;],\r\n    [&quot;6346105&quot;,&quot;Tennessee&quot;,&quot;47&quot;],\r\n    [&quot;25145561&quot;,&quot;Texas&quot;,&quot;48&quot;],\r\n    [&quot;2763885&quot;,&quot;Utah&quot;,&quot;49&quot;],\r\n    [&quot;625741&quot;,&quot;Vermont&quot;,&quot;50&quot;],\r\n    [&quot;8001024&quot;,&quot;Virginia&quot;,&quot;51&quot;],\r\n    [&quot;6724540&quot;,&quot;Washington&quot;,&quot;53&quot;],\r\n    [&quot;1852994&quot;,&quot;West Virginia&quot;,&quot;54&quot;],\r\n    [&quot;5686986&quot;,&quot;Wisconsin&quot;,&quot;55&quot;],\r\n    [&quot;563626&quot;,&quot;Wyoming&quot;,&quot;56&quot;],\r\n    [&quot;3725789&quot;,&quot;Puerto Rico&quot;,&quot;72&quot;]]\r\n\r\nI want to use [jq][1] to generate a file that looks like:\r\n\r\n    {\r\n      &quot;population&quot;: &quot;4779736&quot;,\r\n      &quot;state_name&quot;: &quot;Alabama&quot;,\r\n      &quot;state_code&quot;: &quot;01&quot;\r\n    }\r\n    {\r\n      &quot;population&quot;: &quot;710231&quot;,\r\n      &quot;state_name&quot;: &quot;Alaska&quot;,\r\n      &quot;state_code&quot;: &quot;02&quot;\r\n    }\r\n    {\r\n      &quot;population&quot;: &quot;6392017&quot;,\r\n      &quot;state_name&quot;: &quot;Arizona&quot;,\r\n      &quot;state_code&quot;: &quot;04&quot;\r\n    }\r\n    // etc...\r\n\r\nI have tried:\r\n\r\n    .[1:999999999999] | {population:.[][0], state_name:.[][1], state_code:.[][2]}\r\n\r\nThe `[1:999999999999]` is to remove the first array. It works buuuuut it generates thousands of JS objects, instead of only 53. It appears to be repeating the mapping over and over again. Why is this?\r\n\r\njq can be tested at https://jqplay.org/\r\n\r\n  [1]: https://stedolan.github.io/jq/",
        "link": "https://stackoverflow.com/questions/32176017/using-jq-to-access-nested-arrays",
        "title": "Using jq to access nested arrays"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2161811,
                    "reputation": 1803,
                    "user_id": 1915812,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/5b41c84cf5da47701bdd9f8ce6a5914e?s=256&d=identicon&r=PG",
                    "display_name": "Tom",
                    "link": "https://stackoverflow.com/users/1915812/tom"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1440422054,
                "post_id": 32182087,
                "comment_id": 52251885,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1472550519,
                "post_id": 32182087,
                "comment_id": 65785822,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 16,
                "is_accepted": true,
                "score": 16,
                "last_activity_date": 1551798193,
                "last_edit_date": 1551798193,
                "creation_date": 1440440597,
                "answer_id": 32189130,
                "question_id": 32182087,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "jq 1.5 has a streaming parser. The jq [FAQ][1] gives an example of how to convert a top-level array of JSON objects into a stream of its elements:\r\n\r\n    $ jq -nc --stream &#39;fromstream(1|truncate_stream(inputs))&#39;\r\n    [{&quot;foo&quot;:&quot;bar&quot;},{&quot;foo&quot;:&quot;baz&quot;}]\r\n    {&quot;foo&quot;:&quot;bar&quot;}\r\n    {&quot;foo&quot;:&quot;baz&quot;}\r\n\r\nThat may be enough for your purposes, but it is worthwhile noting that setpath/2 can be helpful.  Here&#39;s how to produce a stream of leaflets:\r\n\r\n    jq -c --stream &#39;. as $in | select(length == 2) | {}|setpath($in[0]; $in[1])&#39;\r\n\r\nFurther information and documentation is available in the jq manual:\r\nhttps://stedolan.github.io/jq/manual/#Streaming \r\n\r\n\r\n  [1]: https://github.com/stedolan/jq/wiki/FAQ#streaming-json-parser",
                "title": "Processing huge json-array files with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 18,
        "last_activity_date": 1601372535,
        "creation_date": 1440418515,
        "last_edit_date": 1504598473,
        "question_id": 32182087,
        "body_markdown": "I have huge (~7GB) json array of relatively small objects.\r\n\r\nIs there relatively simple way to filter these objects without loading whole file into memory?\r\n\r\n**--stream** option looks suitable, but I can&#39;t figure out how to fold stream of [path,value] to original objects.\r\n",
        "link": "https://stackoverflow.com/questions/32182087/processing-huge-json-array-files-with-jq",
        "title": "Processing huge json-array files with jq"
    },
    {
        "tags": [
            "json",
            "parsing",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1440538041,
                "creation_date": 1440538041,
                "answer_id": 32214407,
                "question_id": 32214120,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "I managed to do it using this: \r\n\r\n    jq &#39;.FileSystems[]&#39; | jq &#39;select(.Name==&quot;efs-docker&quot;)&#39; | jq -r &#39;.FileSystemId&#39;\r\n\r\nIt may not be efficient, but it worked.  ",
                "title": "select value from an array using jq"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1440546023,
                "creation_date": 1440546023,
                "answer_id": 32215820,
                "question_id": 32214120,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Avoiding calling `jq` multiple times and thus avoiding the overhead of creating multiple processes:\r\n\r\n    jq -r &#39;.FileSystems[] | select(.Name==&quot;efs-docker&quot;) | .FileSystemId&#39;",
                "title": "select value from an array using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1440546023,
        "creation_date": 1440536933,
        "question_id": 32214120,
        "body_markdown": "I&#39;m trying to write a query using jq that loops through the following json and returns the value of FileSystemId when the value of Name = &quot;efs-docker&quot; and breaks out of the script if no matching records are found.  I thought I might be able to do it using a foreach loop, but the syntax is confusing.  Is possible to do with with a reduce or select function instead?\r\n    \r\n    {\r\n       &quot;FileSystems&quot;: [\r\n         {\r\n            &quot;SizeInBytes&quot;: {\r\n                &quot;Value&quot;: 6144\r\n            },\r\n            &quot;Name&quot;: &quot;not-docker&quot;,\r\n            &quot;CreationToken&quot;: &quot;console-db868fd6-ed6d-46f8-9e3e-4501293847f5&quot;,\r\n            &quot;CreationTime&quot;: 1440519280.0,\r\n            &quot;FileSystemId&quot;: &quot;fs-0fdd32a6&quot;,\r\n            &quot;NumberOfMountTargets&quot;: 3,\r\n            &quot;LifeCycleState&quot;: &quot;available&quot;,\r\n            &quot;OwnerId&quot;: &quot;310444902345&quot;\r\n        },\r\n        {\r\n            &quot;SizeInBytes&quot;: {\r\n                &quot;Timestamp&quot;: 1440514799.0,\r\n                &quot;Value&quot;: 307060736\r\n            },\r\n            &quot;Name&quot;: &quot;efs-docker&quot;,\r\n            &quot;CreationToken&quot;: &quot;console-3b8b33de-dc45-4634-b6e1-882187ac3cd3&quot;,\r\n            &quot;CreationTime&quot;: 1440426036.0,\r\n            &quot;FileSystemId&quot;: &quot;fs-d2c22d7b&quot;,\r\n            &quot;NumberOfMountTargets&quot;: 3,\r\n            &quot;LifeCycleState&quot;: &quot;available&quot;,\r\n            &quot;OwnerId&quot;: &quot;310444902345&quot;\r\n             }\r\n        ]\r\n    }\r\n\r\nThanks,\r\nJeremy      \r\n\r\n      ",
        "link": "https://stackoverflow.com/questions/32214120/select-value-from-an-array-using-jq",
        "title": "select value from an array using jq"
    },
    {
        "tags": [
            "json",
            "unix",
            "twitter",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1440557209,
                "creation_date": 1440557209,
                "answer_id": 32217198,
                "question_id": 32217197,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "One can sort a stream of Twitter JSON blobs with:\r\n\r\n    jq -r &#39;(.created_at | strptime(&quot;%a %b %d %H:%M:%S +0000 %Y&quot;) | todate) + &quot;\\t&quot; + tostring&#39; |\r\n    sort -k1,1 |\r\n    cut -f2\r\n\r\nFor each JSON blob, the `jq` command parses the &quot;created_at&quot; field and outputs an ISO8601 date, followed by a tab, followed by the original JSON (which does not contain tabs or newlines). The `--raw-output`/`-r` flag ensures this is not JSON-encoded, but output as raw text. The stream is then sorted by GNU `sort` or equivalent, and the JSON blobs alone are retuned by `cut`.",
                "title": "use unix tools (e.g. sort) over field extracted from line-delimited JSON"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1440614326,
                "creation_date": 1440614326,
                "answer_id": 32234254,
                "question_id": 32217197,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The fact that jq can easily be used with other command-line tools is indeed one of jq&#39;s strengths, but it is no longer necessary to use the &quot;slurp&quot; option (--slurp or -s) to accomplish tasks such as the one described (i.e., to reduce an input stream of JSON entities).  The key is the new &quot;inputs&quot; filter in jq version 1.5.\r\n\r\nTo illustrate how &quot;inputs&quot; can be used to avoid having to read the input file into memory, consider the task of finding the maximum value of a file of JSON entities.  Here is one solution:\r\n\r\n    $ jq -n &#39;reduce inputs as $i (null; [., $i] | max)&#39;\r\n\r\nNotice that the -n option is required here.\r\n\r\nIn summary, with jq 1.5, one can easily process a stream of JSON entities (such as might be contained in a file) by reading in one at a time, whether or not each input entity is on a line by itself.  The key is to use &quot;inputs&quot; and the &quot;-n&quot; option.  \r\n\r\nSimilarly, very large text files can now also be handled on a line-at-a-time basis while still being able to perform some reduction operations; this would be done using the -R option together with -n and *inputs*.\r\n",
                "title": "use unix tools (e.g. sort) over field extracted from line-delimited JSON"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1440614326,
        "creation_date": 1440557209,
        "question_id": 32217197,
        "body_markdown": "A tool like [jq][1] turns out to be extremely useful for declaratively extracting and filtering content from [line-delimited JSON][2]. However, it appears to require slurping all objects into memory to perform operations such as sorting, and generally it may be useful to exploit existing *NIX tools to process one or more fields from the JSON *while retaining the original JSON blobs alongside*.\r\n\r\nFor example, given a line-delimited JSON from the [Twitter API][3], I&#39;d like to sort the tweet JSON blobs by timestamp. This can be achieved by converting the Twitter date format to [ISO8601][4] (for which lexicographic and chronological ordering are identical), prepending the JSON tweet blob with that date, passing the stream through GNU `sort`, and `cut`ting to remove the prepended date.\r\n\r\nWhile it is possible to use `mkfifo` and `paste` to achieve this, I hoped for a solution that was more concise by utilising `jq`.\r\n\r\n\r\n  [1]: https://github.com/stedolan/jq\r\n  [2]: https://en.wikipedia.org/wiki/Line_Delimited_JSON\r\n  [3]: https://dev.twitter.com/streaming/overview\r\n  [4]: https://en.wikipedia.org/wiki/ISO_8601",
        "link": "https://stackoverflow.com/questions/32217197/use-unix-tools-e-g-sort-over-field-extracted-from-line-delimited-json",
        "title": "use unix tools (e.g. sort) over field extracted from line-delimited JSON"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 23,
                "is_accepted": true,
                "score": 23,
                "last_activity_date": 1440781327,
                "last_edit_date": 1440781327,
                "creation_date": 1440780981,
                "answer_id": 32276111,
                "question_id": 32275538,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "This should work:\r\n\r\n    [\r\n        .ClassIdentifier,\r\n        .StateMode // &quot;null&quot;,\r\n        (.StateGroups\r\n            | map(select(.Status==&quot;active&quot;).StateGroupName)\r\n            | sort\r\n            | join(&quot;|&quot;)\r\n            | if .==&quot;&quot; then &quot;null&quot; else . end\r\n        )\r\n    ] | @csv\r\n\r\nWhich produces:\r\n\r\n    &quot;consumer-leads&quot;,&quot;txt-2300&quot;,&quot;null&quot;\r\n    &quot;main&quot;,&quot;null&quot;,&quot;brown-space|default|txt-hosts&quot;\r\n    &quot;paid-media&quot;,&quot;txt-2300&quot;,&quot;null&quot;\r\n    &quot;reports&quot;,&quot;null&quot;,&quot;default|grey-space|txt-hosts&quot;\r\n\r\nNote that since you&#39;re using 1.3, `join/1` won&#39;t be available to you.  But it shouldn&#39;t be difficult to implement yourself.\r\n\r\n    def join(sep): sep as $sep\r\n        | reduce .[1:][] as $item (.[0]|tostring; . + $sep + $item)\r\n        ;\r\n\r\n",
                "title": "Make JQ transform an array of objects to a string"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 9,
        "last_activity_date": 1457467872,
        "creation_date": 1440778703,
        "last_edit_date": 1457467872,
        "question_id": 32275538,
        "body_markdown": "I have a JSON file:\r\n\r\n    {\r\n      &quot;ClassIdentifier&quot;: &quot;consumer-leads&quot;,\r\n      &quot;StateMode&quot;: &quot;txt-2300&quot;,\r\n      &quot;StateGroups&quot;: []\r\n    }\r\n    {\r\n      &quot;ClassIdentifier&quot;: &quot;main&quot;,\r\n      &quot;StateMode&quot;: null,\r\n      &quot;StateGroups&quot;: [\r\n        {\r\n          &quot;Status&quot;: &quot;active&quot;,\r\n          &quot;StateGroupName&quot;: &quot;default&quot;\r\n        },\r\n        {\r\n          &quot;Status&quot;: &quot;active&quot;,\r\n          &quot;StateGroupName&quot;: &quot;brown-space&quot;\r\n        },\r\n        {\r\n          &quot;Status&quot;: &quot;active&quot;,\r\n          &quot;StateGroupName&quot;: &quot;txt-hosts&quot;\r\n        }\r\n      ]\r\n    }\r\n    {\r\n      &quot;ClassIdentifier&quot;: &quot;paid-media&quot;,\r\n      &quot;StateMode&quot;: &quot;txt-2300&quot;,\r\n      &quot;StateGroups&quot;: []\r\n    }\r\n    {\r\n      &quot;ClassIdentifier&quot;: &quot;reports&quot;,\r\n      &quot;StateMode&quot;: null,\r\n      &quot;StateGroups&quot;: [\r\n        {\r\n          &quot;Status&quot;: &quot;active&quot;,\r\n          &quot;StateGroupName&quot;: &quot;txt-hosts&quot;\r\n        },\r\n        {\r\n          &quot;Status&quot;: &quot;active&quot;,\r\n          &quot;StateGroupName&quot;: &quot;grey-space&quot;\r\n        },\r\n        {\r\n          &quot;Status&quot;: &quot;active&quot;,\r\n          &quot;StateGroupName&quot;: &quot;default&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\nThe output I need:\r\n\r\n    consumer-leads,txt-2300,null\r\n    main,null,brown-space|default|txt-hosts\r\n    paid-media,txt-2300,null\r\n    reports,null,default|grey-space|txt-hosts\r\n\r\nNote that StateGroups (if they exist at all) are sorted by StateGroupName as (or before) they are being transformed into a string of values separated by vertical bars.\r\n\r\nWhat I have tried has given me partial results, but nothing really does the job:\r\n\r\n    cat json_file |\r\n          jq -r &#39;[ .ClassIdentifier,\r\n                   .StateMode,\r\n                   .StateGroups[]\r\n                 ]&#39;\r\n    \r\n    cat json_file |\r\n          jq -r &#39;{ ClassIdentifier,\r\n                   StateMode\r\n                 } +\r\n                 ( .StateGroups[] | { StateGroupName,  Status } )\r\n                 &#39;\r\n    \r\n    cat json_file |\r\n          jq -r &#39; [ .ClassIdentifier,\r\n                  .StateMode,\r\n                  .StateGroups |= sort_by( .StateGroupName )\r\n                 ]&#39;\r\n\r\nUPDATE:  We have to use JQ 1.3, so please keep that in mind for a response.\r\n",
        "link": "https://stackoverflow.com/questions/32275538/make-jq-transform-an-array-of-objects-to-a-string",
        "title": "Make JQ transform an array of objects to a string"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1441136754,
                "creation_date": 1441136754,
                "answer_id": 32339753,
                "question_id": 32338872,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You can use the convenient subtraction operator `-` as follows:\r\n\r\n    jq &#39;. - [&quot;foo&quot;, &quot;baz&quot;]&#39;",
                "title": "Values from array foo not in array bar"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1441136754,
        "creation_date": 1441133340,
        "question_id": 32338872,
        "body_markdown": "I&#39;m trying to filter an array with another.\r\nFor example, given I have this input array:\r\n`[&#39;foo&#39;, bar&#39;, &#39;baz&#39;]`\r\nAnd this filter array:\r\n`[&#39;foo&#39;, &#39;baz&#39;]`\r\n\r\nI want to have this output:\r\n`[&#39;bar&#39;]`\r\n\r\nI feel like I could be able to do this by piping to `select(inside())`, but I can&#39;t get `inside()` to work; I get a &quot;not defined&quot; error.",
        "link": "https://stackoverflow.com/questions/32338872/values-from-array-foo-not-in-array-bar",
        "title": "Values from array foo not in array bar"
    },
    {
        "tags": [
            "json",
            "transpose",
            "relation",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 10,
                "is_accepted": true,
                "score": 10,
                "last_activity_date": 1441214575,
                "creation_date": 1441214575,
                "answer_id": 32359453,
                "question_id": 32357240,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "This should work:\r\n\r\n    map({ name, key: .keys[] })\r\n        | group_by(.key)\r\n        | map({ key: .[0].key, value: map(.name) })\r\n        | from_entries\r\n\r\nThe basic approach is to convert each object to name/key pairs, regroup them by key, then map them out to entries of an object.\r\n\r\nThis produces the following output:\r\n\r\n    {\r\n      &quot;k1&quot;: [ &quot;A&quot; ],\r\n      &quot;k2&quot;: [ &quot;A&quot;, &quot;B&quot; ],\r\n      &quot;k3&quot;: [ &quot;A&quot;, &quot;B&quot; ],\r\n      &quot;k4&quot;: [ &quot;B&quot; ]\r\n    }\r\n\r\n",
                "title": "&quot;Transposing&quot; objects in jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1441229189,
                "creation_date": 1441229189,
                "answer_id": 32363388,
                "question_id": 32357240,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a simple solution that may also be easier to understand. It is based on the idea that a dictionary (a JSON object) can be extended by adding details about additional (key -&gt; value) pairs:\r\n\r\n    # input: a dictionary to be extended by key -&gt; value \r\n    # for each key in keys\r\n    def extend_dictionary(keys; value):\r\n      reduce keys[] as $key (.; .[$key] += [value]);\r\n\r\n    reduce .[] as $o ({}; extend_dictionary($o.keys; $o.name) )\r\n\r\n    \r\n    $ jq -c -f transpose-object.jq input.json\r\n    {&quot;k1&quot;:[&quot;A&quot;],&quot;k2&quot;:[&quot;A&quot;,&quot;B&quot;],&quot;k3&quot;:[&quot;A&quot;,&quot;B&quot;],&quot;k4&quot;:[&quot;B&quot;]}",
                "title": "&quot;Transposing&quot; objects in jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1482507834,
                "last_edit_date": 1482507834,
                "creation_date": 1441295005,
                "answer_id": 32380088,
                "question_id": 32357240,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a better solution for the case that all the values of &quot;name&quot;\r\nare distinct.  It is better because it uses a completely generic\r\nfilter, invertMapping; that is, invertMapping could be a built-in or\r\nlibrary function.  With the help of this function, the solution\r\nbecomes a simple three-liner.\r\n\r\nFurthermore, if the values of &quot;name&quot; are not all unique, then the solution\r\nbelow can easily be tweaked by modifying the initial reduction of the input\r\n(i.e. the line immediately above the invocation of invertMapping).\r\n\r\n\r\n    # input: a JSON object of (key, values) pairs, in which &quot;values&quot; is an array of strings; \r\n    # output: a JSON object representing the inverse relation\r\n    def invertMapping: \r\n      reduce to_entries[] as $pair\r\n        ({}; reduce $pair.value[] as $v (.; .[$v] += [$pair.key] ));\r\n\r\n    \r\n    map( { (.name) : .keys} )\r\n    | add\r\n    | invertMapping\r\n    \r\n    ",
                "title": "&quot;Transposing&quot; objects in jq"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 7,
        "last_activity_date": 1547028531,
        "creation_date": 1441207707,
        "last_edit_date": 1482850261,
        "question_id": 32357240,
        "body_markdown": "I&#39;m unsure if &quot;transpose&quot; is the correct term here, but I&#39;m looking to use `jq` to transpose a 2-dimensional object such as this:\r\n\r\n    [\r\n        {\r\n            &quot;name&quot;: &quot;A&quot;,\r\n            &quot;keys&quot;: [&quot;k1&quot;, &quot;k2&quot;, &quot;k3&quot;]\r\n        },\r\n        {\r\n            &quot;name&quot;: &quot;B&quot;,\r\n            &quot;keys&quot;: [&quot;k2&quot;, &quot;k3&quot;, &quot;k4&quot;]\r\n        }\r\n    ]\r\n\r\nI&#39;d like to transform it to:\r\n\r\n    {\r\n        &quot;k1&quot;: [&quot;A&quot;],\r\n        &quot;k2&quot;: [&quot;A&quot;, &quot;B&quot;],\r\n        &quot;k3&quot;: [&quot;A&quot;, &quot;B&quot;],\r\n        &quot;k4&quot;: [&quot;A&quot;],\r\n    }\r\n\r\nI can split out the object with `.[] | {key: .keys[], name}` to get a list of keys and names, or I could use `.[] | {(.keys[]): [.name]}` to get a collection of key–value pairs `{&quot;k1&quot;:&#160;[&quot;A&quot;]}` and so on, but I&#39;m unsure of the final concatenation step for either approach.\r\n\r\nAre either of these approaches heading in the right direction? Is there a better way?",
        "link": "https://stackoverflow.com/questions/32357240/transposing-objects-in-jq",
        "title": "&quot;Transposing&quot; objects in jq"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1441274155,
                "creation_date": 1441274155,
                "answer_id": 32372447,
                "question_id": 32370843,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "If I&#39;m understanding the problem right, wrapping the right hand expression in parenthesis and using regular piping should do what you ask for.\r\n\r\n    .minimalVersion = (.softwareInfo.requirementsString | \r\n        sub(&quot;iOS(?&lt;version&gt;.*?) or&quot;; &quot;\\(.version)&quot;)))",
                "title": "Apply sub on a single field and assign the result to a new field"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1441274155,
        "creation_date": 1441269552,
        "last_edit_date": 1441269876,
        "question_id": 32370843,
        "body_markdown": "I have a JSON with the path: \r\n\r\n&gt; .softwareInfo.requirementsString\r\n\r\nThe value of the field `requirementsString` contains a string, of which I need only a part of this. For this i use `sub` I want to assign the result to a new field. I&#39;ve come up with something below, but not sure (notice the `??`) how to apply the sub function to only the `requirementsString` field. So this code obviously doesn&#39;t work. What is the correct syntax for this?\r\n\r\n    .minimalVersion = .softwareInfo.requirementsString ?? \r\n        sub(&quot;iOS(?&lt;version&gt;.*?) or&quot;; &quot;\\(.version)&quot;))",
        "link": "https://stackoverflow.com/questions/32370843/apply-sub-on-a-single-field-and-assign-the-result-to-a-new-field",
        "title": "Apply sub on a single field and assign the result to a new field"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1441350153,
                "last_edit_date": 1441350153,
                "creation_date": 1441299673,
                "answer_id": 32381557,
                "question_id": 32381023,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "An `if` processing all entities but leaving the ones with `StatusInfos: null` intact would do as in:\r\n\r\n    jq -r &#39;if .StatusInfos != null then {\r\n        RepStatus: .StatusInfos[0].Status,\r\n        RepStatusType: .StatusInfos[0].StatusType,\r\n        ReadReplicaSourceDBInstanceIdentifier,\r\n        DBInstanceIdentifier } else . end&#39;\r\n\r\nor, when required to deal with multiple StatusInfo&#39;s:\r\n\r\n    jq -r &#39;if .StatusInfos != null then \r\n            .StatusInfos[] as $info | {\r\n                 RepStatus: $info.Status,\r\n                 RepStatusType: $info.StatusType,\r\n                 ReadReplicaSourceDBInstanceIdentifier,\r\n                 DBInstanceIdentifier }\r\n        else . end&#39;\r\n",
                "title": "JQ &#39;select&#39; or &#39;if&#39;?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1441300258,
                "last_edit_date": 1441300258,
                "creation_date": 1441299874,
                "answer_id": 32381609,
                "question_id": 32381023,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Try this:\r\n\r\n    reduce ((.StatusInfos//[])[] | select(.StatusType == &quot;read replication&quot;)) as $info\r\n        ({ ReadReplicaSourceDBInstanceIdentifier, DBInstanceIdentifier };\r\n        .RepStatus = $info.Status | .RepStatusType = $info.StatusType)\r\n\r\nIf you had access to a more recent version of jq, you could utilize the error ignoring filters to change `(.StatusInfos//[])[]` to `.StatusInfos?[]?`",
                "title": "JQ &#39;select&#39; or &#39;if&#39;?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1501796230,
                "creation_date": 1501796230,
                "answer_id": 45494888,
                "question_id": 32381023,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a variation which replaces `StatusInfos` with attributes from its last array element if possible.\r\n\r\n    if .StatusInfos == null\r\n    then .\r\n    else .RepStatus     = .StatusInfos[-1].Status\r\n       | .RepStatusType = .StatusInfos[-1].StatusType\r\n       | del(.StatusInfos)\r\n    end\r\n",
                "title": "JQ &#39;select&#39; or &#39;if&#39;?"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1501796230,
        "creation_date": 1441297885,
        "question_id": 32381023,
        "body_markdown": "I have a JSON file:\r\n\r\n    {\r\n      &quot;StatusInfos&quot;: null,\r\n      &quot;ReadReplicaSourceDBInstanceIdentifier&quot;: null,\r\n      &quot;DBInstanceIdentifier&quot;: &quot;test1&quot;\r\n    }\r\n    {\r\n      &quot;StatusInfos&quot;: null,\r\n      &quot;ReadReplicaSourceDBInstanceIdentifier&quot;: null,\r\n      &quot;DBInstanceIdentifier&quot;: &quot;test2&quot;\r\n    }\r\n    {\r\n      &quot;StatusInfos&quot;: [\r\n        {\r\n          &quot;Status&quot;: &quot;replicating&quot;,\r\n          &quot;StatusType&quot;: &quot;read replication&quot;,\r\n          &quot;Normal&quot;: true\r\n        }\r\n      ],\r\n      &quot;ReadReplicaSourceDBInstanceIdentifier&quot;: &quot;test1&quot;,\r\n      &quot;DBInstanceIdentifier&quot;: &quot;read-rep-test1&quot;\r\n    }\r\n    {\r\n      &quot;StatusInfos&quot;: [\r\n        {\r\n          &quot;Status&quot;: &quot;replicating&quot;,\r\n          &quot;StatusType&quot;: &quot;read replication&quot;,\r\n          &quot;Normal&quot;: true\r\n        }\r\n      ],\r\n      &quot;ReadReplicaSourceDBInstanceIdentifier&quot;: &quot;test2&quot;,\r\n      &quot;DBInstanceIdentifier&quot;: &quot;read-rep-test2&quot;\r\n    }\r\n\r\nI&#39;m trying to produce:\r\n\r\n    {\r\n      &quot;StatusInfos&quot;: null,\r\n      &quot;ReadReplicaSourceDBInstanceIdentifier&quot;: null,\r\n      &quot;DBInstanceIdentifier&quot;: &quot;test1&quot;\r\n    }\r\n    {\r\n      &quot;StatusInfos&quot;: null,\r\n      &quot;ReadReplicaSourceDBInstanceIdentifier&quot;: null,\r\n      &quot;DBInstanceIdentifier&quot;: &quot;test2&quot;\r\n    }\r\n    {\r\n      &quot;RepStatus&quot;: &quot;replicating&quot;,\r\n      &quot;RepStatusType&quot;: &quot;read replication&quot;,\r\n      &quot;ReadReplicaSourceDBInstanceIdentifier&quot;: &quot;test1&quot;,\r\n      &quot;DBInstanceIdentifier&quot;: &quot;read-rep-test1&quot;\r\n    }\r\n    {\r\n      &quot;RepStatus&quot;: &quot;replicating&quot;,\r\n      &quot;RepStatusType&quot;: &quot;read replication&quot;,\r\n      &quot;ReadReplicaSourceDBInstanceIdentifier&quot;: &quot;test2&quot;,\r\n      &quot;DBInstanceIdentifier&quot;: &quot;read-rep-test2&quot;\r\n    }\r\n\r\nI have tried dozens of variations of &#39;select&#39; and &#39;if&#39;, most of which simply spit out errors.  My most recent attempt (I&#39;m limited to jq 1.3 if that is important) produces neither errors nor output:\r\n\r\n       cat json_file |\r\n          jq -r &#39;{ DBInstanceIdentifier,\r\n                   ReadReplicaSourceDBInstanceIdentifier\r\n                 } +\r\n                 ( select( .StatusType == &quot;read replication&quot; ) |\r\n                  .StatusInfos[] | { RepStatusType: .StatusType, RepStatus: .Status }\r\n                 )&#39;\r\n\r\nJQ is absolutely baffling to me.  I have referenced the manuals many times, but they give examples, not principles.  So in addition to how to solve my immediate problem, if you can recommend how I might go about actually understanding JQ, I would appreciate it.\r\n",
        "link": "https://stackoverflow.com/questions/32381023/jq-select-or-if",
        "title": "JQ &#39;select&#39; or &#39;if&#39;?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 10030,
                    "reputation": 339134,
                    "user_id": 18771,
                    "user_type": "registered",
                    "accept_rate": 87,
                    "profile_image": "https://www.gravatar.com/avatar/0ada184c98bf9073d15b2dc815be0170?s=256&d=identicon&r=PG",
                    "display_name": "Tomalak",
                    "link": "https://stackoverflow.com/users/18771/tomalak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1441642177,
                "post_id": 32442433,
                "comment_id": 52748847,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 2795620,
                    "reputation": 102,
                    "user_id": 2404894,
                    "user_type": "registered",
                    "accept_rate": 75,
                    "profile_image": "https://www.gravatar.com/avatar/ca54e48346cde9f30e08770852251281?s=256&d=identicon&r=PG",
                    "display_name": "geledek",
                    "link": "https://stackoverflow.com/users/2404894/geledek"
                },
                "reply_to_user": {
                    "account_id": 10030,
                    "reputation": 339134,
                    "user_id": 18771,
                    "user_type": "registered",
                    "accept_rate": 87,
                    "profile_image": "https://www.gravatar.com/avatar/0ada184c98bf9073d15b2dc815be0170?s=256&d=identicon&r=PG",
                    "display_name": "Tomalak",
                    "link": "https://stackoverflow.com/users/18771/tomalak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1441655052,
                "post_id": 32442433,
                "comment_id": 52753743,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "user_type": "does_not_exist",
                    "display_name": "user3899165"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1441655242,
                "post_id": 32442433,
                "comment_id": 52753817,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 2795620,
                    "reputation": 102,
                    "user_id": 2404894,
                    "user_type": "registered",
                    "accept_rate": 75,
                    "profile_image": "https://www.gravatar.com/avatar/ca54e48346cde9f30e08770852251281?s=256&d=identicon&r=PG",
                    "display_name": "geledek",
                    "link": "https://stackoverflow.com/users/2404894/geledek"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1441659060,
                "post_id": 32442433,
                "comment_id": 52755257,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 2795620,
                    "reputation": 102,
                    "user_id": 2404894,
                    "user_type": "registered",
                    "accept_rate": 75,
                    "profile_image": "https://www.gravatar.com/avatar/ca54e48346cde9f30e08770852251281?s=256&d=identicon&r=PG",
                    "display_name": "geledek",
                    "link": "https://stackoverflow.com/users/2404894/geledek"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1441659120,
                "post_id": 32442433,
                "comment_id": 52755280,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 166270,
                    "reputation": 135171,
                    "user_id": 390278,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/84715fec547362389d02f5be0ed12814?s=256&d=identicon&r=PG",
                    "display_name": "Jeff Mercado",
                    "link": "https://stackoverflow.com/users/390278/jeff-mercado"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1441670971,
                "post_id": 32442433,
                "comment_id": 52758101,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 2795620,
                    "reputation": 102,
                    "user_id": 2404894,
                    "user_type": "registered",
                    "accept_rate": 75,
                    "profile_image": "https://www.gravatar.com/avatar/ca54e48346cde9f30e08770852251281?s=256&d=identicon&r=PG",
                    "display_name": "geledek",
                    "link": "https://stackoverflow.com/users/2404894/geledek"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1441725484,
                "post_id": 32442433,
                "comment_id": 52784988,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1441742882,
                "creation_date": 1441742882,
                "answer_id": 32466392,
                "question_id": 32442433,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "It&#39;s not clear to me from your description whether each business and each review is a top-level object. However it appears that you can arrange that both businesses and reviews can be presented as streams, so in the following, I will assume that:\r\n\r\n    (a) both reviews.json and businesses.json are files of JSON objects;\r\n    (b) it is acceptable to read all the reviews into memory.\r\n\r\n(If, conversely, it is only acceptable to read the businesses into memory, the following can easily be revised.)\r\n\r\nThe logic is: read all the reviews, and then for each restaurant, extract the reviews for that restaurant.\r\n\r\n    select(.categories | index(&quot;Restaurant&quot;))\r\n    | .business_id as $business_id\r\n    | $reviews[]\r\n    | select( .type == &quot;review&quot; and .business_id == $business_id)\r\n\r\nInvocation:\r\n\r\n    $ jq --slurpfile reviews reviews.json yelp.jq businesses.json\r\n\r\nPlease note that the --slurpfile option is NOT available in jq 1.4. \r\n\r\n(If reviews.json is already an array of JSON objects, then you could use --argfile reviews reviews.json, and thus would not need jq 1.5.)\r\n\r\n",
                "title": "Join and filter JSON files using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1441742882,
        "creation_date": 1441641531,
        "last_edit_date": 1441652153,
        "question_id": 32442433,
        "body_markdown": "i am working on a Yelp json corpus with `jq`, desperately trying to accomplish some join &amp; filter task.\r\nThe *business.json* contains **categories** and **business_id**, from which I can get all ids of restaurants, using which I want to filter the *review.json* to extract all reviews for restaurants.\r\n\r\nSounds straight forward in RDBMS but I want to learn the `jq` way.\r\n\r\nCan anyone help?\r\n\r\nThings I have tried.\r\n\r\n1. Extracted business ID and saved in id.txt. But it is impossible to refer to id.txt in `jq`.\r\n\r\n2. In a script loop all ids and execute `jq --arg id $line &#39;. | select( .business_id | contains($id))&#39; reviews.json`\r\n\r\n3. Joining the two json files maybe possible but I am reluctant to do, due to the size of the files (~1G)\r\n\r\nEdited according to comments:\r\n\r\nSimplified sample input:\r\nbusiness.json\r\n&gt;    {\r\n\r\n&gt;    &quot;business_id&quot;: &quot;vcNAWiLM4dR7D2nwwJ7nCA&quot;, \r\n\r\n&gt;    &quot;full_address&quot;: &quot;4840 E Indian School Rd\\nSte 101\\nPhoenix, AZ 85018&quot;,  &gt;   &gt;   \r\n\r\n&gt;    &quot;categories&quot;: [&quot;Restaurant&quot;]\r\n\r\n&gt;    }\r\n\r\nreviews.json\r\n&gt;    {\r\n\r\n&gt;    &quot;date&quot;: &quot;2012-05-15&quot;,\r\n\r\n&gt;    &quot;text&quot;: &quot;Got a letter in the mail last week that said Dr. Goldberg is moving to Arizona to take a new position there in June.  He will be missed very much.  \\n\\nI think finding a new doctor in NYC that you actually like might almost be as awful as trying to find a date!&quot;,\r\n\r\n&gt;    &quot;type&quot;: &quot;review&quot;,\r\n\r\n&gt;    &quot;business_id&quot;: &quot;vcNAWiLM4dR7D2nwwJ7nCA&quot;\r\n&gt;     }\r\n\r\n\r\nBest attemp:\r\nAble to march documents with multiple ids, like\r\n \r\n`jq &#39;. | select( .business_id | contains(&quot;LRKJF43s9-3jG9Lgx4zODg&quot;, &quot;uGykseHzyS5xAMWoN6YUqA&quot;))&#39; reviews.json`\r\n\r\nBut couldn&#39;t replace the query strings with variables,\r\n\r\n`jq --arg t vcNAWiLM4dR7D2nwwJ7nCA &#39;. | select( .business_id | contains(env.t))&#39; reviews.json` doesn&#39;t work",
        "link": "https://stackoverflow.com/questions/32442433/join-and-filter-json-files-using-jq",
        "title": "Join and filter JSON files using jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1441773639,
                "last_edit_date": 1441773639,
                "creation_date": 1441772623,
                "answer_id": 32470872,
                "question_id": 32470524,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The following has been tested with jq 1.4 and jq 1.5:\r\n\r\n    $ jq -M -c &#39;(paths | select(.[length-1] ==&quot;age&quot;)) as $path\r\n        | if (getpath($path) &gt; 35) then $path else empty end&#39; ages.json\r\n    [&quot;springfield&quot;,&quot;homer&quot;,&quot;age&quot;]\r\n    [&quot;shelbyville&quot;,&quot;zone2&quot;,&quot;mark&quot;,&quot;age&quot;]\r\n    [&quot;homeless2&quot;,&quot;age&quot;]\r\n \r\nThe following requires jq 1.5:\r\n\r\n    $ jq -c --stream &#39;select(length == 2 and .[0][-1] == &quot;age&quot; \r\n        and .[1] &gt; 35)&#39; ages.json\r\n    [[&quot;springfield&quot;,&quot;homer&quot;,&quot;age&quot;],40]\r\n    [[&quot;shelbyville&quot;,&quot;zone2&quot;,&quot;mark&quot;,&quot;age&quot;],50]\r\n    [[&quot;homeless2&quot;,&quot;age&quot;],60]\r\n\r\nThese can both easily be adapted to produce similar output.",
                "title": "How can I use jq to find all paths in a JSON object under which a value matches a given criteria?"
            },
            {
                "up_vote_count": 6,
                "is_accepted": true,
                "score": 6,
                "last_activity_date": 1441781857,
                "creation_date": 1441781857,
                "answer_id": 32472813,
                "question_id": 32470524,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "This should do the trick:\r\n\r\n    [paths(.age?&gt;35)]",
                "title": "How can I use jq to find all paths in a JSON object under which a value matches a given criteria?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 4,
        "last_activity_date": 1441781857,
        "creation_date": 1441770116,
        "question_id": 32470524,
        "body_markdown": "Is there a way I could use jq to find all paths that hold a value that matches a given criteria?\r\n\r\nFor example, given the following JSON, I&#39;d like to return all paths where the value of &quot;age&quot; is &gt;35, regardless of the depth of the structure containing that field:\r\n\r\n    {  \r\n      &quot;springfield&quot;:{  \r\n        &quot;marge&quot;:{  \r\n          &quot;age&quot;:30\r\n        },\r\n        &quot;homer&quot;:{  \r\n          &quot;age&quot;:40,\r\n          &quot;job&quot;:&quot;xyz&quot;\r\n        }\r\n      },\r\n      &quot;shelbyville&quot;:{  \r\n        &quot;zone1&quot;:{  \r\n          &quot;john&quot;:{  \r\n            &quot;age&quot;:10\r\n          }\r\n        },\r\n        &quot;zone2&quot;:{  \r\n          &quot;mark&quot;:{  \r\n            &quot;age&quot;:50\r\n          }\r\n        }\r\n      },\r\n      &quot;homeless1&quot;:{  \r\n        &quot;age&quot;:25\r\n      },\r\n      &quot;homeless2&quot;:{  \r\n        &quot;age&quot;:60\r\n      }\r\n    }\r\n\r\nSo the execution would yield something like:\r\n\r\n    [\r\n      [&quot;springfield&quot;, &quot;homer&quot;],\r\n      [&quot;shelbyville&quot;, &quot;zone2&quot;, &quot;mark&quot;],\r\n      [&quot;homeless2&quot;]\r\n    ]",
        "link": "https://stackoverflow.com/questions/32470524/how-can-i-use-jq-to-find-all-paths-in-a-json-object-under-which-a-value-matches",
        "title": "How can I use jq to find all paths in a JSON object under which a value matches a given criteria?"
    },
    {
        "tags": [
            "arrays",
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6931311,
                    "reputation": 209,
                    "user_id": 5320733,
                    "user_type": "registered",
                    "profile_image": "https://lh4.googleusercontent.com/-F2-E9rHzqM4/AAAAAAAAAAI/AAAAAAAAABY/1MNG6BxVwDQ/s256-rj/photo.jpg",
                    "display_name": "Bob Neurone",
                    "link": "https://stackoverflow.com/users/5320733/bob-neurone"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1441892812,
                "post_id": 32499268,
                "comment_id": 52866545,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": -3,
                "last_activity_date": 1441895638,
                "creation_date": 1441895638,
                "answer_id": 32504801,
                "question_id": 32499268,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "As of jq 1.4, there&#39;s [`index/1`](https://stedolan.github.io/jq/manual/#%60index%28s%29%60,%60rindex%28s%29%60) or [`indices/1`](https://stedolan.github.io/jq/manual/#%60indices%28s%29%60) as outlined in the [manual](https://stedolan.github.io/jq/manual/).",
                "title": "Any JQ built-in function returning index of element in JSON array?"
            },
            {
                "up_vote_count": 10,
                "is_accepted": false,
                "score": 10,
                "last_activity_date": 1540447908,
                "last_edit_date": 1540447908,
                "creation_date": 1441901963,
                "answer_id": 32507010,
                "question_id": 32499268,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "There are two robust (i.e., that work in jq 1.3, 1.4 and 1.5) ways to iterate through an array with an index: one is to use keys[] (which works on arrays as well as objects), and the other using range/2.  These two approaches can be illustrated as follows, assuming $a is an array:\r\n\r\n\r\n    ($a | keys[]) as $i | [$i, $a[$i]] \r\n  \r\n    range(0; $a | length) as $i | [$i, $a[$i]]\r\n\r\nOr more succinctly:\r\n\r\n    $a | keys[] as $i | [$i, .[$i]]\r\n\r\n    $a | range(0;length) as $i | [$i, .[$i]]\r\n\r\nIf your jq has `keys_unsorted`, you might wish to use it instead.\r\n\r\n(index/1 is probably not what is needed here.)\r\n\r\n",
                "title": "Any JQ built-in function returning index of element in JSON array?"
            },
            {
                "up_vote_count": 25,
                "is_accepted": false,
                "score": 25,
                "last_activity_date": 1510047422,
                "last_edit_date": 1510047422,
                "creation_date": 1495663115,
                "answer_id": 44169151,
                "question_id": 32499268,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "[`to_entries`](https://stedolan.github.io/jq/manual/#to_entries,from_entries,with_entries) should work perfectly.\r\n\r\n    jq -n &#39;[&quot;a&quot;,&quot;b&quot;,&quot;c&quot;] | to_entries&#39;\r\n\r\nwill produce\r\n\r\n    [{&quot;key&quot;:0,&quot;value&quot;:&quot;a&quot;},{&quot;key&quot;:1,&quot;value&quot;:&quot;b&quot;},{&quot;key&quot;:2,&quot;value&quot;:&quot;c&quot;}]",
                "title": "Any JQ built-in function returning index of element in JSON array?"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 19,
        "last_activity_date": 1540447908,
        "creation_date": 1441880628,
        "last_edit_date": 1488927501,
        "question_id": 32499268,
        "body_markdown": "I have created a csv output from an input JSON file.\r\n\r\nSince some JSON arrays do not have their own id&#39;s, I need to add a unique id in my csv output that will be based on index of current element in its JSON array. \r\n\r\nIs there any built-in JQ function returning the element index?",
        "link": "https://stackoverflow.com/questions/32499268/any-jq-built-in-function-returning-index-of-element-in-json-array",
        "title": "Any JQ built-in function returning index of element in JSON array?"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 4610597,
                    "reputation": 291,
                    "user_id": 3738838,
                    "user_type": "registered",
                    "accept_rate": 0,
                    "profile_image": "https://www.gravatar.com/avatar/b8eff35e3eae6795a2bdc9c54fbede9c?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "user3738838",
                    "link": "https://stackoverflow.com/users/3738838/user3738838"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1441916769,
                "post_id": 32509866,
                "comment_id": 52881091,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 4610597,
                    "reputation": 291,
                    "user_id": 3738838,
                    "user_type": "registered",
                    "accept_rate": 0,
                    "profile_image": "https://www.gravatar.com/avatar/b8eff35e3eae6795a2bdc9c54fbede9c?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "user3738838",
                    "link": "https://stackoverflow.com/users/3738838/user3738838"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1441917108,
                "post_id": 32509866,
                "comment_id": 52881250,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 4610597,
                    "reputation": 291,
                    "user_id": 3738838,
                    "user_type": "registered",
                    "accept_rate": 0,
                    "profile_image": "https://www.gravatar.com/avatar/b8eff35e3eae6795a2bdc9c54fbede9c?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "user3738838",
                    "link": "https://stackoverflow.com/users/3738838/user3738838"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1441918462,
                "post_id": 32509866,
                "comment_id": 52881904,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 1143565,
                    "reputation": 535973,
                    "user_id": 1126841,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa05233b2357f8d11c22ef4cfc7bb85c?s=256&d=identicon&r=PG",
                    "display_name": "chepner",
                    "link": "https://stackoverflow.com/users/1126841/chepner"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1441922460,
                "post_id": 32509866,
                "comment_id": 52883619,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1441996674,
                "last_edit_date": 1441996674,
                "creation_date": 1441913119,
                "answer_id": 32510120,
                "question_id": 32509866,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The question is a bit fuzzy, but since you mention &quot;the shell&quot;, the following might be relevant.  The *-r* option might also be relevant.\r\n\r\n\r\n    #!/bin/bash\r\n    \r\n    vars=($(jq -n &#39;&quot;a\\tb&quot;, &quot;{\\&quot;a\\&quot;:1}&quot; | @sh&#39;))\r\n    \r\n    for x in &quot;${vars[@]}&quot;\r\n    do\r\n      echo &quot;$x&quot;\r\n    done\r\n    \r\n\r\nThe above script, when run, produces:\r\n\r\n    &quot;&#39;a\\tb&#39;&quot;\r\n    &quot;&#39;{\\&quot;a\\&quot;:1}&#39;&quot;\r\n\r\n\r\nHere&#39;s a variant (and more dangerous) approach that uses *eval*:\r\n\r\n    jq -r &#39;@sh &quot;a=\\(.a) b=\\(.b)&quot;&#39; | while read -r line; do eval &quot;$line&quot;; done\r\n\r\n\r\nYou might also be able to do more of the processing in jq, so that (for example) you can create a pipeline, rather than setting shell variables.",
                "title": "How to create a custom report using jq?"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1441996674,
        "creation_date": 1441912115,
        "last_edit_date": 1441920118,
        "question_id": 32509866,
        "body_markdown": "What is the easiest way to take the json output of a curl statement and save variables created by filters in jq with the goal of creating a report (e.g., using javascript)? I love jq.play and can create filters to get firstname, lastname, etc. but want to use these results in a combined custom report and dont know how to save them to invidual variables from the shell. ",
        "link": "https://stackoverflow.com/questions/32509866/how-to-create-a-custom-report-using-jq",
        "title": "How to create a custom report using jq?"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1441972247,
                "creation_date": 1441972247,
                "answer_id": 32522849,
                "question_id": 32522064,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Use the assignment operator:\r\n\r\n    jq &#39;.user.songs = 40&#39; myfile",
                "title": "Edit an item and print the whole content with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1441972716,
        "creation_date": 1441969866,
        "last_edit_date": 1441972716,
        "question_id": 32522064,
        "body_markdown": "Say I have a JSON like this:\r\n\r\n    {\r\n        &quot;user&quot; :\r\n        {\r\n            &quot;name&quot;: &quot;Manu&quot;,\r\n            &quot;songs&quot;: 30\r\n        },\r\n        &quot;admin&quot; :\r\n        {\r\n            &quot;name&quot;: &quot;Chao&quot;,\r\n            &quot;songs&quot;: 50\r\n        }\r\n    }\r\n\r\nAnd I want to replace `user -&gt; songs` to 40 and print the whole file, so that I get:\r\n\r\n    {\r\n        &quot;user&quot; :\r\n        {\r\n            &quot;name&quot;: &quot;Manu&quot;,\r\n            &quot;songs&quot;: 40        &lt;------ this is the line to change\r\n        },\r\n        &quot;admin&quot; :\r\n        {\r\n            &quot;name&quot;: &quot;Chao&quot;,\r\n            &quot;songs&quot;: 50\r\n        }\r\n    }\r\n\r\nHow can I do this with [`jq`][1] (using `jq version 1.3`)? I tried the following, which successfully replaces the value but, then, does not print the whole thing:\r\n\r\n    $ jq &quot;[.user | { &quot;name&quot;: .name, &quot;songs&quot;: 40 }]&quot; myfile\r\n    [\r\n      {\r\n        &quot;songs&quot;: 40,\r\n        &quot;name&quot;: &quot;Manu&quot;\r\n      }\r\n    ]\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/#\r\n",
        "link": "https://stackoverflow.com/questions/32522064/edit-an-item-and-print-the-whole-content-with-jq",
        "title": "Edit an item and print the whole content with jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1442035487,
                "last_edit_date": 1442035487,
                "creation_date": 1442033869,
                "answer_id": 32535318,
                "question_id": 32534990,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You sometimes have to be careful what you ask for, but this will produce the result you said you want:\r\n\r\n    .channels[] as $channel\r\n    | $channel.name,\r\n      (.links[] | select(.id == $channel.id) | .streams[0].url) \r\n\r\nOutput for the given input:\r\n\r\n    &quot;Pop&quot;\r\n    &quot;http://example.com/pop&quot;\r\n    &quot;Rock&quot;\r\n    &quot;http://example.com/rock&quot;\r\n",
                "title": "jq: output values of ids instead of numbers"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1501798125,
                "creation_date": 1501798125,
                "answer_id": 45495316,
                "question_id": 32534990,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a solution which uses **reduce** and **setpath** to make a `$urls` lookup table from `.links` and then scans `.channels` generating corresponding urls and names.\r\n\r\n      (\r\n        reduce .links[] as $l (\r\n          {};\r\n          setpath([ $l.id|tostring ]; [$l.streams[].url])\r\n        )\r\n      ) as $urls\r\n    | .channels[]\r\n    | $urls[ .id|tostring ][], .name\r\n\r\nIf multiple urls are present in the &quot;streams&quot; attribute this will\r\nprint them all before printing the name.  e.g. if the input is\r\n\r\n    {\r\n        &quot;channels&quot;: [\r\n            { &quot;id&quot;: 1, &quot;name&quot;: &quot;Pop&quot;},\r\n            { &quot;id&quot;: 2, &quot;name&quot;: &quot;Rock&quot;}\r\n        ],\r\n        &quot;links&quot;: [\r\n            { &quot;id&quot;: 2, &quot;streams&quot;: [ {&quot;url&quot;: &quot;http://example.com/rock&quot;},\r\n                                    {&quot;url&quot;: &quot;http://example.com/hardrock&quot;} ] },\r\n            { &quot;id&quot;: 1, &quot;streams&quot;: [ {&quot;url&quot;: &quot;http://example.com/pop&quot;} ] }        \r\n        ]\r\n    }\r\n\r\nthe output will be\r\n\r\n    &quot;http://example.com/pop&quot;\r\n    &quot;Pop&quot;\r\n    &quot;http://example.com/rock&quot;\r\n    &quot;http://example.com/hardrock&quot;\r\n    &quot;Rock&quot;\r\n\r\n\r\n",
                "title": "jq: output values of ids instead of numbers"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": -1,
        "last_activity_date": 1501798125,
        "creation_date": 1442030021,
        "question_id": 32534990,
        "body_markdown": "Here&#39;s my input json:\r\n\r\n    {\r\n        &quot;channels&quot;: [\r\n            { &quot;id&quot;: 1, &quot;name&quot;: &quot;Pop&quot;},\r\n            { &quot;id&quot;: 2, &quot;name&quot;: &quot;Rock&quot;}\r\n        ],\r\n        &quot;links&quot;: [\r\n            { &quot;id&quot;: 2, &quot;streams&quot;: [ {&quot;url&quot;: &quot;http://example.com/rock&quot;} ] },\r\n            { &quot;id&quot;: 1, &quot;streams&quot;: [ {&quot;url&quot;: &quot;http://example.com/pop&quot;} ] }        \r\n        ]\r\n    }\r\n\r\nThis is what I want as an output:\r\n\r\n    &quot;http://example.com/pop&quot;\r\n    &quot;Pop&quot;\r\n    &quot;http://example.com/rock&quot;\r\n    &quot;Rock&quot;\r\n\r\nSo I need jq to replace `.channels[].id` with `.links[].streams[0].url` based on `.links[].id`\r\n\r\nI don&#39;t know if it&#39;s right, but this is how I managed to output the urls:\r\n\r\n    (.channels[].id | tostring) as $ids | [.links[]] | map({(.id | tostring): .streams[0].url}) | add as $urls | $urls[$ids]\r\n    \r\n    &quot;http://example.com/pop&quot;\r\n    &quot;http://example.com/rock&quot;\r\n\r\nThe question is, how do I add `.channels[].name` to it?",
        "link": "https://stackoverflow.com/questions/32534990/jq-output-values-of-ids-instead-of-numbers",
        "title": "jq: output values of ids instead of numbers"
    },
    {
        "tags": [
            "json",
            "windows",
            "batch-file",
            "cmd",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1858106,
                    "reputation": 24496,
                    "user_id": 1683264,
                    "user_type": "registered",
                    "accept_rate": 75,
                    "profile_image": "https://www.gravatar.com/avatar/1775f6311d777e21ee2c59df9769e60b?s=256&d=identicon&r=PG",
                    "display_name": "rojo",
                    "link": "https://stackoverflow.com/users/1683264/rojo"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1442318223,
                "post_id": 32584952,
                "comment_id": 53024450,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 1858106,
                    "reputation": 24496,
                    "user_id": 1683264,
                    "user_type": "registered",
                    "accept_rate": 75,
                    "profile_image": "https://www.gravatar.com/avatar/1775f6311d777e21ee2c59df9769e60b?s=256&d=identicon&r=PG",
                    "display_name": "rojo",
                    "link": "https://stackoverflow.com/users/1683264/rojo"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1442318445,
                "post_id": 32584952,
                "comment_id": 53024589,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1442319870,
                "last_edit_date": 1495542307,
                "creation_date": 1442319479,
                "answer_id": 32585899,
                "question_id": 32584952,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "In general, when you want to capture the output of a command to a variable, use a `for /F` loop.  `for /f &quot;delims=&quot; %%I in (&#39;command&#39;) do set &quot;variable=%%I&quot;` or similar.  See `help for` in a cmd console for more info.\r\n\r\n----\r\n\r\nIt is possible to make JScript interpret JSON similar to the way JavaScript would.  There are [security concerns](https://stackoverflow.com/a/27643386/1683264); but if you can be reasonably certain no one is likely to insert malicious code into the JSON, you can parse it without requiring 3rd party tools.\r\n\r\n---\r\n\r\nThis example script combines the two ideas mentioned above -- invoking a JScript code block with `cscript.exe`, and capturing its output with a `for /f` loop.\r\n\r\n**config.json:**\r\n\r\n&lt;!-- language-all: lang-js --&gt;\r\n\r\n\t{ &quot;path&quot; : { &quot;editor&quot; : &quot;...value...&quot; } }\r\n\r\n**parseJSON.bat:**\r\n\r\n\t@if (@CodeSection == @Batch) @then\r\n\t\r\n\t@echo off\r\n\tsetlocal\r\n\t\r\n\tset &quot;JSONfile=config.json&quot;\r\n\t\r\n\tfor /f &quot;delims=&quot; %%I in (&#39;cscript /nologo /e:JScript &quot;%~f0&quot; &quot;%JSONfile%&quot;&#39;) do set &quot;%%~I&quot;\r\n\t\r\n\trem // Delayed expansion prevents path names with symbols (&amp; or %) from choking the script\r\n\tsetlocal enabledelayedexpansion\r\n\techo editor: !editor!\r\n\tendlocal\r\n\t\r\n\tgoto :EOF\r\n\t\r\n\t@end // end batch / begin JScript chimera\r\n\t\r\n\tvar fso = WSH.CreateObject(&#39;scripting.filesystemobject&#39;),\r\n\t\tJSONfile = fso.OpenTextFile(WSH.Arguments(0), 1);\r\n\t\r\n\teval(&#39;obj = &#39; + JSONfile.ReadAll());\r\n\tJSONfile.Close();\r\n\t\r\n\tfunction walk(tree) {\r\n\t\tfor (var i in tree) {\r\n\t\t\tif (typeof tree[i] === &#39;object&#39;) walk(tree[i]);\r\n\t\t\telse WSH.Echo(i + &#39;=&#39; + tree[i]);\r\n\t\t}\r\n\t}\r\n\t\r\n\twalk(obj);\r\n\r\n**Output:**\r\n\r\n&gt; editor: ...value...",
                "title": "Get json config value into windows script variable"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1442328968,
                "creation_date": 1442328968,
                "answer_id": 32589274,
                "question_id": 32584952,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here are illustrations of two approaches using jq:\r\n\r\n    @echo off\r\n    setlocal\r\n\r\n    for /f &quot;delims=&quot; %%I in (&#39;jq -n -r &quot;\\&quot;123\\&quot;&quot;&#39;) do set A=%%I\r\n    echo A is %A%\r\n\r\n    jq -n -r  &quot;@sh \\&quot;set B=123\\&quot;&quot; &gt; setvars.bat\r\n    call .\\setvars.bat\r\n    echo B is %B%\r\n\r\n\r\nIn the first example, the batch file determines the variable name; in the second example, the jq program determines the variable name(s).\r\n\r\nBy the way, for non-Windows users, there is a &quot;recipe&quot; about this in the [jq Cookbook][1].\r\n\r\n  [1]: https://github.com/stedolan/jq/wiki/Cookbook#extract-data-and-set-shell-variables",
                "title": "Get json config value into windows script variable"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1547247621,
        "creation_date": 1442316747,
        "question_id": 32584952,
        "body_markdown": "I would like to parse config.json file and gets some specific values into variables.\r\n\r\nFollowing command is working, it print value from json:\r\n``type config.json | &quot;jq-win64.exe&quot; .path.editor``\r\n\r\n- config.json content:\r\n``{ &quot;path&quot; : { &quot;editor&quot; : &quot;...value...&quot; } }``\r\n\r\n- jq is library for json (https://stedolan.github.io/jq/)\r\n\r\nQuestion is how to get this value into some variable ?\r\n\r\nI tried this, but is not working:\r\n``set editorPath = type config.json | &quot;jq-win64.exe&quot; -r .path.editor``\r\n\r\nResult is that ``%editorPath%`` is empty\r\n\r\nMaybe it&#39;s related to jq library (https://stedolan.github.io/jq/) but I am quite noob in windows shell so maybe someone can help how to solve this issue.\r\n\r\nThanks",
        "link": "https://stackoverflow.com/questions/32584952/get-json-config-value-into-windows-script-variable",
        "title": "Get json config value into windows script variable"
    },
    {
        "tags": [
            "json",
            "unix",
            "command-line-interface",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1442350910,
                "last_edit_date": 1442350910,
                "creation_date": 1442340267,
                "answer_id": 32592767,
                "question_id": 32591769,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The following works using jq 1.4 or jq 1.5 with a Mac/Linux shell: \r\n\r\n    jq  &#39;.interpreterSettings.&quot;2B188AQ5T&quot;.properties.&quot;spark.executor.instances&quot; = &quot;16&quot; &#39; test.json\r\n\r\nIf you have trouble adapting the above for Windows, I&#39;d suggest putting the jq program in a file, say my.jq, and invoking it like so:\r\n\r\n    jq -f my.jq test.json\r\n\r\nNotice that there is no need to use &quot;cat&quot; in this case.\r\n\r\np.s. You were on the right track - try replacing *|=* with *+=*\r\n\r\n",
                "title": "Update inner attribute of JSON with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1548121303,
        "creation_date": 1442336742,
        "question_id": 32591769,
        "body_markdown": "Could somebody help me to deal with jq command line utility to update JSON object&#39;s inner value?\r\n\r\nI want to alter object `interpreterSettings.2B263G4Z1.properties` by adding several key-values, like `&quot;spark.executor.instances&quot;: &quot;16&quot;`. \r\n\r\nSo far I only managed to fully replace this object, not add new properties with command: \r\n\r\n    cat test.json | jq &quot;.interpreterSettings.\\&quot;2B188AQ5T\\&quot;.properties |= { \\&quot;spark.executor.instances\\&quot;: \\&quot;16\\&quot; }&quot;\r\n\r\nThis is input JSON:\r\n\r\n\t{\r\n\t  &quot;interpreterSettings&quot;: {\r\n\t\t&quot;2B263G4Z1&quot;: {\r\n\t\t  &quot;id&quot;: &quot;2B263G4Z1&quot;,\r\n\t\t  &quot;name&quot;: &quot;sh&quot;,\r\n\t\t  &quot;group&quot;: &quot;sh&quot;,\r\n\t\t  &quot;properties&quot;: {}\r\n\t\t},\r\n\t\t&quot;2B188AQ5T&quot;: {\r\n\t\t  &quot;id&quot;: &quot;2B188AQ5T&quot;,\r\n\t\t  &quot;name&quot;: &quot;spark&quot;,\r\n\t\t  &quot;group&quot;: &quot;spark&quot;,\r\n\t\t  &quot;properties&quot;: {\r\n\t\t\t&quot;spark.cores.max&quot;: &quot;&quot;,\r\n\t\t\t&quot;spark.yarn.jar&quot;: &quot;&quot;,\r\n\t\t\t&quot;master&quot;: &quot;yarn-client&quot;,\r\n\t\t\t&quot;zeppelin.spark.maxResult&quot;: &quot;1000&quot;,\r\n\t\t\t&quot;zeppelin.dep.localrepo&quot;: &quot;local-repo&quot;,\r\n\t\t\t&quot;spark.app.name&quot;: &quot;Zeppelin&quot;,\r\n\t\t\t&quot;spark.executor.memory&quot;: &quot;2560M&quot;,\r\n\t\t\t&quot;zeppelin.spark.useHiveContext&quot;: &quot;true&quot;,\r\n\t\t\t&quot;spark.home&quot;: &quot;/usr/lib/spark&quot;,\r\n\t\t\t&quot;zeppelin.spark.concurrentSQL&quot;: &quot;false&quot;,\r\n\t\t\t&quot;args&quot;: &quot;&quot;,\r\n\t\t\t&quot;zeppelin.pyspark.python&quot;: &quot;python&quot;\r\n\t\t  }\r\n\t\t}\r\n\t  },\r\n\t  &quot;interpreterBindings&quot;: {\r\n\t\t&quot;2AXUMXYK4&quot;: [\r\n\t\t  &quot;2B188AQ5T&quot;,\r\n\t\t  &quot;2AY8SDMRU&quot;\r\n\t\t]\r\n\t  }\r\n\t}\r\n\r\nI also tried the following but this only prints contents of `interpreterSettings.2B263G4Z1.properties`, not full object.\r\n\r\n    cat test.json | jq &quot;.interpreterSettings.\\&quot;2B188AQ5T\\&quot;.properties + { \\&quot;spark.executor.instances\\&quot;: \\&quot;16\\&quot; }&quot;",
        "link": "https://stackoverflow.com/questions/32591769/update-inner-attribute-of-json-with-jq",
        "title": "Update inner attribute of JSON with jq"
    }
]