[
    {
        "tags": [
            "json",
            "nested",
            "updates",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1482960647,
                "creation_date": 1482960647,
                "answer_id": 41369992,
                "question_id": 41369121,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Select only fields that are of type `object` and that match your condition (`A == 1`) : \r\n\r\n    jq &#39;(.foobar | .. | select(type == &quot;object&quot; and .A == 1)) |= .+ {&quot;baz&quot;: [&quot;bing&quot;, &quot;bop&quot;]}&#39; test.json\r\n\r\nThe `()` around the filter query take care that the whole document will be returned with the updated fields and not just your subdocument",
                "title": "Modifying nested json conditionally using jq"
            },
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1483023781,
                "last_edit_date": 1483023781,
                "creation_date": 1482999014,
                "answer_id": 41375582,
                "question_id": 41369121,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "In general it is better to avoid `..` if possible, for reasons of efficiency. In the present case, the following will do the job:\r\n\r\n    (.foobar[][] | select(.A == 1)) |= .+ {&quot;baz&quot;:[&quot;bing&quot;, &quot;bop&quot;]}",
                "title": "Modifying nested json conditionally using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 5,
        "last_activity_date": 1483091239,
        "creation_date": 1482956243,
        "last_edit_date": 1483091239,
        "question_id": 41369121,
        "body_markdown": "I would like to modify something like the following JSON:\r\n\r\n    {\r\n      &quot;foobar&quot;: {\r\n        &quot;a&quot;: {\r\n          &quot;adkjfe&quot;: {\r\n            &quot;A&quot;: 1,\r\n            &quot;foo&quot;: &quot;bar&quot;\r\n          }\r\n        },\r\n        &quot;b&quot;: {\r\n          &quot;ekjaei&quot;: {\r\n            &quot;A&quot;: 2,\r\n            &quot;bar&quot;: &quot;foo&quot;\r\n          }\r\n        }\r\n      }\r\n    }\r\n\r\nto add more data say `{&quot;baz&quot;: [&quot;bing&quot;, &quot;bop&quot;]}` to the parent of A if A=1. Assuming I don&#39;t know the parent key while leaving the rest of the json untouched. I&#39;ve tried many different things including:\r\n\r\n    .foobar | .. | .. | .[] | if select(.A==1) then . += {&quot;baz&quot;: &quot;bing&quot;} else . end \r\n\r\nwhich gives me an error and only my modified section. \r\n\r\nThe result, in this case, that I would like to see is:\r\n\r\n    {\r\n      &quot;foobar&quot;: {\r\n        &quot;a&quot;: {\r\n          &quot;adkjfe&quot;: {\r\n            &quot;A&quot;: 1,\r\n            &quot;foo&quot;: &quot;bar&quot;,\r\n            &quot;baz&quot;: [&quot;bing&quot;, &quot;bop&quot;]\r\n          }\r\n        },\r\n        &quot;b&quot;: {\r\n          &quot;ekjaei&quot;: {\r\n            &quot;A&quot;: 2,\r\n            &quot;bar&quot;: &quot;foo&quot;\r\n          }\r\n        }\r\n      }\r\n    }",
        "link": "https://stackoverflow.com/questions/41369121/modifying-nested-json-conditionally-using-jq",
        "title": "Modifying nested json conditionally using jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1482961415,
                "creation_date": 1482961415,
                "answer_id": 41370138,
                "question_id": 41369982,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You can use a `select` with `.tags[&quot;my.key&quot;] == &quot;true&quot;` and get only the `id` field :\r\n\r\n    jq &#39;.[] | select(.tags[&quot;my.key&quot;] == &quot;true&quot;) | .id&#39; data.json",
                "title": "how to select a json object where a child value array contains a certain propery"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1482961415,
        "creation_date": 1482960565,
        "question_id": 41369982,
        "body_markdown": "I have an array of objects similar to the following:\r\n\r\n    [\r\n      {\r\n        &quot;id&quot;: &quot;one&quot;,\r\n        &quot;tags&quot;: {\r\n          &quot;my.key&quot;: &quot;true&quot;\r\n        }\r\n      },\r\n      {\r\n        &quot;id&quot;: &quot;two&quot;,\r\n      }\r\n    ]\r\n\r\nHow can I select all &quot;id&quot; values for each object containing a tag where &quot;my.key&quot; is &quot;true&quot;?",
        "link": "https://stackoverflow.com/questions/41369982/how-to-select-a-json-object-where-a-child-value-array-contains-a-certain-propery",
        "title": "how to select a json object where a child value array contains a certain propery"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1483025538,
                "post_id": 41382610,
                "comment_id": 69967309,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 8344031,
                    "reputation": 2835,
                    "user_id": 6268432,
                    "user_type": "registered",
                    "accept_rate": 85,
                    "profile_image": "https://i.sstatic.net/pnLBv.png?s=256",
                    "display_name": "Alex",
                    "link": "https://stackoverflow.com/users/6268432/alex"
                },
                "reply_to_user": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1483025699,
                "post_id": 41382610,
                "comment_id": 69967397,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1483025989,
                "post_id": 41382610,
                "comment_id": 69967569,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 8344031,
                    "reputation": 2835,
                    "user_id": 6268432,
                    "user_type": "registered",
                    "accept_rate": 85,
                    "profile_image": "https://i.sstatic.net/pnLBv.png?s=256",
                    "display_name": "Alex",
                    "link": "https://stackoverflow.com/users/6268432/alex"
                },
                "reply_to_user": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1483026194,
                "post_id": 41382610,
                "comment_id": 69967666,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1483047432,
                "last_edit_date": 1483047432,
                "creation_date": 1483026548,
                "answer_id": 41382956,
                "question_id": 41382610,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "This `jq` filter should help you get `secretmail` string\r\n\r\n    jq &#39;.[] | select(.ParameterKey==&quot;RTSMEMAIL&quot;) | .ParameterValue&#39; json\r\n    &quot;secretemail&quot;\r\n\r\nAdd a `-r` file for raw output to remove quotes around the value\r\n\r\n    jq -r &#39;.[] | select(.ParameterKey==&quot;RTSMEMAIL&quot;) | .ParameterValue&#39; json\r\n    secretemail\r\n\r\n&gt;--raw-output / -r:\r\n\r\n&gt;With this option, if the filter’s result is a string then it will be written directly to standard output rather than being formatted as a JSON string with quotes. This can be useful for making jq filters talk to non-JSON-based systems.\r\n\r\nAs I could see it you are trying to pass `args` to `jq` filter, for extraction you can do something first by setting the variable in `bash` \r\n\r\n    email=&quot;RTSMEMAIL&quot;\r\n\r\nand now pass it to the filter as\r\n\r\n    jq --arg email &quot;$email&quot; -r &#39;.[] | select(.ParameterKey==$email) | .ParameterValue&#39; json \r\n    secretemail\r\n\r\nNow to replace the string obtained from `parameters_v13.json` file to your `GREPNAME_parameters.json` do the following steps:-\r\n\r\nFirst storing the result from the first file in a variable to re-use later, I have used the file to extract as `json`, this actually points your `parameters_v13.json` file in another path.\r\n\r\n    replacementValue=$(jq --arg email &quot;$email&quot; -r &#39;.[] | select(.ParameterKey==$email) | .ParameterValue&#39; json)\r\n\r\nnow the `$replacementValue` will hold the `secretmail` which you want to update to another file. As you have indicated previously `GREPNAME_parameters.json` has a similar syntax as of the first file. Something like below,\r\n\r\n    $ cat GREPNAME_parameters.json\r\n    [ \r\n    {\r\n       &quot;ParameterKey&quot;: &quot;SOMEJUNK&quot;,\r\n       &quot;ParameterValue&quot;: &quot;somejunkvalue&quot;\r\n      }\r\n    ]\r\n\r\nNow I understand your intention is replace `&quot;ParameterValue&quot;` from the above file to the value obtained from the other file. To achieve that, \r\n\r\n    jq --arg replace &quot;$replacementValue&quot; &#39;.[] | .ParameterValue = $replace&#39; GREPNAME_parameters.json\r\n    {\r\n      &quot;ParameterKey&quot;: &quot;SOMEJUNK&quot;,\r\n      &quot;ParameterValue&quot;: &quot;secretemail&quot;\r\n    }\r\n\r\nYou can then write this output to the a temp file and move it back as the `GREPNAME_parameters.json`. Hope this answers your question.",
                "title": "Get json field value with JQ from different directory"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1483056308,
                "last_edit_date": 1483056308,
                "creation_date": 1483046429,
                "answer_id": 41387346,
                "question_id": 41382610,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "@Alex - \r\n\r\n(1) `sponge` simply provides a convenient way to modify a file without having to manage a temporary file.  You could use it like this:\r\n\r\n    jq  ........ input.json | sponge input.json\r\n\r\nHere, &quot;input.json&quot; is the file that you want to edit &quot;in place&quot;.  If you want to avoid overwriting the input file, you would not use `sponge`.  In fact, I would recommend against doing so until you&#39;re absolutely sure that&#39;s what you want.\r\n\r\n(2) There are several strategies for achieving what you have described using jq. They basically fall into two categories: (a) invoke jq twice; (b) invoke jq once.\r\n\r\nIgnoring the `sponge` part:\r\n\r\n- the pattern for using jq twice would be as follows:\r\n\r\n        param=$(jq -r &#39;.[]\r\n          | select(.ParameterKey == &quot;RTSMEMAIL&quot;)|.ParameterValue\r\n          &#39; cloudformation/parameters_v13.json )\r\n\r\n        jq --arg param &quot;$param&quot; -f edit.jq input.json\r\n\r\n* assuming you have jq 1.5, the pattern for doing everything with just one invocation of jq would be:\r\n\r\n        jq --argfile p cloudformation/parameters_v13.json -f manage.jq input.json\r\n\r\nHere, edit.jq and manage.jq are files containing suitable jq programs.\r\n\r\nBased on my understanding of your requirements, edit.jq might look like this:\r\n\r\n    (.[] | select(.ParameterKey == &quot;RTSMEMAIL&quot;)|.ParameterValue) |= $param\r\n\r\nAnd manage.jq might look like this:\r\n\r\n    ($p[] | select(.ParameterKey == &quot;RTSMEMAIL&quot;)|.ParameterValue) as $param\r\n    | (.[]| select(.ParameterKey == &quot;RTSMEMAIL&quot;)|.ParameterValue) |= $param\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n",
                "title": "Get json field value with JQ from different directory"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1483056308,
        "creation_date": 1483025187,
        "last_edit_date": 1483025682,
        "question_id": 41382610,
        "body_markdown": "Title may be incorrect as I&#39;m not actually sure where this is failing. I have a bash script running in one directory, and a JSON file I need a value from in a different directory. I want to copy the value from the external directory into an identical JSON file in the current directory.\r\n\r\nI&#39;m using jq to grab the value, but I can&#39;t figure out how to grab from a directory other than the one the script is running in. \r\n\r\nThe relevant bits of file structure are as follows;\r\n\r\n    cloudformation\r\n      - parameters_v13.json\r\n    environment_files\r\n      - prepare_stack_files.json (the script this is run from)\r\n      - directory, changes based on where the script is pointed\r\n          - created directory where created files are being output\r\n             - GREPNAME_parameters.json\r\n\r\nThe chunk of the JSON file I&#39;m interested in looks like this;\r\n\r\n    [ \r\n    {\r\n       &quot;ParameterKey&quot;: &quot;RTSMEMAIL&quot;,\r\n       &quot;ParameterValue&quot;: &quot;secretemail&quot;\r\n      }\r\n    ]\r\n\r\nThe script needs to get the &quot;secretemail&quot; from `cloudformation/parameters_v13.json`  and paste it into the matching RTSMEMAIL field in the `GREPNAME_parameters.json` file. \r\n\r\nI&#39;ve been attempting the following with no luck - nothing is output. No error message either, just blank output. I know the GREPNAME path is correct because it&#39;s used elsewhere with no issues.\r\n\r\n    jq --arg email &quot;$EMAIL&quot; &#39;(.[] | select(.ParameterKey == &quot;RTSMEMAIL&quot;) | .ParameterValue) |= $email&#39; ../cloudformation/parameters_v13.json | sponge ${GREPNAME}_parameters.json",
        "link": "https://stackoverflow.com/questions/41382610/get-json-field-value-with-jq-from-different-directory",
        "title": "Get json field value with JQ from different directory"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 9,
                "is_accepted": true,
                "score": 9,
                "last_activity_date": 1483040635,
                "creation_date": 1483040635,
                "answer_id": 41386230,
                "question_id": 41386019,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The following might work:\r\n\r\n    $ jq -r &#39;.indices | to_entries[] | &quot;\\(.key): \\(.value.primaries.docs.count)&quot;&#39; input.json\r\n    plan: 14208\r\n    resource: 1427143\r\n    user: 104475\r\n\r\nThe above assumes the input is:\r\n\r\n    {\r\n      &quot;indices&quot;: {\r\n        &quot;plan&quot;:     { &quot;primaries&quot;: { &quot;docs&quot;: { &quot;count&quot;: 123 }}},\r\n        &quot;resource&quot;: { &quot;primaries&quot;: { &quot;docs&quot;: { &quot;count&quot;: 456 }}},\r\n        &quot;user&quot;:     { &quot;primaries&quot;: { &quot;docs&quot;: { &quot;count&quot;: 789 }}}\r\n      }\r\n    }\r\n\r\n`to_entries` will convert the object `indices` to an array:\r\n\r\n    [\r\n      { &quot;key&quot;: &quot;plan&quot;, &quot;value&quot;: { ... } },\r\n      ...,\r\n      ...\r\n    ]\r\n\r\nWhich can then be easily mapped.",
                "title": "jq - How to print key (not value of key) and iterate over keys to print sub value"
            },
            {
                "up_vote_count": 7,
                "is_accepted": false,
                "score": 7,
                "last_activity_date": 1505021823,
                "creation_date": 1505021823,
                "answer_id": 46137616,
                "question_id": 41386019,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a solution that uses keys directly:\r\n\r\n      .indices\r\n    | keys[] as $k\r\n    | &quot;\\($k): \\(.[$k].primaries.docs.count)&quot;\r\n",
                "title": "jq - How to print key (not value of key) and iterate over keys to print sub value"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 9,
        "last_activity_date": 1593190236,
        "creation_date": 1483039599,
        "last_edit_date": 1593190236,
        "question_id": 41386019,
        "body_markdown": "I can print the keys:\r\n\r\n    $ jq -r &#39;.indices | keys[]&#39;\r\n    plan\r\n    resource\r\n    user\r\n\r\n\r\nI can print the sub value:\r\n\r\n    $ jq &#39;.indices[] | .primaries.docs.count&#39;\r\n    14208\r\n    1427143\r\n    104475\r\n\r\nHow do I print the key and subvalue?\r\n\r\n    plan: 14208\r\n    resource: 1427143\r\n    user: 104475",
        "link": "https://stackoverflow.com/questions/41386019/jq-how-to-print-key-not-value-of-key-and-iterate-over-keys-to-print-sub-valu",
        "title": "jq - How to print key (not value of key) and iterate over keys to print sub value"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1524003927,
                "last_edit_date": 1524003927,
                "creation_date": 1483062946,
                "answer_id": 41389633,
                "question_id": 41389347,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "    .a | .[] | .c\r\n\r\nwhich can be abbreviated as:\r\n\r\n    .a[].c\r\n\r\n## Value of all .c keys\r\n\r\nIf you wanted the value of all keys named &quot;c&quot;, no matter where they occur:\r\n\r\n    .. | .c? // empty\r\n\r\n",
                "title": "Unix jq parsing wildcards"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1524003927,
        "creation_date": 1483060349,
        "question_id": 41389347,
        "body_markdown": "I have a json output with dozens of entries following this format:\r\n\r\n    {\r\n      &quot;a&quot;: {\r\n        &quot;1&quot;: {\r\n          &quot;c&quot;: &quot;text1&quot;\r\n        },\r\n    dozens more ...\r\n        &quot;999&quot;: {\r\n          &quot;c&quot;: &quot;text99&quot;\r\n        }\r\n      }\r\n    }\r\n\r\nI want the &quot;c&quot; value for each\r\nSomething like:\r\n&quot;.a.*.c&quot;\r\nAny suggestions?\r\n",
        "link": "https://stackoverflow.com/questions/41389347/unix-jq-parsing-wildcards",
        "title": "Unix jq parsing wildcards"
    },
    {
        "tags": [
            "arrays",
            "json",
            "bash",
            "unix",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1483472146,
                "last_edit_date": 1483472146,
                "creation_date": 1483071503,
                "answer_id": 41390550,
                "question_id": 41389981,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "In terms of your intermediate results &quot;A&quot; and &quot;B&quot; (denoted below by $a and $b), the following filter produces the required answer. The key is `transpose`:\r\n\r\n\r\n    ($a | [.hits_percents, .visitors_percents, .bytes_percents] | transpose)\r\n    | . as $v\r\n    | reduce range(0; length) as $i\r\n        ($b;\r\n           .[$i].hits.percent = $v[$i][0] \r\n         | .[$i].visitors.percent = $v[$i][1]\r\n         | .[$i].bytes.percent = $v[$i][2] )\r\n\r\nThere is probably a better way to get the final result, but you asked how the two intermediate results can be combined....\r\n\r\n\r\n### Bonus question:\r\n\r\n\r\n     # Round a (positive) percentage to two decimal places:\r\n     def percent:\r\n       ((1000 * .) | floor)\r\n       | (. % 10) as $r\r\n       | ((. / 10) | floor) as $answer\r\n       | if $r &gt; 4 then ($answer + 1) else $answer end\r\n       | . / 100\r\n       ;\r\n\r\nThis could be used by adding `map(map(percent))` after the transposition: \r\n\r\n\r\n    def percent:\r\n      ((1000 * .) | floor)\r\n      | (. % 10) as $r\r\n      | ((. / 10) | floor) as $answer\r\n      | if $r &gt; 4 then ($answer + 1) else $answer end\r\n      | . / 100;\r\n    ($a | [.hits_percents, .visitors_percents, .bytes_percents] | transpose)\r\n      | map(map(percent))\r\n      | . as $v\r\n      | reduce range(0; length) as $i\r\n          ($b;\r\n             .[$i].hits.percent = $v[$i][0] \r\n           | .[$i].visitors.percent = $v[$i][1]\r\n           | .[$i].bytes.percent = $v[$i][2] )",
                "title": "Combine JSON files and recalculate percentages with JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1483472146,
        "creation_date": 1483066172,
        "question_id": 41389981,
        "body_markdown": "I&#39;m using `jq` inside a bash shell script to process a list of JSON files daily, which combines them into a new array. After I combine them I need to recalculate values based on the value of each object within the array. This new JSON file is then consumed in a client-facing analytics HTML report.\r\n\r\nI&#39;m so close to getting it working, but can&#39;t figure out how to combine my below `jq` filters.\r\n\r\nI can create an array of the recalculated percents in **Filter A**, and I can output the array I&#39;m expecting (minus the new percent values) in **Filter B** but can&#39;t find a way to combine these into a **Filter C**.\r\n\r\n**JQ Playground URL:** https://jqplay.org/#\r\n\r\n[**JSON input (located on gist.github)**](https://gist.github.com/skplunkerin/f14ef7d4f6e8ecfc16408fa44747d8f1#file-1-input-json)\r\n\r\n**Filter A:**\r\n\r\n    {&quot;hits_percents&quot;: [(.[].hits.count / (group_by(.hits.count) | map(map(.hits.count))|add|add)*100)], &quot;visitors_percents&quot;: [(.[].visitors.count / (group_by(.visitors.count) | map(map(.visitors.count))|add|add)*100)], &quot;bytes_percents&quot;: [(.[].bytes.count / (group_by(.bytes.count) | map(map(.bytes.count))|add|add)*100)]}\r\n\r\n**Output A:**\r\n\r\n    {\r\n      &quot;hits_percents&quot;: [\r\n        1.2345679012345678,\r\n        8.641975308641975,\r\n        8.641975308641975,\r\n        9.876543209876543,\r\n        6.172839506172839,\r\n        3.7037037037037033,\r\n        1.2345679012345678,\r\n        2.4691358024691357,\r\n        58.0246913580247\r\n      ],\r\n      &quot;visitors_percents&quot;: [\r\n        4,\r\n        28.000000000000004,\r\n        28.000000000000004,\r\n        8,\r\n        4,\r\n        8,\r\n        4,\r\n        8,\r\n        8\r\n      ],\r\n      &quot;bytes_percents&quot;: [\r\n        0.31110007608374707,\r\n        36.59886623706793,\r\n        31.692110521802018,\r\n        7.187835244744665,\r\n        1.6285539319606,\r\n        5.880482040688714,\r\n        0.7481999111612437,\r\n        0.6484148671259253,\r\n        15.304437169365146\r\n      ]\r\n    }\r\n\r\n**Filter B:**\r\n\r\n    [.[] | { &quot;hits&quot;: {&quot;count&quot;: .hits.count, &quot;percent&quot;: &quot;TODO&quot; }, &quot;visitors&quot;: { &quot;count&quot;: .visitors.count, &quot;percent&quot;: &quot;TODO&quot;}, &quot;bytes&quot;: {&quot;count&quot;: .bytes.count, &quot;percent&quot;: &quot;TODO&quot;}, &quot;data&quot;: .data }]\r\n\r\n\r\n[**Output B (located on gist)**](https://gist.github.com/skplunkerin/f14ef7d4f6e8ecfc16408fa44747d8f1#file-2-unwanted-output-json)\r\n\r\n**Filter C:** (Filter A + B)\r\n\r\n    ????\r\n\r\n[**Desired Output C**](https://gist.github.com/skplunkerin/f14ef7d4f6e8ecfc16408fa44747d8f1#file-3-expected-output-json)\r\n\r\nAny suggestions on how I can get the **Output C** within a bash script using `jq` would be fantastic. I&#39;ve been turning my gears for several hours and currently out of ideas.\r\n\r\n-------\r\n\r\n**Bonus Question:** How can I get `jq` to round up 2 digits on the percents? \r\n\r\nI can&#39;t get any kind of math working, and their [Math documentation](https://stedolan.github.io/jq/manual/#Math) is too vague to help.\r\n",
        "link": "https://stackoverflow.com/questions/41389981/combine-json-files-and-recalculate-percentages-with-jq",
        "title": "Combine JSON files and recalculate percentages with JQ"
    },
    {
        "tags": [
            "json",
            "select",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1483216889,
                "creation_date": 1483216889,
                "answer_id": 41411586,
                "question_id": 41411283,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Assuming your input file contains an array of the model you posted, you can match your records with :\r\n\r\n    cat file1.json | jq &#39;.[] | select(.file_name | contains(&quot;197407&quot;))&#39;\r\n\r\nIn your statement `.file_name[]` means that you want to return each element of the array `file_name`",
                "title": "Print all entries in a json file with specified value content, using jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1483276188,
                "last_edit_date": 1483276188,
                "creation_date": 1483249564,
                "answer_id": 41413625,
                "question_id": 41411283,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Re: Q2\r\n\r\nFor efficiency, along the lines suggested by Jeff:\r\n\r\n    .[range(0;length;1000)]\r\n\r\nOr for fun:\r\n\r\n    recurse(.[1000:]; . !=  []) | .[0]",
                "title": "Print all entries in a json file with specified value content, using jq"
            }
        ],
        "is_answered": false,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1505521382,
        "creation_date": 1483213944,
        "last_edit_date": 1505521382,
        "question_id": 41411283,
        "body_markdown": "I&#39;m using jq for the first time.  I have a large json file with entries like the one below.  I would like to print the full content (like below) for all entries where the &quot;`file_name`&quot; contains 197407\r\n\r\n    {\r\n    \t&quot;license&quot;: 5,\r\n    \t&quot;file_name&quot;: &quot;COCO_train2014_000000057870.jpg&quot;,\r\n    \t&quot;coco_url&quot;: &quot;http://mscoco.org/images/57870&quot;,\r\n    \t&quot;height&quot;: 480,\r\n    \t&quot;width&quot;: 640,\r\n    \t&quot;date_captured&quot;: &quot;2013-11-14 16:28:13&quot;,\r\n    \t&quot;flickr_url&quot;: &quot;http://farm4.staticflickr.com/3153/2970773875_164f0c0b83_z.jpg&quot;,\r\n    \t&quot;id&quot;: 57870\r\n    }\r\n\r\nI tried the following, and got the following error:\r\n\r\n    $ cat file1.json | jq -c &#39;.file_name[]  | \r\n    select(.file_name[]|contains(&quot;197407&quot;))&#39; \r\n    \r\n    jq: error: Cannot iterate over null\r\n\r\nQuestion2: I would like to “sample” the contents of the file (it contains multiple formats of content), perhaps by printing every 1,000th entry.  Can `jq` do this ?\r\n\r\n",
        "link": "https://stackoverflow.com/questions/41411283/print-all-entries-in-a-json-file-with-specified-value-content-using-jq",
        "title": "Print all entries in a json file with specified value content, using jq"
    },
    {
        "tags": [
            "json",
            "bash",
            "shell",
            "dictionary",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1535031435,
                "last_edit_date": 1535031435,
                "creation_date": 1483311506,
                "answer_id": 41419770,
                "question_id": 41418646,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I&#39;m assuming your JSON is in `infile.json` and the text with the tags to be replaced in `infile.txt`.\r\n\r\nHere is an entirely unreadable one-liner that does it:\r\n\r\n    $ sed -f &lt;(jq -r &#39;to_entries[] | [.key, .value] | @tsv&#39; &lt; infile.json | sed &#39;s~^~s|%~;s~\\t~%|~;s~$~|g~&#39;) infile.txt\r\n    Lamba login name is lambda, and avatar url is https://avatars.githubusercontent.com/u/37398?v=3\r\n\r\nNow, to decipher what this does. First, a few linebreaks for readability:\r\n\r\n    sed -f &lt;(\r\n        jq -r &#39;\r\n            to_entries[] |\r\n            [.key, .value] |\r\n            @tsv\r\n        &#39; &lt; infile.json |\r\n        sed &#39;\r\n            s~^~s|%~\r\n            s~\\t~%|~\r\n            s~$~|g~\r\n        &#39;\r\n    ) infile.txt\r\n\r\nWe&#39;re basically using a sed command that takes its instructions from a file; instead of an actual file, we use process substitution to generate the sed commands:\r\n\r\n    jq -r &#39;to_entries[] | [.key, .value] | @tsv&#39; &lt; infile.json |\r\n        sed &#39;s~^~s|%~;s~\\t~%|~;s~$~|g~&#39;\r\n\r\nSome processing with jq, followed by some sed substitutions.\r\n\r\nThis is what the jq command does:\r\n\r\n* Generate raw output (no quotes, actual tabs instead of `\\t`) with the [`-r`](https://stedolan.github.io/jq/manual/v1.5/#Invokingjq) option\r\n* Turn the input JSON object into an array of key-value pairs with the [`to_entries`](https://stedolan.github.io/jq/manual/v1.5/#to_entries,from_entries,with_entries) function, resulting in\r\n\r\n        [\r\n          {\r\n            &quot;key&quot;: &quot;login&quot;,\r\n            &quot;value&quot;: &quot;lambda&quot;\r\n          },\r\n          {\r\n            &quot;key&quot;: &quot;id&quot;,\r\n            &quot;value&quot;: 37398\r\n          },\r\n          ...\r\n    ]\r\n\r\n* Get all elements of the array with [`[]`](https://stedolan.github.io/jq/manual/v1.5/#.[]):\r\n    \r\n        {\r\n          &quot;key&quot;: &quot;login&quot;,\r\n          &quot;value&quot;: &quot;lambda&quot;\r\n        }\r\n        {\r\n          &quot;key&quot;: &quot;id&quot;,\r\n          &quot;value&quot;: 37398\r\n        }\r\n        ...\r\n* Get a list of arrays with key/value in each using [`[.key, .value]`](https://stedolan.github.io/jq/manual/v1.5/#Arrayconstruction-[]), resulting in\r\n    \r\n        [\r\n          &quot;login&quot;,\r\n          &quot;lambda&quot;\r\n        ]\r\n        [\r\n          &quot;id&quot;,\r\n          37398\r\n        ]\r\n        ...\r\n\r\n* Finally, use the [`@tsv`](https://stedolan.github.io/jq/manual/v1.5/#Formatstringsandescaping) filter to get the key-value pairs as a tab separated list:\r\n    \r\n        login   lambda\r\n        id      37398\r\n        ...\r\n\r\nNow, we pipe this to sed, which performs three substitutions:\r\n\r\n* `s~^~s|%~` &amp;ndash; add `s|%` to the beginning of each line\r\n* `s~\\t~%|~` &amp;ndash; replace the tab with `%|`\r\n* `s~$~|g~` &amp;ndash; add `|g` to the end of each line\r\n\r\nThis gives us a sed file that looks as follows:\r\n\r\n    s|%login%|lambda|g\r\n    s|%id%|37398|g\r\n    s|%avatar_url%|https://avatars.githubusercontent.com/u/37398?v=3|g\r\n\r\nNotice that for these substitutions, we used `~` as the delimiter, and for the substitution commands we generated, we used `|` &amp;ndash; mostly to avoid running into problems with strings containing `/`.\r\n\r\nIf this sed file were stored as `commands.sed`, the overall command would correspond to\r\n\r\n    sed -f commands.sed infile.txt\r\n\r\n----\r\n\r\n**Remarks**\r\n\r\n* If  your shell doesn&#39;t support process substitution, you could make sed read from standard input instead, using `sed -f -`:\r\n\r\n        jq -r &#39;to_entries[] | [.key, .value] | @tsv&#39; &lt; infile.json |\r\n            sed &#39;s~^~s|%~;s~\\t~%|~;s~$~|g~&#39; |\r\n            sed -f - infile.txt\r\n\r\n* If `infile.json` contained `|` or `~`, you would have to choose different delimiters for the sed substitutions (see for example [this answer](https://stackoverflow.com/a/4844945/3266847) about using a non-printable character as a delimiter) or even perform additional substitutions to get rid of the delimiting characters first and put them back in at the end (see [this](https://stackoverflow.com/q/407523/3266847) and [this](https://stackoverflow.com/q/29613304/3266847) Q&amp;A).\r\n* Some seds (such as BSD sed found in MacOS) have trouble with `\\t` used in the pattern to substitute. If that is the case, the command `s~\\t~%|~` has to be replaced by `s~&#39;$&#39;\\t&#39;&#39;~%|~` to &quot;splice in&quot; the tab character, or (if the shell doesn&#39;t support ANSI-C quoting) even with `s~&#39;&quot;$(printf &#39;\\t&#39;)&quot;&#39;~%|~`.\r\n\r\n",
                "title": "Replace tags in text file using key-value pairs from JSON file"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1483414926,
                "last_edit_date": 1483414926,
                "creation_date": 1483329052,
                "answer_id": 41421149,
                "question_id": 41418646,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The whole thing can be done quite simply (and very efficiently) in jq.  \r\n\r\nFor the sake of illustration, suppose we have defined `dictionary` to be the dictionary object given in the question, and `template` to be the template string:\r\n\r\n    def dictionary: { ...... };\r\n\r\n    def template: \r\n      &quot;Lamba login name is %login%, and avatar url is %avatar_url%&quot;;\r\n\r\nThen the required interpolation can be performed as follows:\r\n\r\n    dictionary\r\n    | reduce to_entries[] as $pair (template; gsub(&quot;%\\($pair.key)%&quot;; $pair.value))\r\n\r\nThe above produces:\r\n\r\n\r\n    &quot;Lamba login name is lambda, and avatar url is https://avatars.githubusercontent.com/u/37398?v=3&quot;\r\n\r\nThere are of course many other ways in which the dictionary and template string can be presented.\r\n",
                "title": "Replace tags in text file using key-value pairs from JSON file"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1650966111,
                "last_edit_date": 1650966111,
                "creation_date": 1650965398,
                "answer_id": 72011555,
                "question_id": 41418646,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a simple sed solution. Assume that the json Object is in x.json and the file where the replacements should be done in f.txt.\r\nThe following x.sed - Programm called as\r\n\r\n    sed -n -f x.sed x.json &lt;(echo FILE_DELIM) f.txt\r\n\r\ndoes the job. \r\n\r\nx.sed:\r\n\r\n    1,$H\r\n    $ {\r\n        x\r\n        :b\r\n        s/\\(&quot;\\([^&quot;]\\+\\)&quot; *: *\\(\\(&quot;\\([^&quot;]*\\)&quot;\\)\\|\\(\\(\\w\\|\\.\\)\\+\\)\\).*FILE_DELIM.*\\)%\\2%\\(.*\\)/\\1\\3\\8/\r\n        tb\r\n        s/.*FILE_DELIM\\n//\r\n        p\r\n    }\r\n\r\nThe trick is to save the two files (separated by the string FILE_DELIM) in one line in sed&#39;s hold space and then recursively replace the keys (e.g. %login%) by their values behind the FILE_DELIM.\r\nThe crucial point is to define the pattern which matches a key value pair in the json object. Here I used: \r\n\r\n&quot; followed by non &quot; followed by &quot; followed by blanks followed by a colon (*1) followed by blanks followed by (again a qouted string or a string consisting of (word characters or .)) (*2)\r\n\r\nThe backreference \\2 in the search pattern matches the key and is replaced with \\3 which matches the value.\r\n\r\n*1): Up to here this matches a key like &quot;login&quot;\r\n\r\n*2): The values are allowed to be &quot;xyz&quot;, &quot;&quot;, abc, 0.1, ...",
                "title": "Replace tags in text file using key-value pairs from JSON file"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 2,
        "last_activity_date": 1650966111,
        "creation_date": 1483301780,
        "last_edit_date": 1483372469,
        "question_id": 41418646,
        "body_markdown": "I am trying to write a shell script that can read a json string, decode it to an array and foreach through the array and use the key/value for replacing strings in another file.\r\n\r\nIf this were PHP, then I would write something like this.\r\n\r\n    $array = json_decode($jsonString, true);\r\n    foreach($array as $key =&gt; $value)\r\n    {\r\n      str_replace($key, $value, $rawString);\r\n    }\r\n\r\n\r\nI need this to be converted to Bash script.\r\nHere is the example JSON string.\r\n\r\n    {\r\n      &quot;login&quot;: &quot;lambda&quot;,\r\n      &quot;id&quot;: 37398,\r\n      &quot;avatar_url&quot;: &quot;https://avatars.githubusercontent.com/u/37398?v=3&quot;,\r\n      &quot;gravatar_id&quot;: &quot;&quot;,\r\n      &quot;url&quot;: &quot;https://api.github.com/users/lambda&quot;,\r\n      &quot;html_url&quot;: &quot;https://github.com/lambda&quot;,\r\n      &quot;followers_url&quot;: &quot;https://api.github.com/users/lambda/followers&quot;,\r\n      &quot;following_url&quot;: &quot;https://api.github.com/users/lambda/following{/other_user}&quot;,\r\n      &quot;gists_url&quot;: &quot;https://api.github.com/users/lambda/gists{/gist_id}&quot;,\r\n      &quot;starred_url&quot;: &quot;https://api.github.com/users/lambda/starred{/owner}{/repo}&quot;,\r\n      &quot;subscriptions_url&quot;: &quot;https://api.github.com/users/lambda/subscriptions&quot;,\r\n      &quot;organizations_url&quot;: &quot;https://api.github.com/users/lambda/orgs&quot;,\r\n      &quot;repos_url&quot;: &quot;https://api.github.com/users/lambda/repos&quot;,\r\n      &quot;events_url&quot;: &quot;https://api.github.com/users/lambda/events{/privacy}&quot;,\r\n      &quot;received_events_url&quot;: &quot;https://api.github.com/users/lambda/received_events&quot;,\r\n      &quot;type&quot;: &quot;User&quot;,\r\n      &quot;site_admin&quot;: false,\r\n      &quot;name&quot;: &quot;Brian Campbell&quot;,\r\n      &quot;company&quot;: null,\r\n      &quot;blog&quot;: null,\r\n      &quot;location&quot;: null,\r\n      &quot;email&quot;: null,\r\n      &quot;hireable&quot;: null,\r\n      &quot;bio&quot;: null,\r\n      &quot;public_repos&quot;: 27,\r\n      &quot;public_gists&quot;: 23,\r\n      &quot;followers&quot;: 8,\r\n      &quot;following&quot;: 2,\r\n      &quot;created_at&quot;: &quot;2008-11-30T21:03:27Z&quot;,\r\n      &quot;updated_at&quot;: &quot;2016-12-21T23:53:11Z&quot;\r\n    }\r\n\r\n\r\nI&#39;ve this file, \r\n\r\n&gt;     Lamba login name is %login%, and avatar url is %avatar_url%\r\n\r\nI am using jq\r\n\r\n    jq -c &#39;.[]&#39; /tmp/json | while read i; do\r\n       echo $i\r\n    done\r\n\r\nThis outputs only the value part. How do I loop through key and also get value? \r\n\r\nAlso, I&#39;ve found that the keys of the json string can be returned using \r\n\r\n    jq  &#39;keys&#39; /tmp/params\r\n\r\nHowever, I am still trying to figure out how to loop through the key and return the data.",
        "link": "https://stackoverflow.com/questions/41418646/replace-tags-in-text-file-using-key-value-pairs-from-json-file",
        "title": "Replace tags in text file using key-value pairs from JSON file"
    },
    {
        "tags": [
            "json",
            "increment",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1483462891,
                "last_edit_date": 1483462891,
                "creation_date": 1483389002,
                "answer_id": 41432947,
                "question_id": 41431965,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Assuming your jq has `foreach`:\r\n\r\n    # emit a stream of {id:_, value: _} objects\r\n    def counts(s; start):\r\n      foreach s as $i (start-1; .+1; {id:., value: $i});\r\n\r\n    [ counts(.z[] | select(has(&quot;name&quot;)); $START|tonumber)\r\n    | {id, name: .value.name} ]\r\n\r\nSince the above assumes you have `foreach`, you might as well also use the --argjson option, which allows you to pass the value of START in as a JSON number.\r\n\r\nIf your jq does not have `foreach`, then the above is easily modified to use `reduce` instead.\r\n\r\n### Postscript\r\n\r\nBased on the revision to the question, it looks like you will want your jq program to have the form:\r\n\r\n    .z = [ ... ]\r\n\r\nor \r\n\r\n    .z |= [[.[] | select(has(&quot;name&quot;))] | to_entries | ...\r\n\r\nor equivalent.",
                "title": "Increment arg in jq"
            },
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1483462480,
                "last_edit_date": 1483462480,
                "creation_date": 1483389684,
                "answer_id": 41433037,
                "question_id": 41431965,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You can use `to_entries`, which, when given an array, will give the index for each item : \r\n\r\n    jq --arg START 10 &#39;($START | tonumber) as $s\r\n      | [.z[] | select(has(&quot;name&quot;))]\r\n      | to_entries\r\n      | map({name:.value.name, id: ($s + .key) })&#39;\r\n\r\nThis way, `id` goes from `10 + 0` to `10 + n`",
                "title": "Increment arg in jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1483462891,
        "creation_date": 1483383182,
        "last_edit_date": 1483446637,
        "question_id": 41431965,
        "body_markdown": "I have something like: \r\n\r\n    jq --arg START 10 &#39;[.z[] | select(has(&quot;name&quot;)) | {id: $START | tonumber, name}]&#39;\r\n\r\ntransforming to an array of objects with a &#39;name&#39; key, appending an incremental id, which outputs:\r\n\r\n    [\r\n      {\r\n        id: 10,\r\n        name: &quot;stuff&quot;\r\n      },\r\n      {\r\n        id: 10,\r\n        name: &quot;more stuff&quot;\r\n      }\r\n    ]\r\n\r\nHow can I increment the START arg so that the second object has an id of 11 and so on?\r\n\r\nEDIT: I should have posted the original json:\r\n\r\n    {\r\n      &quot;u&quot;: &quot;stuff&quot;,\r\n      &quot;x&quot;: [1,2,3],\r\n      &quot;y&quot;: {\r\n        &quot;field&quot;: &quot;value&quot;\r\n      },\r\n      &quot;z&quot;: {\r\n        &quot;stuffWithoutName&quot;: {\r\n           &quot;ex&quot;: &quot;stuff&quot;\r\n        },\r\n        &quot;zz&quot;: {\r\n           &quot;name&quot;: &quot;change me&quot;,\r\n           &quot;more&quot;: &quot;stuff&quot;\r\n        },\r\n        &quot;randomKey&quot;:  {\r\n           &quot;name&quot;: &quot;change me&quot;,\r\n           &quot;random&quot;: &quot;more stuff&quot;\r\n        }\r\n      }\r\n    }\r\n\r\n\r\n\r\nThanks!",
        "link": "https://stackoverflow.com/questions/41431965/increment-arg-in-jq",
        "title": "Increment arg in jq"
    },
    {
        "tags": [
            "amazon-ec2",
            "aws-cli",
            "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": 1483478423,
                "post_id": 41452437,
                "comment_id": 70111417,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 9962494,
                    "reputation": 31,
                    "user_id": 7371298,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/182d221dd9a2481d243822e75fc91b00?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Nick Abbruzzese",
                    "link": "https://stackoverflow.com/users/7371298/nick-abbruzzese"
                },
                "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": 1483479383,
                "post_id": 41452437,
                "comment_id": 70111886,
                "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": 2,
                "creation_date": 1483479430,
                "post_id": 41452437,
                "comment_id": 70111915,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 9962494,
                    "reputation": 31,
                    "user_id": 7371298,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/182d221dd9a2481d243822e75fc91b00?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Nick Abbruzzese",
                    "link": "https://stackoverflow.com/users/7371298/nick-abbruzzese"
                },
                "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": 1,
                "creation_date": 1483479502,
                "post_id": 41452437,
                "comment_id": 70111952,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1741190376,
                "last_edit_date": 1741190376,
                "creation_date": 1483479965,
                "answer_id": 41452907,
                "question_id": 41452437,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Jeff Marcado&#39;s answer in the comments will be accepted if he writes it up as a full fledged answer. In the meantime, since I had hit a wall with trying to get JQ to do it, I experimented with the --query syntax for AWS to get this.\r\n\r\nIt might be a bit better, since this catches only objects that start with 10.10, whereas the jq from above will catch any object that contains 10.10, so things like 10.100. or 110.100, etc... will get through. That&#39;s assuming there is not a similar operator to &quot;starts_with&quot; in jq. Probably there is. Regardless, I&#39;m putting this here because it worked for my end goal and may be helpful to someone else at some point.\r\n\r\n&lt;!-- language: shell --&gt;\r\n    aws ec2 describe-instances \\\r\n        --no-paginate --filter &quot;Name=instance-state-name,Values=running&quot; \\\r\n        --query &#39;Reservations[].Instances[?starts_with(PrivateIpAddress, `10.10.`) == `false`]&#39; |\r\n      jq &#39;.[] | .[] | {PrivateIpAddress, PublicIpAddress, PublicDnsName}&#39;",
                "title": "JQ Select items that do not match string"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1741190389,
        "creation_date": 1483477837,
        "last_edit_date": 1741190389,
        "question_id": 41452437,
        "body_markdown": "I&#39;ve got a group of AWS instances that I&#39;m parsing via aws ec describe-instances. I&#39;m looking to trim out all the records whose IP&#39;s do not start with &#39;10.10&#39;.\r\n\r\n&lt;!-- language: shell --&gt;\r\n    aws ec2 describe-instances --no-paginate --filter &quot;Name=instance-state-name,Values=running&quot; --query &#39;Reservations[].Instances[].{Private:PrivateIpAddress,PublicDNS:PublicDnsName,PublicIP:PublicIpAddress}&#39; | jq &#39;.[] | select( .Private | contains(&quot;10.10&quot;))&#39;\r\n\r\nThis gets me the exact opposite of what I want. It seems logical that I should be able to negate the contains in some way - but I&#39;ve not been able to glean it from the documentation, nor through experimentation. My jq proficiency is middling, so perhaps I&#39;m using the wrong operator or function here. \r\n\r\nWhile i WOULD like an answer to this specific jq question - I&#39;ll accept an answer that utilizes JMESPath through the --query switch yield the same result. ",
        "link": "https://stackoverflow.com/questions/41452437/jq-select-items-that-do-not-match-string",
        "title": "JQ Select items that do not match string"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 9518332,
                    "reputation": 9585,
                    "user_id": 7073944,
                    "user_type": "registered",
                    "accept_rate": 83,
                    "profile_image": "https://i.sstatic.net/BecHV.png?s=256",
                    "display_name": "Vanquished Wombat",
                    "link": "https://stackoverflow.com/users/7073944/vanquished-wombat"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1483635036,
                "post_id": 41490031,
                "comment_id": 70186343,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 9518332,
                    "reputation": 9585,
                    "user_id": 7073944,
                    "user_type": "registered",
                    "accept_rate": 83,
                    "profile_image": "https://i.sstatic.net/BecHV.png?s=256",
                    "display_name": "Vanquished Wombat",
                    "link": "https://stackoverflow.com/users/7073944/vanquished-wombat"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1483636004,
                "post_id": 41490031,
                "comment_id": 70187047,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1483636889,
                "creation_date": 1483636889,
                "answer_id": 41491026,
                "question_id": 41490031,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "If you&#39;re only extracting a single value and the arrays will always correspond with eachother, you could find the index in the `columns` array then use that index into the `values` array.\r\n\r\nIt seems like `values` is an array of rows with those values.  Assuming you want to output the values of all rows with the selected column:\r\n\r\n    $ jq --arg col &#39;count_value&#39; &#39;.values[][.columns | index($col)]&#39; input.json",
                "title": "Having separate arrays, how to extract value based on the column name?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1483674539,
                "creation_date": 1483674539,
                "answer_id": 41498635,
                "question_id": 41490031,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "If the specified column name does not exist in .columns, then Jeff&#39;s filter will fail with a rather obscure error message.  It might therefore be preferable to check whether the column name is found.  Here is an illustration of how to do so:\r\n\r\n     jq --arg col count_value &#39;\r\n       (.columns | index($col)) as $ix\r\n       | if $ix then .values[][$ix] else empty end&#39; input.json\r\n\r\nIf you want an informative error message to be printed, then replace `empty` with something like:\r\n\r\n    error(&quot;specified column name, \\($col), not found&quot;)",
                "title": "Having separate arrays, how to extract value based on the column name?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1523736620,
        "creation_date": 1483633924,
        "last_edit_date": 1523736620,
        "question_id": 41490031,
        "body_markdown": "I am trying to extract data from some JSON with JQ - I have already got it down to the last level of data that I need to extract from, but I am completely stumped as to how to proceed with how this part of the data is formatted.\r\n\r\nAn example would be:\r\n\r\n    {\r\n      &quot;values&quot;: [\r\n        [\r\n          1483633677,\r\n          42\r\n        ]\r\n      ],\r\n      &quot;columns&quot;: [\r\n        &quot;time&quot;,\r\n        &quot;count_value&quot;\r\n      ],\r\n      &quot;name&quot;: &quot;response_time_error&quot;\r\n    }\r\n\r\nI would want to extract just the value for a certain column (e.g. `count_value`) and I can extract it by using `[-1]` in this specific case, but I want to select the column by its name in case they change in the future.",
        "link": "https://stackoverflow.com/questions/41490031/having-separate-arrays-how-to-extract-value-based-on-the-column-name",
        "title": "Having separate arrays, how to extract value based on the column name?"
    },
    {
        "tags": [
            "json",
            "path",
            "key",
            "schema",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1705,
                    "reputation": 180444,
                    "user_id": 1902010,
                    "user_type": "registered",
                    "accept_rate": 81,
                    "profile_image": "https://www.gravatar.com/avatar/a19f9308334d07d4be19c8f6d11151ff?s=256&d=identicon&r=PG",
                    "display_name": "ceejayoz",
                    "link": "https://stackoverflow.com/users/1902010/ceejayoz"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1483639949,
                "post_id": 41491773,
                "comment_id": 70189559,
                "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": 1483653860,
                "post_id": 41491773,
                "comment_id": 70197239,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 25679,
                    "reputation": 1458,
                    "user_id": 66187,
                    "user_type": "registered",
                    "accept_rate": 11,
                    "profile_image": "https://www.gravatar.com/avatar/e513d6507faed4fc4625e71bd2961758?s=256&d=identicon&r=PG",
                    "display_name": "Matt Hughes",
                    "link": "https://stackoverflow.com/users/66187/matt-hughes"
                },
                "reply_to_user": {
                    "account_id": 1705,
                    "reputation": 180444,
                    "user_id": 1902010,
                    "user_type": "registered",
                    "accept_rate": 81,
                    "profile_image": "https://www.gravatar.com/avatar/a19f9308334d07d4be19c8f6d11151ff?s=256&d=identicon&r=PG",
                    "display_name": "ceejayoz",
                    "link": "https://stackoverflow.com/users/1902010/ceejayoz"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1483737134,
                "post_id": 41491773,
                "comment_id": 70234919,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 25679,
                    "reputation": 1458,
                    "user_id": 66187,
                    "user_type": "registered",
                    "accept_rate": 11,
                    "profile_image": "https://www.gravatar.com/avatar/e513d6507faed4fc4625e71bd2961758?s=256&d=identicon&r=PG",
                    "display_name": "Matt Hughes",
                    "link": "https://stackoverflow.com/users/66187/matt-hughes"
                },
                "reply_to_user": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1483737381,
                "post_id": 41491773,
                "comment_id": 70235045,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1483642108,
                "creation_date": 1483642108,
                "answer_id": 41492459,
                "question_id": 41491773,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "If you&#39;re interested in viewing objects at a specific depth, you could utilize `getpath` and `paths`.  `paths` will return paths to all values in the graph.  You could filter those paths to paths of specific lengths then get the corresponding value using `getpath`.\r\n\r\ne.g., looking at all values at depth 3 from the current object\r\n\r\n    getpath(paths | select(length == 3))\r\n\r\nThen you could filter and narrow it down as you as you go.",
                "title": "Browsing large JSON file"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1484017079,
                "last_edit_date": 1484017079,
                "creation_date": 1483740415,
                "answer_id": 41515118,
                "question_id": 41491773,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Appended is a jq schema-inference program that can be useful for understanding the structure of a large JSON object or array of JSON entities, at least if there is some rhyme or reason behind it. \r\n\r\nUsage: if the JSON entity of interest is in a file, input.json, then assuming the program below is in schema.jq, run:\r\n\r\n    jq -f schema.jq input.json\r\n\r\nFor a very large file, the schema inference might be slow, but typically it&#39;s faster to do it this way than using some kind of iterative method.  See, for example, the remarks following the example given next.\r\n\r\n### Example\r\nHere&#39;s an example using JSON=JEOPARDY_QUESTIONS1.json, a 54MB file (55554625 bytes) \r\navailable from https://raw.githubusercontent.com/alicemaz/super_jeopardy/master/JEOPARDY_QUESTIONS1.json\r\n\r\n    $ time jq -c -f schema.jq $JSON\r\n    [\r\n      {\r\n        &quot;air_date&quot;: &quot;string&quot;,\r\n        &quot;answer&quot;: &quot;string&quot;,\r\n        &quot;category&quot;: &quot;string&quot;,\r\n        &quot;question&quot;: &quot;string&quot;,\r\n        &quot;round&quot;: &quot;string&quot;,\r\n        &quot;show_number&quot;: &quot;string&quot;,\r\n        &quot;value&quot;: &quot;string&quot;\r\n      }\r\n    ]\r\n\r\n    real\t0m12.868s\r\n    user\t0m11.713s\r\n    sys \t0m0.342s\r\n\r\nThe u+s time is noteworthy because it&#39;s about two-thirds of the u+s time on the same machine for the approach using the streaming parser to generate a synopsis of the paths (see synopsis.jq on this page).  This is perhaps counterintuitive given that the JSON file is an array of length 216,930. \r\n\r\n### schema.jq\r\n    # Schema inference\r\n    # Version 0.1\r\n    # Author: pkoppstein at gmail dot com\r\n    # Requires: jq 1.4 or higher\r\n    \r\n    # This module defines three filters:\r\n    #   typeof/0 returns the extended-type of its input;\r\n    #   typeUnion(a;b) returns the union of the two specified extended-type values;\r\n    #   schema/0 returns the typeUnion of the extended-type values of the entities\r\n    #    in the input array, if the input is an array,\r\n    #     otherwise it simply returns the &quot;typeof&quot; value of its input.\r\n    \r\n    # Each extended type can be thought of as a set of JSON entities,\r\n    # e.g. &quot;number&quot; for the set of JSON numbers, and [&quot;number&quot;] for the\r\n    # set of JSON number-valued arrays including [].\r\n    \r\n    # The extended-type values are always JSON entities.\r\n    # The possible values are:\r\n    # &quot;null&quot;, &quot;boolean&quot;, &quot;string&quot;, &quot;number&quot;;\r\n    # &quot;scalar&quot; for any combination of non-null scalars;\r\n    # [T] where T is an extended type;\r\n    # an object all of whose values are extended types;\r\n    # &quot;JSON&quot; signifying that no other extended-type value is applicable.\r\n    \r\n    # The extended-type values are defined recursively:\r\n    # The extended-type of a scalar value is its JSON type.\r\n    # The extended-type of a non-empty array of values all of which have the\r\n    #      same JSON type, t, is [t], and similarly for [&quot;scalar&quot;], and [&quot;JSON&quot;].\r\n    # The extended-type of [] is [&quot;null&quot;], since that is the extended type of all arrays\r\n    #     which have no elements other than null.\r\n    # The extended-type of an object is an object with the same keys, but the\r\n    #     values of which are the extended-types of the corresponding values.\r\n    \r\n    # typeUnion(a;b) returns the least extended-type value that subsumes both a and b.\r\n    # For example:\r\n    #  typeUnion(&quot;number&quot;; &quot;string&quot;) yields &quot;scalar&quot;;\r\n    #  typeUnion({&quot;a&quot;: &quot;number&quot;}; {&quot;b&quot;: &quot;string&quot;}) yields {&quot;a&quot;: &quot;number&quot;, &quot;b&quot;: &quot;string&quot;};\r\n    #  typeUnion(&quot;null&quot;, t) yields t for any valid extended type, t.\r\n    \r\n    def typeUnion(a;b):\r\n      def scalarp: . == &quot;boolean&quot; or . == &quot;string&quot; or . == &quot;number&quot; or . == &quot;scalar&quot;;\r\n      a as $a | b as $b\r\n      | if $a == $b then $a\r\n        elif ($a | scalarp) and ($b | scalarp) then &quot;scalar&quot;\r\n        elif $a == &quot;JSON&quot; or $b == &quot;JSON&quot; then &quot;JSON&quot;\r\n        elif ($a|type) == &quot;array&quot; and ($b|type) == &quot;array&quot; then [ typeUnion($a[0]; $b[0]) ]\r\n        elif ($a|type) == &quot;object&quot; and ($b|type) == &quot;object&quot; then\r\n          ((($a|keys) + ($b|keys)) | unique) as $keys\r\n          | reduce $keys[] as $key ( {} ; .[$key] = typeUnion( $a[$key]; $b[$key]) )\r\n        elif $a == &quot;null&quot; or $a == null then $b\r\n        elif $b == &quot;null&quot; or $b == null then $a\r\n        else &quot;JSON&quot;\r\n        end ;\r\n    \r\n    def typeof:\r\n      def typeofArray:\r\n        if length == 0 then [&quot;null&quot;]\r\n        else [reduce .[] as $item (null; typeUnion(.; $item|typeof))]\r\n        end ;\r\n      def typeofObject:\r\n        reduce keys[] as $key (. ; .[$key] |= typeof) ;\r\n    \r\n      . as $in\r\n      | type\r\n      | if . == &quot;string&quot; or . == &quot;number&quot; or . == &quot;null&quot; or . == &quot;boolean&quot; then .\r\n        elif . == &quot;object&quot; then $in | typeofObject\r\n        else $in | typeofArray\r\n        end ;\r\n    \r\n    # Omit the outermost [] for an array\r\n    def schema:\r\n      if type == &quot;array&quot; then reduce .[] as $x (&quot;null&quot;;  typeUnion(.; $x|typeof))\r\n      else typeof\r\n      end ;\r\n    \r\n    \r\n    \r\n    # Example top-level:\r\n    schema\r\n    \r\n    \r\n",
                "title": "Browsing large JSON file"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1483982985,
                "last_edit_date": 1483982985,
                "creation_date": 1483764004,
                "answer_id": 41517851,
                "question_id": 41491773,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a filter which emits a stream of synopses of all the paths of\r\nlength &lt;= depth in the input entity, except that if depth &lt;= 0, the\r\ndepth limitation is ignored.\r\n\r\nThe synopsis of a path [p1, p2, ...] is constructed by replacing\r\ninteger components with &quot;.[]&quot;, and prefixing string components with &quot;.&quot;,\r\nso for example, if i and j are integers, then\r\n[i, &quot;keyname&quot;, j] would be represented as .[].keyname.[]\r\n\r\nHere is an example of the output produced using `jq -r`:\r\n\r\n    .[]\r\n    .[].data\r\n    .[].data.children\r\n    .[].data.modhash\r\n    .[].kind\r\n    \r\n### paths_synopsis/1\r\n\r\n    # If depth&lt;0 then select paths of length equal to -depth    \r\n    def paths_synopsis(depth):\r\n      [ paths\r\n      | if depth &gt; 0 then select(length &lt;= depth)\r\n        elif (depth &lt; 0) then select(length == -depth)\r\n        else . end\r\n      | [.[]|if type==&quot;number&quot; then &quot;[]&quot; else . end]]\r\n      | unique\r\n      | .[]\r\n      | &quot;.&quot; + join(&quot;.&quot;)\r\n      ;\r\n\r\n\r\n### Very large JSON entities\r\njq has a streaming parser intended for use with very large JSON entities.\r\n\r\nThe following filter is intended for use with the jq streaming parser (jq --stream)\r\nin a pipeline, the second component of which uniquifies the synopses as illustrated in this example:\r\n\r\n    jq --arg depth 0 -c --stream -f synopsis.jq input.json | sort -u\r\n\r\nIn the following formulation, the desired DEPTH limit must be specified on the command line.\r\nSpecify 0 for no limit.\r\n\r\n#### synopsis.jq\r\n    # Usage: jq --arg depth DEPTH -c --stream -f synopsis.jq input.json | sort -u\r\n    # or:    jq --arg depth DEPTH -c --stream -f synopsis.jq input.json | jq -s -c unique[]\r\n    def synopsis(depth):\r\n      select(length == 2)\r\n      | .[0]\r\n      | if depth &gt; 0 then select(length &lt;= depth)\r\n        elif (depth &lt; 0) then select(length == -depth)\r\n        else . end\r\n      | map( if type==&quot;number&quot; then [] else . end) ;\r\n    \r\n    synopsis( $depth | if . then tonumber else 0 end )\r\n \r\n### Example:\r\n\r\n    curl -Ss &#39;http://forecast.weather.gov/MapClick.php?FcstType=json&amp;lat=39.56&amp;lon=-104.85&#39; |\r\n      jq --arg depth 0 -c --stream -f synopsis.jq |\r\n      sort -u | head -n 50\r\n\r\n```\r\n[&quot;creationDate&quot;]\r\n[&quot;creationDateLocal&quot;]\r\n[&quot;credit&quot;]\r\n[&quot;currentobservation&quot;,&quot;Altimeter&quot;]\r\n[&quot;currentobservation&quot;,&quot;Date&quot;]\r\n[&quot;currentobservation&quot;,&quot;Dewp&quot;]\r\n[&quot;currentobservation&quot;,&quot;Gust&quot;]\r\n[&quot;currentobservation&quot;,&quot;Relh&quot;]\r\n[&quot;currentobservation&quot;,&quot;SLP&quot;]\r\n[&quot;currentobservation&quot;,&quot;Temp&quot;]\r\n[&quot;currentobservation&quot;,&quot;Visibility&quot;]\r\n[&quot;currentobservation&quot;,&quot;Weather&quot;]\r\n[&quot;currentobservation&quot;,&quot;Weatherimage&quot;]\r\n[&quot;currentobservation&quot;,&quot;WindChill&quot;]\r\n[&quot;currentobservation&quot;,&quot;Windd&quot;]\r\n[&quot;currentobservation&quot;,&quot;Winds&quot;]\r\n[&quot;currentobservation&quot;,&quot;elev&quot;]\r\n[&quot;currentobservation&quot;,&quot;id&quot;]\r\n[&quot;currentobservation&quot;,&quot;latitude&quot;]\r\n[&quot;currentobservation&quot;,&quot;longitude&quot;]\r\n[&quot;currentobservation&quot;,&quot;name&quot;]\r\n[&quot;currentobservation&quot;,&quot;state&quot;]\r\n[&quot;currentobservation&quot;,&quot;timezone&quot;]\r\n[&quot;data&quot;,&quot;hazard&quot;,[]]\r\n[&quot;data&quot;,&quot;hazardUrl&quot;,[]]\r\n```   ",
                "title": "Browsing large JSON file"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": -2,
        "last_activity_date": 1484017079,
        "creation_date": 1483639426,
        "last_edit_date": 1483764349,
        "question_id": 41491773,
        "body_markdown": "I have a huge JSON file with some very deep paths.  I was hoping to use `jq` to show the top N keys with the deeper contents hidden.  And then once I find the keys I&#39;m interesting in, keep drilling down, only showing me N levels down from my starting point similar to a text editors ability to fold everything below N levels.  Is this possible?\r\n\r\n",
        "link": "https://stackoverflow.com/questions/41491773/browsing-large-json-file",
        "title": "Browsing large JSON file"
    },
    {
        "tags": [
            "javascript",
            "python",
            "json",
            "powershell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3307354,
                    "reputation": 517,
                    "user_id": 2781750,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/89eb995deda391a820c2235e4561188c?s=256&d=identicon&r=PG",
                    "display_name": "drkibitz",
                    "link": "https://stackoverflow.com/users/2781750/drkibitz"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1483686171,
                "post_id": 41500569,
                "comment_id": 70206714,
                "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": 1483721204,
                "post_id": 41500569,
                "comment_id": 70226379,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": -1,
                "last_activity_date": 1483689286,
                "creation_date": 1483689286,
                "answer_id": 41501336,
                "question_id": 41500569,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "I haven&#39;t tested this code properly. But should provide you some idea on how you can solve the problem mentioned above\r\n\r\n&lt;!-- begin snippet: js hide: false console: true babel: false --&gt;\r\n\r\n&lt;!-- language: lang-js --&gt;\r\n\r\n    var json = {\r\n            &quot;type&quot;: &quot;FeatureCollection&quot;,\r\n            &quot;features&quot;: [\r\n              {\r\n                &quot;type&quot;: &quot;Feature&quot;,\r\n                &quot;properties&quot;: {},\r\n                &quot;geometry&quot;: {\r\n                  &quot;type&quot;: &quot;Polygon&quot;,\r\n                  &quot;coordinates&quot;: [\r\n                    [\r\n                      [\r\n                        -37.880859375,\r\n                        78.81903553711727\r\n                      ],\r\n                      [\r\n                        -42.01171875,\r\n                        78.31385955743478\r\n                      ],\r\n                      [\r\n                        -37.6171875,\r\n                        78.06198918665974\r\n                      ],\r\n                      [\r\n                        -37.880859375,\r\n                        78.81903553711727\r\n                      ]\r\n                    ]\r\n                  ]\r\n                }\r\n              },\r\n              {\r\n                &quot;type&quot;: &quot;Feature&quot;,\r\n                &quot;properties&quot;: {},\r\n                &quot;geometry&quot;: {\r\n                  &quot;type&quot;: &quot;Polygon&quot;,\r\n                  &quot;coordinates&quot;: [\r\n                    [\r\n                      [\r\n                        -37.6171875,\r\n                        78.07107600956168\r\n                      ],\r\n                      [\r\n                        -35.48583984375,\r\n                        78.42019327591201\r\n                      ],\r\n                      [\r\n                        -37.880859375,\r\n                        78.81903553711727\r\n                      ],\r\n                      [\r\n                        -37.6171875,\r\n                        78.07107600956168\r\n                      ]\r\n                    ]\r\n                  ]\r\n                }\r\n              }\r\n            ]\r\n          }\r\n          $(document).ready(function(){\r\n            var counter = 1;\r\n            json.features.forEach(function(feature){\r\n              var data = {type: json.type, features: [feature]}\r\n              var newJson = JSON.stringify(data);\r\n              var blob = new Blob([newJson], {type: &quot;application/json&quot;});\r\n              var url  = URL.createObjectURL(blob);\r\n              var a = document.createElement(&#39;a&#39;);\r\n              a.download    = &quot;feature_&quot; + counter + &quot;.json&quot;;\r\n              a.href        = url;\r\n              a.textContent = &quot;Download feature_&quot; + counter + &quot;.json&quot;;\r\n              counter++;\r\n              document.getElementById(&#39;feature&#39;).appendChild(a);\r\n              document.getElementById(&#39;feature&#39;).appendChild(document.createElement(&#39;br&#39;));\r\n            });\r\n          });\r\n\r\n&lt;!-- language: lang-html --&gt;\r\n\r\n    &lt;script src=&quot;https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js&quot;&gt;&lt;/script&gt;\r\n    &lt;div id=&quot;feature&quot;&gt;&lt;/div&gt;\r\n\r\n&lt;!-- end snippet --&gt;\r\n\r\n",
                "title": "Split JSON File Objects Into Multiple Files"
            },
            {
                "up_vote_count": 6,
                "is_accepted": false,
                "score": 6,
                "last_activity_date": 1526193343,
                "last_edit_date": 1526193343,
                "creation_date": 1483696227,
                "answer_id": 41503000,
                "question_id": 41500569,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a solution requiring just one invocation of `jq` and one of `awk`, assuming the input is in a file (input.json) and that the N-th component should be written to a file /tmp/file$N.json beginning with N=1:\r\n\r\n    jq -c &#39;.features = (.features[] | [.]) &#39; input.json |\r\n      awk &#39;{ print &gt; &quot;/tmp/file&quot; NR &quot;.json&quot;}&#39;\r\n\r\nAn alternative to `awk` here would be `split -l 1`.\r\n\r\nIf you want each of the output files to be &quot;pretty-printed&quot;, then using a shell such as bash, you could (at the cost of n additional calls to jq) write:\r\n\r\n    N=0\r\n    jq -c &#39;.features = (.features[] | [.])&#39; input.json |\r\n      while read -r json ; do\r\n\t  N=$((N+1))\r\n\t  jq . &lt;&lt;&lt; &quot;$json&quot;  &gt; &quot;/tmp/file${N}.json&quot;\r\n    done\r\n\r\nEach of the additional calls to jq will be fast, so this may be acceptable.\r\n\r\n\r\n\r\n    \r\n",
                "title": "Split JSON File Objects Into Multiple Files"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1483704976,
                "creation_date": 1483704976,
                "answer_id": 41505542,
                "question_id": 41500569,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "PowerShell solution (requires PowerShell v3 or newer):\r\n\r\n&lt;!-- language: powershell --&gt;\r\n\r\n    $i = 0\r\n    Get-Content &#39;C:\\path\\to\\input.json&#39; -Raw |\r\n      ConvertFrom-Json |\r\n      Select-Object -Expand features |\r\n      ForEach-Object {\r\n        $filename = &#39;C:\\path\\to\\feature{0:d5}.json&#39; -f ($i++)\r\n\r\n        $properties = [ordered]@{\r\n          type     = &#39;FeatureCollection&#39;\r\n          features = $_\r\n        }\r\n\r\n        New-Object -Type PSObject -Property $properties |\r\n          ConvertTo-Json -Depth 10 |\r\n          Set-Content $filename\r\n      }\r\n",
                "title": "Split JSON File Objects Into Multiple Files"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1526193343,
        "creation_date": 1483685935,
        "question_id": 41500569,
        "body_markdown": "I have a file with too many data objects in JSON of the following form:\r\n\r\n    {\r\n      &quot;type&quot;: &quot;FeatureCollection&quot;,\r\n      &quot;features&quot;: [\r\n        {\r\n          &quot;type&quot;: &quot;Feature&quot;,\r\n          &quot;properties&quot;: {},\r\n          &quot;geometry&quot;: {\r\n            &quot;type&quot;: &quot;Polygon&quot;,\r\n            &quot;coordinates&quot;: [\r\n              [\r\n                [\r\n                  -37.880859375,\r\n                  78.81903553711727\r\n                ],\r\n                [\r\n                  -42.01171875,\r\n                  78.31385955743478\r\n                ],\r\n                [\r\n                  -37.6171875,\r\n                  78.06198918665974\r\n                ],\r\n                [\r\n                  -37.880859375,\r\n                  78.81903553711727\r\n                ]\r\n              ]\r\n            ]\r\n          }\r\n        },\r\n        {\r\n          &quot;type&quot;: &quot;Feature&quot;,\r\n          &quot;properties&quot;: {},\r\n          &quot;geometry&quot;: {\r\n            &quot;type&quot;: &quot;Polygon&quot;,\r\n            &quot;coordinates&quot;: [\r\n              [\r\n                [\r\n                  -37.6171875,\r\n                  78.07107600956168\r\n                ],\r\n                [\r\n                  -35.48583984375,\r\n                  78.42019327591201\r\n                ],\r\n                [\r\n                  -37.880859375,\r\n                  78.81903553711727\r\n                ],\r\n                [\r\n                  -37.6171875,\r\n                  78.07107600956168\r\n                ]\r\n              ]\r\n            ]\r\n          }\r\n        }\r\n      ]\r\n    }\r\n\r\nI would like to split the large file such that each features object would have its own file containing a its type object and features(coordinates) object. So essentially, I am trying to get many of these:\r\n\r\n\r\n    {\r\n      &quot;type&quot;: &quot;FeatureCollection&quot;,\r\n      &quot;features&quot;: [\r\n        {\r\n          &quot;type&quot;: &quot;Feature&quot;,\r\n          &quot;properties&quot;: {},\r\n          &quot;geometry&quot;: {\r\n            &quot;type&quot;: &quot;Polygon&quot;,\r\n            &quot;coordinates&quot;: [\r\n              [\r\n                [\r\n                  -37.6171875,\r\n                  78.07107600956168\r\n                ],\r\n                [\r\n                  -35.48583984375,\r\n                  78.42019327591201\r\n                ],\r\n                [\r\n                  -37.880859375,\r\n                  78.81903553711727\r\n                ],\r\n                [\r\n                  -37.6171875,\r\n                  78.07107600956168\r\n                ]\r\n              ]\r\n            ]\r\n          }\r\n        }\r\n      ]\r\n    }",
        "link": "https://stackoverflow.com/questions/41500569/split-json-file-objects-into-multiple-files",
        "title": "Split JSON File Objects Into Multiple Files"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 55050,
                    "reputation": 196179,
                    "user_id": 164835,
                    "user_type": "registered",
                    "accept_rate": 80,
                    "profile_image": "https://i.sstatic.net/ayYoh.jpg?s=256",
                    "display_name": "Kent",
                    "link": "https://stackoverflow.com/users/164835/kent"
                },
                "edited": false,
                "score": 4,
                "creation_date": 1483698316,
                "post_id": 41503387,
                "comment_id": 70212442,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1483700670,
                "last_edit_date": 1483700670,
                "creation_date": 1483700309,
                "answer_id": 41504208,
                "question_id": 41503387,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Using `jq` with a straight forward filter, should do it for you.\r\n\r\n    .global.name = &quot;dsa&quot;\r\n\r\ni.e.\r\n\r\n    jq &#39;.global.name = &quot;dsa&quot;&#39; json-file\r\n    {\r\n      &quot;global&quot;: {\r\n        &quot;name&quot;: &quot;dsa&quot;,\r\n        &quot;id&quot;: 1\r\n      }\r\n    }\r\n\r\nYou can play around with your json-filters, [here](https://jqplay.org/).",
                "title": "Modifying JSON by using jq"
            },
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1483804249,
                "last_edit_date": 1495539206,
                "creation_date": 1483701877,
                "answer_id": 41504661,
                "question_id": 41503387,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Your only problem was that the script passed to `jq` was quoted incorrectly.  \r\n\r\nIn your particular case, using a single double-quoted string with embedded `\\`-escaped `&quot;` instances is probably simplest:\r\n\r\n    jq -r &quot;.global.name = \\&quot;$INPUT\\&quot;&quot; &quot;$CONF_FILE&quot; &gt; tmp.$$.json &amp;&amp; mv tmp.$$.json &quot;$CONF_FILE&quot;\r\n\r\nGenerally, however, **[chepner&#39;s helpful answer](https://stackoverflow.com/a/41505474/45375) shows a more robust alternative to embedding the shell variable reference directly in the script**: Using the **`--arg` option** to pass a value as a `jq` _variable_ allows _single-quoting_ the script, which is preferable, because it avoids confusion over what elements are expanded by the shell up front and obviates the need for escaping `$` instances that should be passed through to `jq`.\r\n\r\n\r\nAlso:\r\n\r\n\r\n* Just `=` is sufficient to assign the value; while `|=`, the so-called update operator, works too, it behaves the same as `=` in this instance, because the RHS is a *literal*, not an expression referencing the LHS - see [the manual](https://stedolan.github.io/jq/manual/#Assignment).\r\n* You should routinely double-quote your shell-variable references and you should avoid use of all-uppercase variable names in order to [avoid conflicts with environment variables and special shell variables](http://pubs.opengroup.org/onlinepubs/9699919799/basedefs/V1_chap08.html#tag_08_01).\r\n\r\n----------\r\n\r\nAs for **why your quoting didn&#39;t work**:\r\n \r\n`&#39;.global.name |= &#39;&quot;&quot;$INPUT&quot;&quot;` is composed of the following tokens:\r\n\r\n* String literal `.global.name |= ` (due to single-quoting)\r\n* String literal `&quot;&quot;` - i.e., the empty string - the quotes will be _removed_ by the shell before `jq` sees the script\r\n* An _unquoted_ reference to variable `$INPUT` (which makes its value subject to word-splitting and globbing).\r\n* Another instance of literal `&quot;&quot;`.\r\n\r\nWith your sample value, `jq` ended up seeing the following string as its script:  \r\n\r\n    .global.name |= dsa\r\n\r\nAs you can see, the double quotes are missing, causing `jq` to interpret `dsa` as a _function name_ rather than a string literal, and since no argument was passed to (non-existent) function `dsa`, `jq`&#39;s error message referenced it as `dsa/0` - a function with no (`0`) arguments.\r\n",
                "title": "Modifying JSON by using jq"
            },
            {
                "up_vote_count": 5,
                "is_accepted": false,
                "score": 5,
                "last_activity_date": 1483704757,
                "creation_date": 1483704757,
                "answer_id": 41505474,
                "question_id": 41503387,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "It&#39;s much simpler and safer to pass the value using the `--arg` option:\r\n\r\n    jq -r --arg newname &quot;$INPUT&quot; &#39;.global.name |= $newname&#39; &quot;$CONF_FILE&quot;\r\n\r\nThis ensures that the exact value of `$INPUT` is used and quoted as a JSON value.",
                "title": "Modifying JSON by using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 4,
        "last_activity_date": 1483804249,
        "creation_date": 1483697561,
        "last_edit_date": 1483713929,
        "question_id": 41503387,
        "body_markdown": "I want to modify a JSON file by using the Linux command line.\r\n\r\nI tried these steps:\r\n\r\n    [root@localhost]# INPUT=&quot;dsa&quot;\r\n    [root@localhost]# echo $INPUT\r\n    dsa\r\n    [root@localhost]# CONF_FILE=test.json\r\n    [root@localhost]# echo $CONF_FILE\r\n    test.json\r\n    [root@localhost]# cat $CONF_FILE\r\n    {\r\n      &quot;global&quot; : {\r\n        &quot;name&quot; : &quot;asd&quot;,\r\n        &quot;id&quot; : 1\r\n      }\r\n    }\r\n    [root@localhost]# jq -r &#39;.global.name |= &#39;&quot;&quot;$INPUT&quot;&quot; $CONF_FILE &gt; tmp.$$.json &amp;&amp; mv tmp.$$.json $CONF_FILE\r\n    jq: error: dsa/0 is not defined at &lt;top-level&gt;, line 1:\r\n    .global.name |= dsa\r\n    jq: 1 compile error\r\n\r\nDesired output:\r\n\r\n    [root@localhost]# cat $CONF_FILE\r\n        {   &quot;global&quot; : {\r\n        &quot;name&quot; : &quot;dsa&quot;,\r\n        &quot;id&quot; : 1   } }",
        "link": "https://stackoverflow.com/questions/41503387/modifying-json-by-using-jq",
        "title": "Modifying JSON by using jq"
    },
    {
        "tags": [
            "json",
            "csv",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1483935012,
                "last_edit_date": 1483935012,
                "creation_date": 1483909726,
                "answer_id": 41537929,
                "question_id": 41537235,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "With the caveat that you have to be careful what you wish for, and assuming the input is an array of objects as shown:\r\n\r\n    .[]\r\n    | [.[]\r\n       | if type == &quot;array&quot; then map(tonumber? // .) else . end\r\n       | tostring]\r\n    | @csv\r\n\r\nproduces the desired output, except for the header row.\r\n\r\n(The &quot;tonumber? // .&quot; avoids an error if the array contents cannot be converted to a number.)\r\n\r\n### Generalization\r\nHere&#39;s a variant that (a) produces a row of headers for all the keys in the first object, whatever they may be; and (b) is robust with respect to re-ordering the keys within the objects:\r\n\r\n```\r\n. as $in\r\n| ($in[0] | keys_unsorted) as $h\r\n| ($h, \r\n   ( $in[]\r\n   | ( [range(0; $h|length) as $i | getpath( [$h[$i]] )]\r\n     | map(if type == &quot;array&quot; then map(tonumber? // .) else . end)\r\n     | map(tostring) ) ))\r\n| @csv\r\n```\r\n\r\nWith this in tocsv.jq and your input in input.json:\r\n\r\n```\r\n$ jq -r -f tocsv.jq input.json\r\n&quot;var&quot;,&quot;section&quot;,&quot;x&quot;\r\n&quot;1&quot;,&quot;[&quot;&quot;a&quot;&quot;,2,3]&quot;,&quot;test1&quot;\r\n&quot;2&quot;,&quot;[2,3,4]&quot;,&quot;test2&quot;\r\n&quot;3&quot;,&quot;[3,4,5]&quot;,&quot;test3&quot;\r\n```\r\n\r\n",
                "title": "How to convert json with array into csv?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1483935012,
        "creation_date": 1483905618,
        "last_edit_date": 1483921824,
        "question_id": 41537235,
        "body_markdown": "I know this is possible with jq, but there is an added complexity. One of the fields inside the json object is an array of strings. How do we handle this with jq?\r\n\r\n    {\r\n        &quot;var&quot;: 1,\r\n        &quot;section&quot;: [&quot;1&quot;,&quot;2&quot;,&quot;3&quot;],\r\n        &quot;x&quot;: &quot;test1&quot;\r\n    },\r\n    {\r\n        &quot;var&quot;: 2,\r\n        &quot;section&quot;: [&quot;2&quot;,&quot;3&quot;,&quot;4&quot;],\r\n        &quot;x&quot;: &quot;test2&quot;\r\n    },\r\n    {\r\n        &quot;var&quot;: 3,\r\n        &quot;section&quot;: [&quot;3&quot;,&quot;4&quot;,&quot;5&quot;],\r\n        &quot;x&quot;: &quot;test3&quot;\r\n    },\r\n\r\nHow do we make CSV output like this?\r\n\r\n    var,section,x\r\n    &quot;1&quot;,&quot;[1,2,3]&quot;,&quot;test1&quot;\r\n    &quot;2&quot;,&quot;[2,3,4]&quot;,&quot;test2&quot;\r\n    &quot;3&quot;,&quot;[3,4,5]&quot;,&quot;test3&quot;\r\n\r\nI&#39;m thingking of using JSON.stringify inside the jq arguments. \r\n",
        "link": "https://stackoverflow.com/questions/41537235/how-to-convert-json-with-array-into-csv",
        "title": "How to convert json with array into csv?"
    },
    {
        "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": 3,
                "creation_date": 1484032942,
                "post_id": 41562602,
                "comment_id": 70330827,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1484053551,
                "creation_date": 1484053551,
                "answer_id": 41569564,
                "question_id": 41562602,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You will need to quote the input string so the shell doesn&#39;t do anything with your string\r\n\r\n    json=&#39;{&quot;id&quot;:&quot;12345&quot;,&quot;key&quot;:&quot;ABC-DEF&quot;,&quot;url&quot;:&quot;https://google.com&quot;}&#39;\r\n    ID=$(echo &quot;$json&quot; | jq &#39;.key&#39; )\r\n\r\n",
                "title": "Parsing errors of JSON using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1484053551,
        "creation_date": 1484030372,
        "question_id": 41562602,
        "body_markdown": "I have a curl command which results in the following example json:\r\n\r\n    json={&quot;id&quot;:&quot;12345&quot;,&quot;key&quot;:&quot;ABC-DEF&quot;,&quot;url&quot;:&quot;https://google.com&quot;}\r\n\r\nNow, I want to parse this, and get the key out of it and store it in a variable. What I did was the following:\r\n\r\n    json={&quot;id&quot;:&quot;12345&quot;,&quot;key&quot;:&quot;ABC-DEF&quot;,&quot;url&quot;:&quot;https://google.com&quot;}\r\n    ID=$(echo $json | jq &#39;.key&#39; )\r\n\r\nBut the above gives me a error as: `parse error: Invalid numeric literal at line 1, column 4`. Can someone help me with this? Thanks!\r\n\r\n",
        "link": "https://stackoverflow.com/questions/41562602/parsing-errors-of-json-using-jq",
        "title": "Parsing errors of JSON using jq"
    },
    {
        "tags": [
            "json",
            "unix",
            "logging",
            "error-handling",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 148267,
                    "reputation": 3196,
                    "user_id": 359910,
                    "user_type": "registered",
                    "accept_rate": 42,
                    "profile_image": "https://www.gravatar.com/avatar/1540f01a56f566e4e8e6c672b60f761d?s=256&d=identicon&r=PG",
                    "display_name": "Brandon",
                    "link": "https://stackoverflow.com/users/359910/brandon"
                },
                "reply_to_user": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1484163795,
                "post_id": 41599314,
                "comment_id": 70401463,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 74,
                "is_accepted": true,
                "score": 72,
                "last_activity_date": 1484163747,
                "creation_date": 1484163747,
                "answer_id": 41599388,
                "question_id": 41599314,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Assuming that each log entry is exactly one line, you can use the `-R` or `--raw-input` option to tell jq to leave the lines unparsed, after which you can prepend `fromjson? |` to your filter to make jq try to parse each line as JSON and throw away the ones that error.",
                "title": "Ignore Unparseable JSON with jq"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1484165291,
                "last_edit_date": 1495540890,
                "creation_date": 1484165291,
                "answer_id": 41599840,
                "question_id": 41599314,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "There are several Q&amp;As on the [FAQ page][2] dealing with the topic of &quot;invalid JSON&quot;, but see in particular the Q:\r\n\r\n&gt; Is there a way to have jq keep going after it hits an error in the input file?\r\n\r\nIn particular, this shows how to use --seq. \r\n\r\nHowever, from the the sparse details you&#39;ve given (SO [recommends][3] a minimal example be given), it would seem it might be better simply to use `inputs`. The idea is to process one JSON entity at a time, using &quot;try/catch&quot;, e.g.\r\n\r\n    def handle: inputs | [., &quot;length is \\(length)&quot;] ;\r\n    def process: try handle catch (&quot;Failed&quot;, process) ;\r\n    process  \r\n\r\nDon&#39;t forget to use the -n option when invoking jq.\r\n\r\n\r\nSee also [Processing not-quite-valid JSON][1]. \r\n\r\n  [1]: https://github.com/stedolan/jq/wiki/FAQ#processing-not-quite-valid-json\r\n  [2]: https://github.com/stedolan/jq/wiki/FAQ\r\n  [3]: https://stackoverflow.com/help/mcve",
                "title": "Ignore Unparseable JSON with jq"
            },
            {
                "up_vote_count": 20,
                "is_accepted": false,
                "score": 18,
                "last_activity_date": 1615871807,
                "last_edit_date": 1615871807,
                "creation_date": 1573081310,
                "answer_id": 58739678,
                "question_id": 41599314,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I have log stream where some messages are in json format.\r\nI want to pipe the json messages through jq, and just echo the rest.\r\n\r\nThe json messages are on a **single line**.\r\n\r\n**Solution:** use grep and tee to split the lines in two streams, those starting with &quot;^{&quot; pipe through jq and the rest just echo to terminal.\r\n\r\n  `kubectl logs -f web-svjkn | tee &gt;(grep -v &quot;^{&quot;) | grep &quot;^{&quot; | jq . `\r\n\r\n  or \r\n\r\n ` cat logs | tee &gt;(grep -v &quot;^{&quot;) | grep &quot;^{&quot; | jq . ` \r\n\r\n**Explanation:** \r\ntee generates 2nd stream, and grep -v prints non json info, 2nd grep only pipes what looks like json opening bracket to jq.",
                "title": "Ignore Unparseable JSON with jq"
            },
            {
                "up_vote_count": 33,
                "is_accepted": false,
                "score": 33,
                "last_activity_date": 1713271037,
                "last_edit_date": 1713271037,
                "creation_date": 1636504310,
                "answer_id": 69906667,
                "question_id": 41599314,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This is an old thread, but here&#39;s another solution fully in `jq`. This allows you to both process proper json lines and also print out non-json lines:\r\n\r\n```\r\njq -R &#39;. as $line | try (fromjson) catch $line&#39;\r\n```\r\n\r\nIf you need to do additional jq processing:\r\n```\r\njq -R &#39;. as $line | try (fromjson | &lt;further processing for proper json lines&gt;) catch $line&#39;\r\n```\r\n\r\nMind to use single-quotes, because the `$` addresses `jq` and not your shell.",
                "title": "Ignore Unparseable JSON with jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": -2,
                "last_activity_date": 1666926090,
                "last_edit_date": 1666926090,
                "creation_date": 1666621784,
                "answer_id": 74182662,
                "question_id": 41599314,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If JSON in curly braces {}:\r\n\r\n```grep -Pzo &#39;\\{(?&gt;[^\\{\\}]|(?R))*\\}&#39; | jq &#39;objects&#39;```\r\n\r\nIf JSON in square brackets []:\r\n\r\n```grep -Pzo &#39;\\[(?&gt;[^\\[\\]]|(?R))*\\]&#39; | jq &#39;arrays&#39;```\r\n\r\nThis works if there are no []{} in non-JSON lines.\r\n",
                "title": "Ignore Unparseable JSON with jq"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1699711348,
                "creation_date": 1699711348,
                "answer_id": 77465369,
                "question_id": 41599314,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Summarizing as the *most valuable* answers were actually *in comments*. \r\n\r\n&gt; Assuming that each log entry is exactly one line, you can use the -R or --raw-input option to tell jq to leave the lines unparsed, after which you can prepend fromjson? | to your filter to make jq try to parse each line as JSON and throw away the ones that error.\r\n\r\nIf you don&#39;t quite understand what to do with it, like me, then this is the answer:\r\n\r\n`cat file_to_clean.jsonl | jq -R &quot;fromjson? | . &quot; -c &gt; clean_file.jsonl`\r\n\r\nGiven by **steven2308** on Apr 14, 2020.\r\n\r\nI&#39;m parsing the `json` returned from web server, and I need to see the returned header as well, while this method will not show anything other than `json`.\r\n\r\nThe comment\r\n\r\n&gt; I found `tail -f log | jq -R &#39;try fromjson catch .&#39;` enough for most cases \r\n\r\nby **Dennis C** on Apr 4, 2022 suits my purpose -- I can see the HTTP headers returned from web server now, even though they show up as errors like `Invalid numeric literal at line 1`. But that&#39;s OK for me as I just want to see the headers. I guess it&#39;ll suit most people&#39;s case when they&#39;re checking out logs, for otherwise the *context* would be missing with solution #1.\r\n",
                "title": "Ignore Unparseable JSON with jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1706018679,
                "creation_date": 1706018679,
                "answer_id": 77866889,
                "question_id": 41599314,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I see two goals of this question:\r\n\r\n* Be able to get output regardless of errors in the input JSON\r\n* Be able to track down where the error **is**.\r\n\r\nthe `yq` binary from https://github.com/mikefarah/yq is more permissive, so you can use that to output lines in mostly the same way as with `jq`.\r\n\r\nIn addition, if you have a JSON file with errors a simple comparison using some linux / bash shell magic can help a lot.\r\n\r\n```bash\r\n# Using GNU diff, ignoring whitespace\r\n# ...and Bash Process Substitution to diff the output of the yq command\r\ndiff -w inputfile.json &lt;(yq inputfile.json)\r\n```\r\n\r\nExample output - missing trailing comma:\r\n\r\n```diff\r\n13c13\r\n&lt;         &quot;kind&quot;: &quot;ConfigMap&quot;\r\n---\r\n&gt;       &quot;kind&quot;: &quot;ConfigMap&quot;,\r\n```\r\n\r\n[Bash Process Substitution][1]\r\n\r\n\r\n  [1]: https://tldp.org/LDP/abs/html/process-sub.html",
                "title": "Ignore Unparseable JSON with jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1735943083,
                "creation_date": 1735943083,
                "answer_id": 79327830,
                "question_id": 41599314,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Another option using `jq` that will show you as much of the log as possible up until the error is:\r\n\r\n```\r\n&lt;/path/to/your/log.txt jq --stream -n &#39;def r:(try input catch [])as $o|if $o|has(1)then setpath($o[0];$o[1])|r elif $o|has(0)then r end;{}|r&#39;\r\n```\r\n\r\nThe above isn&#39;t as aggressive as fromjson but it gives a much more meaningful output, preserving the JSON file structure for as much of it is parsable JSON.",
                "title": "Ignore Unparseable JSON with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 8,
        "score": 45,
        "last_activity_date": 1735943083,
        "creation_date": 1484163436,
        "last_edit_date": 1484177044,
        "question_id": 41599314,
        "body_markdown": "I&#39;m using jq to parse some of my logs, but some of the log lines can&#39;t be parsed for various reasons. Is there a way to have jq ignore those lines? I can&#39;t seem to find a solution. I tried to use the --seq argument that was recommended by some people, but --seq ignores all the lines in my file.",
        "link": "https://stackoverflow.com/questions/41599314/ignore-unparseable-json-with-jq",
        "title": "Ignore Unparseable JSON with jq"
    },
    {
        "tags": [
            "arrays",
            "dictionary",
            "key",
            "grouping",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 8306545,
                    "reputation": 58596,
                    "user_id": 6243352,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/193965abcb7230d85c6264e55e2f0bda?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "ggorlen",
                    "link": "https://stackoverflow.com/users/6243352/ggorlen"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1627351501,
                "post_id": 41603594,
                "comment_id": 121127016,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1484198627,
                "last_edit_date": 1484198627,
                "creation_date": 1484192666,
                "answer_id": 41604761,
                "question_id": 41603594,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "With your example and the following lines in merge.jq:\r\n\r\n    def merge_entries:\r\n      reduce .[] as $pair ({}; .[$pair[&quot;key&quot;]] += [$pair[&quot;value&quot;]] );\r\n\r\n    merge_entries\r\n\r\nthe invocation: jq -c -f merge.jq\r\nyields:\r\n\r\n    {&quot;a&quot;:[1,3],&quot;b&quot;:[2,4]}\r\n\r\nYou could also use the invocation:\r\n\r\n    jq &#39;reduce .[] as $p ({}; .[$p.key] += [$p.value])&#39;",
                "title": "variant of jq from_entries that collate values for each key occurrence"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1484220116,
        "creation_date": 1484183930,
        "last_edit_date": 1484220116,
        "question_id": 41603594,
        "body_markdown": "Can I use jq to run a filter that behaves similarly to from_entries, with the one difference being, if multiple entries for the same key are encountered, it will collate the values into an array, rather than just use the last value?\r\n\r\nIf so, what filter would achieve this? For example, if my input is:\r\n\r\n    [\r\n      {\r\n        &quot;key&quot;: &quot;a&quot;,\r\n        &quot;value&quot;: 1\r\n      },\r\n      {\r\n        &quot;key&quot;: &quot;b&quot;,\r\n        &quot;value&quot;: 2\r\n      },\r\n      {\r\n        &quot;key&quot;: &quot;a&quot;,\r\n        &quot;value&quot;: 3\r\n      },\r\n      {\r\n        &quot;key&quot;: &quot;b&quot;,\r\n        &quot;value&quot;: 4\r\n      }\r\n    ]\r\n\r\nthen the desired output would be:\r\n\r\n    { &quot;a&quot;: [1,3], &quot;b&quot;: [2,4] }\r\n\r\nNote that, using &#39;from_entries&#39; alone as the filter, the resulting values are just the last value (that is, ```{ &quot;a&quot;: 3, &quot;b&quot;: 4 }```)",
        "link": "https://stackoverflow.com/questions/41603594/variant-of-jq-from-entries-that-collate-values-for-each-key-occurrence",
        "title": "variant of jq from_entries that collate values for each key occurrence"
    },
    {
        "tags": [
            "json",
            "csv",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1484202473,
                "last_edit_date": 1484202473,
                "creation_date": 1484199897,
                "answer_id": 41605928,
                "question_id": 41605653,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "With your data in input.json, and the following jq program in tocsv.jq:\r\n\r\n    .[]\r\n    | [.name, .age] +\r\n      (.skills[]\r\n      | select(.lang == &quot;spanish&quot;)\r\n      | [.grade, .school.name, .school.url, input_filename, input_line_number] )\r\n    | @csv\r\n\r\nthe invocation:\r\n\r\n    jq -r -f tocsv.jq  input.json\r\n\r\nyields:\r\n\r\n    &quot;joe&quot;,21,&quot;47&quot;,&quot;my school&quot;,&quot;example.com/sp-school&quot;,&quot;input.json&quot;,51\r\n    &quot;jim&quot;,26,&quot;60&quot;,,,&quot;input.json&quot;,51\r\n\r\n\r\nIf you want the number-valued strings converted to numbers, you could use the &quot;tonumber&quot; filter.  If you want the null-valued fields replaced by strings, use e.g. `.school.name // &quot;&quot;`\r\n\r\nOf course this approach doesn&#39;t yield a very useful line number. One approach that would yield higher granularity would be to stream the individual objects into jq, but then you&#39;d lose the filename. To recover the filename you could pass it in as an argument.  So you would have a pipeline like so:\r\n\r\n    jq -c &#39;.[]&#39; input.json | jq -r --arg file input.json -f tocsv2.jq\r\n\r\nwhere tocsv2.jq would be like tscsv.jq above but without the initial `.[] |`, and with `$file` instead of `input_filename`.\r\n\r\nFinally, please also consider using the TSV format (@tsv) rather than the rather messy CSV format (@csv).",
                "title": "Creating a CSV from json using jq, based on elements in array"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1484202473,
        "creation_date": 1484198520,
        "question_id": 41605653,
        "body_markdown": "I have the following json format that I need to convert to CSV \r\n\r\n    [{\r\n        \t\t&quot;name&quot;: &quot;joe&quot;,\r\n        \t\t&quot;age&quot;: 21,\r\n        \t\t&quot;skills&quot;: [{\r\n        \t\t\t&quot;lang&quot;: &quot;spanish&quot;,\r\n        \t\t\t&quot;grade&quot;: &quot;47&quot;,\r\n        \t\t\t&quot;school&quot;: {\r\n        \t\t\t\t&quot;name&quot;: &quot;my school&quot;,\r\n        \t\t\t\t&quot;url&quot;: &quot;example.com/sp-school&quot;\r\n        \t\t\t}\r\n        \t\t}, {\r\n        \t\t\t&quot;lang&quot;: &quot;english&quot;,\r\n        \t\t\t&quot;grade&quot;: &quot;87&quot;\r\n        \t\t}]\r\n        \r\n        \t},\r\n        \r\n        \t{\r\n        \t\t&quot;name&quot;: &quot;sarah&quot;,\r\n        \t\t&quot;age&quot;: 34,\r\n        \t\t&quot;skills&quot;: [{\r\n        \t\t\t&quot;lang&quot;: &quot;french&quot;,\r\n        \t\t\t&quot;grade&quot;: &quot;47&quot;,\r\n        \t\t\t&quot;school&quot;: {\r\n        \t\t\t\t&quot;name&quot;: &quot;my school&quot;,\r\n        \t\t\t\t&quot;url&quot;: &quot;example.com/sp-school&quot;\r\n        \t\t\t}\r\n        \t\t}, {\r\n        \t\t\t&quot;lang&quot;: &quot;english&quot;,\r\n        \t\t\t&quot;grade&quot;: &quot;87&quot;\r\n        \t\t}]\r\n        \r\n        \t}, {\r\n        \t\t&quot;name&quot;: &quot;jim&quot;,\r\n        \t\t&quot;age&quot;: 26,\r\n        \t\t&quot;skills&quot;: [{\r\n        \t\t\t&quot;lang&quot;: &quot;spanish&quot;,\r\n        \t\t\t&quot;grade&quot;: &quot;60&quot;\r\n        \r\n        \t\t}, {\r\n        \t\t\t&quot;lang&quot;: &quot;english&quot;,\r\n        \t\t\t&quot;grade&quot;: &quot;66&quot;,\r\n        \t\t\t&quot;school&quot;: {\r\n        \t\t\t\t&quot;name&quot;: &quot;eg school&quot;,\r\n        \t\t\t\t&quot;url&quot;: &quot;eg-school.com&quot;\r\n        \r\n        \t\t\t}\r\n        \t\t}]\r\n        \r\n        \t}\r\n        ]\r\n\r\nto convert to csv \r\n\r\n    name,age,grade,school,url,file,line_number\r\n    joe,21,47,&quot;my school&quot;,&quot;example.com/sp-school&quot;,sample.json,1\r\n    jim,26,60,&quot;&quot;,&quot;&quot;,sample.json,3\r\n\r\nSo add the top level fields and the object from the skills array if lang=spanish and the school hash from the skills object for spanish if it exists \r\n\r\nI&#39;d also like to add the file and line number it came from.\r\n\r\n\r\nI would like to use jq for the job, but can&#39;t figure out the syntax , anyone help me out ? \r\n\r\n",
        "link": "https://stackoverflow.com/questions/41605653/creating-a-csv-from-json-using-jq-based-on-elements-in-array",
        "title": "Creating a CSV from json using jq, based on elements in array"
    },
    {
        "tags": [
            "json",
            "wrapper",
            "interactive",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1484621762,
                "last_edit_date": 1484621762,
                "creation_date": 1484315247,
                "answer_id": 41636066,
                "question_id": 41631626,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You may have to roll-your-own.  \r\n\r\nOf course, jq itself is interactive in the sense that if you invoke it without specifying any JSON input, it will process STDIN interactively.\r\n\r\nIf you want to feed the same data to multiple programs, you could easily write your own wrapper. Over at github, there&#39;s [a bash script named jqplay][1] that has a few bells and whistles.  For example, if the input command begins with | then the most recent result is used as input.\r\n\r\n### Example 1\r\n\r\n    ./jqplay -c spark.json\r\n    Enter a jq filter (possibly beginning with &quot;|&quot;), or blank line to terminate:\r\n    .[0]\r\n    {&quot;name&quot;:&quot;Paddington&quot;,&quot;lovesPandas&quot;:null,&quot;knows&quot;:{&quot;friends&quot;:[&quot;holden&quot;,&quot;Sparky&quot;]}}\r\n    .[1]\r\n    {&quot;name&quot;:&quot;Holden&quot;}\r\n    | .name\r\n    &quot;Holden&quot;\r\n    | .[0:1]\r\n    &quot;H&quot;\r\n    | length\r\n    1\r\n    .[1].name\r\n    &quot;Holden&quot;\r\n    \r\n    Bye.\r\n\r\n### Example 2\r\n\r\n    ./jqplay -n\r\n    Enter a jq filter (possibly beginning and/or ending with &quot;|&quot;), or blank line to terminate:\r\n    ?\r\n    An initial | signifies the filter should be applied to the previous jq\r\n    output.\r\n    \r\n    A terminating | causes the next line that does not trigger a special\r\n    action to be appended to the current line.\r\n    \r\n    Special action triggers:\r\n    :exit        # exit this script, also triggered by a blank line\r\n    :help        # print this help\r\n    :input PATHNAME ...\r\n    :options OPTIONS\r\n    :save PN     # save the most recent output in the named file provided\r\n                   it does not exist\r\n    :save! PN    # save the most recent output in the named file \r\n    :save        # save to the file most recently specified by a :save command\r\n    :show        # print the OPTIONS and PATHNAMEs currently in effect\r\n    :! PN        # equivalent to the sequence of commands\r\n                   :save! PN \r\n                   :input PN\r\n    ?            # print this help\r\n    #            # ignore this line\r\n    \r\n    1+2\r\n    3\r\n    :exit\r\n    Bye.\r\n\r\n  [1]: https://gist.github.com/pkoppstein/b9d4085703944114e72fbe4afcd7d0d1\r\n",
                "title": "Is there a `jq` command line tool or wrapper which lets you interactively explore `jq` similar to `jmespath.terminal`"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1484713993,
                "creation_date": 1484713993,
                "answer_id": 41711401,
                "question_id": 41631626,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "https://github.com/simeji/jid\r\n\r\nn.b. I&#39;m not clear how strictly it follows jq syntax and feature set",
                "title": "Is there a `jq` command line tool or wrapper which lets you interactively explore `jq` similar to `jmespath.terminal`"
            },
            {
                "up_vote_count": 18,
                "is_accepted": true,
                "score": 17,
                "last_activity_date": 1484865717,
                "last_edit_date": 1484865717,
                "creation_date": 1484864579,
                "answer_id": 41752833,
                "question_id": 41631626,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "I&#39;ve been using `jiq` and I&#39;m pretty happy with it.\r\n\r\nhttps://github.com/fiatjaf/jiq\r\n\r\nIt&#39;s [jid][1] with [jq][2].\r\n\r\nYou can drill down interactively by using jq filtering queries.\r\n\r\n`jiq` uses `jq` internally, and it requires you to have `jq` in your PATH.\r\n\r\n\r\n  [1]: https://github.com/simeji/jid\r\n  [2]: https://stedolan.github.io/jq/\r\n\r\n\r\n**Using the `aws` cli**\r\n\r\n    aws ec2 describe-regions --region-names us-east-1 us-west-1 | jiq\r\n\r\n\r\n**`jiq` output**\r\n\r\n    [Filter]&gt; .Regions\r\n    {\r\n      &quot;Regions&quot;: [\r\n        {\r\n          &quot;Endpoint&quot;: &quot;ec2.us-east-1.amazonaws.com&quot;,\r\n          &quot;RegionName&quot;: &quot;us-east-1&quot;\r\n        },\r\n        {\r\n          &quot;Endpoint&quot;: &quot;ec2.us-west-1.amazonaws.com&quot;,\r\n          &quot;RegionName&quot;: &quot;us-west-1&quot;\r\n        }\r\n      ]\r\n    }\r\n",
                "title": "Is there a `jq` command line tool or wrapper which lets you interactively explore `jq` similar to `jmespath.terminal`"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1533561035,
                "creation_date": 1533561035,
                "answer_id": 51708464,
                "question_id": 41631626,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you&#39;re using Emacs (or willing to) then JQ-mode allows you to run JQ filters interactively on the current JSON document buffer:\r\n\r\nhttps://github.com/ljos/jq-mode",
                "title": "Is there a `jq` command line tool or wrapper which lets you interactively explore `jq` similar to `jmespath.terminal`"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1644673805,
                "creation_date": 1644673805,
                "answer_id": 71092426,
                "question_id": 41631626,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "There is a new one: https://github.com/PaulJuliusMartinez/jless\r\n\r\n&gt; JLess is a command-line JSON viewer designed for reading, exploring, and searching through JSON data.\r\n&gt; \r\n&gt; JLess will pretty print your JSON and apply syntax highlighting.\r\n&gt;\r\n&gt; Expand and collapse Objects and Arrays to grasp the high- and low-level structure of a JSON document. JLess has a large suite of vim-inspired commands that make exploring data a breeze.\r\n&gt;\r\n&gt; JLess supports full text regular-expression based search. Quickly find the data you&#39;re looking for in long String values, or jump between values for the same Object key.\r\n",
                "title": "Is there a `jq` command line tool or wrapper which lets you interactively explore `jq` similar to `jmespath.terminal`"
            }
        ],
        "is_answered": true,
        "answer_count": 5,
        "score": 12,
        "last_activity_date": 1644673805,
        "creation_date": 1484300800,
        "last_edit_date": 1484546669,
        "question_id": 41631626,
        "body_markdown": "`jq` is a lightweight and flexible command-line JSON processor.  \r\nhttps://stedolan.github.io/jq/\r\n\r\nIs there a `jq` command line tool or wrapper which lets you pipe output into it and interactively explore `jq`, with the JSON input in one pane and your interactively updating result in another pane, similar to `jmespath.terminal` ?\r\n\r\nI&#39;m looking for something similar to the JMESPath Terminal `jpterm`  \r\n&quot;JMESPath exploration tool in the terminal&quot;  \r\nhttps://github.com/jmespath/jmespath.terminal\r\n\r\nI found this project `jqsh` but it&#39;s not maintained and it appears to produce a lot of errors when I use it.  \r\nhttps://github.com/bmatsuo/jqsh\r\n\r\nI&#39;ve used https://jqplay.org/ and it&#39;s a great web based `jq` learning tool. However, I want to be able to, in the shell, pipe the json output of a command into an interactive `jq` which allows me to explore and experiment with `jq` commands.\r\n\r\nThanks in advance!",
        "link": "https://stackoverflow.com/questions/41631626/is-there-a-jq-command-line-tool-or-wrapper-which-lets-you-interactively-explor",
        "title": "Is there a `jq` command line tool or wrapper which lets you interactively explore `jq` similar to `jmespath.terminal`"
    },
    {
        "tags": [
            "json",
            "command-line",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3451932,
                    "reputation": 354,
                    "user_id": 2891429,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/967bf80853a295f167ccbc86788bbd7a?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "newGuy",
                    "link": "https://stackoverflow.com/users/2891429/newguy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1484347648,
                "post_id": 41644633,
                "comment_id": 70489063,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 10024763,
                    "reputation": 25,
                    "user_id": 7413227,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/130871cc536166a42f2a6987baccfa3d?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "apple",
                    "link": "https://stackoverflow.com/users/7413227/apple"
                },
                "reply_to_user": {
                    "account_id": 3451932,
                    "reputation": 354,
                    "user_id": 2891429,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/967bf80853a295f167ccbc86788bbd7a?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "newGuy",
                    "link": "https://stackoverflow.com/users/2891429/newguy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1484348290,
                "post_id": 41644633,
                "comment_id": 70489267,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 3451932,
                    "reputation": 354,
                    "user_id": 2891429,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/967bf80853a295f167ccbc86788bbd7a?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "newGuy",
                    "link": "https://stackoverflow.com/users/2891429/newguy"
                },
                "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": 1484348609,
                "post_id": 41644633,
                "comment_id": 70489364,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1484348057,
                "creation_date": 1484348057,
                "answer_id": 41644707,
                "question_id": 41644633,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Not sure what you mean by &quot;validate.&quot; But to simply get the `&quot;course&quot;` and it&#39;s current `&quot;enrollment&quot;` status, you could do this:\r\n\r\n    .courses | to_entries[] | &quot;\\(.key) : \\(.value.enrollment)&quot;",
                "title": "How to validate child value in nested json"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1484603869,
                "creation_date": 1484603869,
                "answer_id": 41685671,
                "question_id": 41644633,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "If &quot;validate&quot; means checking that the values are all as expected, then you could use a filter along these lines:\r\n\r\n    .courses\r\n    | with_entries( select( .value.enrollment as $e\r\n                    | [&quot;enrolled&quot;, &quot;not-enrolled&quot;] | index($e) | not) )\r\n\r\n \r\nThat is, select the courses for which the &quot;enrollment&quot; is NOT in the list of acceptable values.  (Here, &quot;X | not&quot; has the effect of negating X.)\r\n\r\nRunning this against your data augmented with a course for which the &quot;enrollment&quot; is invalid yields that course:\r\n\r\n    {\r\n      &quot;french&quot;: {\r\n        &quot;description&quot;: &quot;abc&quot;,\r\n        &quot;enrollment&quot;: &quot;non&quot;,\r\n        &quot;status&quot;: {\r\n          &quot;result&quot;: &quot;OK&quot;\r\n        }\r\n      }\r\n    }\r\n\r\n",
                "title": "How to validate child value in nested json"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1484603869,
        "creation_date": 1484347563,
        "last_edit_date": 1484348084,
        "question_id": 41644633,
        "body_markdown": "This is the json respond body: \r\n\r\n    {\r\n      &quot;studentName&quot;: &quot;good student&quot;,\r\n      &quot;age&quot;: &quot;18&quot;,\r\n      &quot;address&quot;: &quot;street 123&quot;,\r\n      &quot;courses&quot;: {\r\n        &quot;math&quot;: {\r\n          &quot;description&quot;: &quot;how to calculate&quot;,\r\n          &quot;enrollment&quot;: &quot;enrolled&quot;,\r\n          &quot;status&quot;: {\r\n            &quot;result&quot;: &quot;OK&quot;\r\n          }\r\n        },\r\n        &quot;english&quot;: {\r\n          &quot;description&quot;: &quot;abc&quot;,\r\n          &quot;enrollment&quot;: &quot;not-enrolled&quot;,\r\n          &quot;status&quot;: {\r\n            &quot;result&quot;: &quot;OK&quot;\r\n          }\r\n        }\r\n      }\r\n    }\r\n\r\nI&#39;d like to validate the &quot;enrollment&quot; value, for example, I want to get the output in the format: \r\n\r\n    math : enrolled\r\n    english : not-enrolled\r\n\r\nwondering how to do this with jq command, thanks in advance. ",
        "link": "https://stackoverflow.com/questions/41644633/how-to-validate-child-value-in-nested-json",
        "title": "How to validate child value in nested json"
    },
    {
        "tags": [
            "json",
            "environment-variables",
            "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": 1484562955,
                "post_id": 41673543,
                "comment_id": 70546071,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 365601,
                    "reputation": 2438,
                    "user_id": 710618,
                    "user_type": "registered",
                    "accept_rate": 66,
                    "profile_image": "https://www.gravatar.com/avatar/779233af08fd9f187990a44146f1778c?s=256&d=identicon&r=PG",
                    "display_name": "Alexandre Thenorio",
                    "link": "https://stackoverflow.com/users/710618/alexandre-thenorio"
                },
                "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": 1484579898,
                "post_id": 41673543,
                "comment_id": 70556294,
                "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": 1484581786,
                "post_id": 41673543,
                "comment_id": 70557471,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 365601,
                    "reputation": 2438,
                    "user_id": 710618,
                    "user_type": "registered",
                    "accept_rate": 66,
                    "profile_image": "https://www.gravatar.com/avatar/779233af08fd9f187990a44146f1778c?s=256&d=identicon&r=PG",
                    "display_name": "Alexandre Thenorio",
                    "link": "https://stackoverflow.com/users/710618/alexandre-thenorio"
                },
                "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": 1484606944,
                "post_id": 41673543,
                "comment_id": 70569682,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1484563421,
                "creation_date": 1484563421,
                "answer_id": 41674526,
                "question_id": 41673543,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You can use an `if/else` construct:\r\n\r\n\r\n    jq -n --arg myvar &quot;${SOMEVAR}&quot; &#39;if ($myvar|length &gt; 0) then {$myvar} else {} end&#39;\r\n",
                "title": "Conditional variables in JQ json depending on argument value?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1487473355,
                "last_edit_date": 1487473355,
                "creation_date": 1485988103,
                "answer_id": 41991022,
                "question_id": 41673543,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Suppose you have a template of variable names, in the form of an object as you have suggested you want:\r\n\r\n    {a, b, c}\r\n\r\nSuppose also (for the sake of illustration) that you want to pull in the corresponding values from *ix environment variables.  Then you just need to adjust the template, which can be done using this filter:\r\n\r\n    def adjust: with_entries( env[.key] as $v | select($v != null) | .value = $v );\r\n\r\nExample:\r\n\r\nAssuming the above filter, together with the following line, is in a file named adjust.jq:\r\n\r\n     {a,b,c} | adjust\r\n\r\nthen:\r\n\r\n     $ export a=123\r\n     $ jq -n -f -c adjust.jq \r\n     {&quot;a&quot;:&quot;123&quot;}\r\n\r\n   ",
                "title": "Conditional variables in JQ json depending on argument value?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1485990738,
                "creation_date": 1485990738,
                "answer_id": 41991560,
                "question_id": 41673543,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "It&#39;s still not clear where the variable-value pairs are coming from, so maybe it would be simplest to construct the object containing the mapping before invoking jq, and then passing it in using the --argjson or --argfile option?  ",
                "title": "Conditional variables in JQ json depending on argument value?"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1487473355,
        "creation_date": 1484560267,
        "last_edit_date": 1485987188,
        "question_id": 41673543,
        "body_markdown": "I am trying to build a json with jq with --arg arguments however I&#39;d like for the json not to be able to have a condition if the variable is empty.\r\n\r\nAn example, if I run the following command\r\n\r\n    jq -n --arg myvar &quot;${SOMEVAR}&quot; &#39;{ $myvar}&#39;\r\n\r\n\r\nI&#39;d like the json in that case to be `{}` if myvar happens to be empty (Because the variable ${SOMEVAR} does not exist) and not `{ &quot;myvar&quot;: &quot;&quot; }` which is what I get by just running the command above.\r\n\r\nIs there any way to achieve this through some sort of condition?\r\n\r\nUPDATE:\r\n\r\nSome more details about the use case\r\n\r\nI want to build a json based on several environment variables but only include the variables that have a value.\r\n\r\nSomething like\r\n\r\n`{&quot;varA&quot;: &quot;value&quot;, &quot;varB&quot;: &quot;value&quot;}`\r\n\r\nBut only include varA if its value is defined and so on. The issue now is that if value is not defined, the property `varA` will still exist with an empty value and because of the multiple argument/variable nature, using an if/else to build the entire json as suggested will lead to a huge amount of conditions to cover for every possible combination of variables not existing",
        "link": "https://stackoverflow.com/questions/41673543/conditional-variables-in-jq-json-depending-on-argument-value",
        "title": "Conditional variables in JQ json depending on argument value?"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1484573343,
                "creation_date": 1484573343,
                "answer_id": 41677522,
                "question_id": 41677435,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Like in Javascript, you can use brackets to access such &quot;problematic&quot; property names, like this:\r\n\r\n    jq &#39;.perf.cumulativeStatistics[0][&quot;Mean_Test_Time_(ms)&quot;]&#39; sample.data\r\n\r\n",
                "title": "Using jq to fetch a value with a bracket"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1484573343,
        "creation_date": 1484573020,
        "question_id": 41677435,
        "body_markdown": "I have the following JSON data\r\n\r\n     &quot;cumulativeStatistics&quot;: [\r\n          {\r\n            &quot;Mean_Test_Time_(ms)&quot;: 481.6876712328767,\r\n            &quot;Response_bytes_per_second&quot;: 10514.456156404525,\r\n            &quot;Errors&quot;: 0.0,\r\n            &quot;testNumber&quot;: 1.0,\r\n            &quot;TPS&quot;: 2.141001049970378,\r\n            &quot;testDescription&quot;: &quot;Some status&quot;,\r\n            &quot;Mean_time_to_first_byte&quot;: 481.1034246575342,\r\n            &quot;Tests&quot;: 1460.0,\r\n            &quot;Peak_TPS&quot;: 4.0\r\n          },\r\n          {\r\n            &quot;Mean_Test_Time_(ms)&quot;: 453.88211103495547,\r\n            &quot;Response_bytes_per_second&quot;: 10507.254474105619,\r\n            &quot;Errors&quot;: 0.0,\r\n            &quot;testNumber&quot;: 2.0,\r\n            &quot;TPS&quot;: 2.1395346108950557,\r\n            &quot;testDescription&quot;: &quot;Status Again&quot;,\r\n            &quot;Mean_time_to_first_byte&quot;: 453.4825222755312,\r\n            &quot;Tests&quot;: 1459.0,\r\n            &quot;Peak_TPS&quot;: 4.0\r\n          }\r\n\r\nI&#39;m using the following jq that&#39;s able to get out every other parameter except Mean_Test_Time_(ms) because of the brackets\r\n\r\n     cat sample.data | jq &#39;.perf.cumulativeStatistics[0].Response_bytes_per_second&#39;\r\n\r\nIt&#39;s interpretting the brackets itself. So when I use Mean_Test_time_(ms) with that command, I get the following error\r\n\r\n    error: syntax error, unexpected &#39;(&#39;, expecting $end\r\n    .perf.cumulativeStatistics[0].Mean_Test_Time_(ms)\r\n\r\nHow do I escape these paranthesis?\r\n\r\nThanks!",
        "link": "https://stackoverflow.com/questions/41677435/using-jq-to-fetch-a-value-with-a-bracket",
        "title": "Using jq to fetch a value with a bracket"
    },
    {
        "tags": [
            "json",
            "bash",
            "shell",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1484578373,
                "creation_date": 1484578373,
                "answer_id": 41679094,
                "question_id": 41678444,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "One way to do this is to use `split` and `join` to process the path, and use `|=` to bind the correct expression to the `.path` attribute.\r\n\r\n    ... | jq &#39;.[] | .path|=(split(&quot;/&quot;)[:-1]|join(&quot;/&quot;))\r\n\r\n * `split(&quot;/&quot;)` takes a string and returns an array\r\n * `x[:-1]` returns an array consisting of all but the last element of `x`\r\n * `join(&quot;/&quot;)` combines the elements of the incoming array with `/` to return a single string.\r\n * `.path|=x` takes the value of `.path`, feeds it through the filter `x`, and assigns the resulting value to `.path` again.",
                "title": "Bash jq modify json : get and set"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1484578373,
        "creation_date": 1484576257,
        "question_id": 41678444,
        "body_markdown": "I use jq to parse and modify cURL response and it works perfect for all of my requirements except one. I wish to modify a key value in the json, like:\r\n\r\nA) Input json\r\n\r\n    [\r\n        {\r\n            &quot;id&quot;: 169,\r\n            &quot;path&quot;: &quot;dir1/dir2&quot;\r\n        }\r\n    ]\r\n\r\nB) Output json\r\n\r\n    [\r\n        {\r\n            &quot;id&quot;: 169,\r\n            &quot;path&quot;: &quot;dir1&quot;\r\n        }\r\n    ]\r\n\r\nSo the last directory is removed from the path. I use the script:\r\n\r\n    curl --header -X GET -k &quot;${URL}&quot; | jq &#39;[.[] | {id: .id, path: .path_with_namespace}]&#39; | jq &#39;(.[] | .path) = &quot;${.path%/*}&quot;&#39;\r\n\r\nThe last pipe is ofcourse not correct and this is where I am stuck. The point is to get the `path` value and modify it. Any help is appreciated.",
        "link": "https://stackoverflow.com/questions/41678444/bash-jq-modify-json-get-and-set",
        "title": "Bash jq modify json : get and set"
    },
    {
        "tags": [
            "bash",
            "docker",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3959308,
                    "reputation": 53394,
                    "user_id": 3266847,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/U0oyt.png?s=256",
                    "display_name": "Benjamin W.",
                    "link": "https://stackoverflow.com/users/3266847/benjamin-w"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1484579411,
                "post_id": 41678524,
                "comment_id": 70555992,
                "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": 1484630725,
                "post_id": 41678524,
                "comment_id": 70575874,
                "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": 1484674477,
                "post_id": 41678524,
                "comment_id": 70602752,
                "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": 1539040689,
                "post_id": 41678524,
                "comment_id": 92348624,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1539040739,
                "post_id": 41678524,
                "comment_id": 92348641,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1539040895,
                "post_id": 41678524,
                "comment_id": 92348678,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 293130,
                    "reputation": 268849,
                    "user_id": 596285,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/b6975c494d3d9c404dd3d7af2edf3133?s=256&d=identicon&r=PG",
                    "display_name": "BMitch",
                    "link": "https://stackoverflow.com/users/596285/bmitch"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1540234945,
                "post_id": 41678524,
                "comment_id": 92781257,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": -1,
                "last_activity_date": 1484619815,
                "last_edit_date": 1484619815,
                "creation_date": 1484613339,
                "answer_id": 41687269,
                "question_id": 41678524,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Although the default (`json-file`) logging driver uses JSON as a _file format_, the `docker logs` command does not output JSON, but plain text, so if you use jq, you would have to use the -R option to read it.",
                "title": "How to tail docker into jq?"
            },
            {
                "up_vote_count": 5,
                "is_accepted": false,
                "score": 5,
                "last_activity_date": 1540166197,
                "last_edit_date": 1540166197,
                "creation_date": 1539040348,
                "answer_id": 52711227,
                "question_id": 41678524,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Instead of tailing from stdout you might want to tail the log file that is stored in the container directory.\r\n\r\nDocker stores logs for each container under `/var/lib/docker/containers/[container_ID]`, you can find the container ID using `docker inspect --format=&quot;{{.Id}}&quot; container_name`\r\n\r\nthen use tail and jq as you would normally.\r\n\r\n    tail -f  /var/lib/docker/containers/[container_ID]/[container_ID]-json.log | jq &#39;.&#39;\r\n",
                "title": "How to tail docker into jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 5,
        "last_activity_date": 1540166197,
        "creation_date": 1484576513,
        "question_id": 41678524,
        "body_markdown": "I&#39;m trying to pipe json logs from docker into `jq`.\r\nIt works fine if I use:\r\n\r\n    docker logs container_id 2&gt;&amp;1 | jq &#39;.&#39;\r\n\r\nBut, if I try to tail it, it gets stuck (displaying nothing).\r\n\r\n    docker logs -f container_id 2&gt;&amp;1 | jq &#39;.&#39;\r\n\r\nWhile tailing by itself does work:\r\n\r\n    docker logs -f container_id 2&gt;&amp;1\r\n\r\nWhat am I missing here?",
        "link": "https://stackoverflow.com/questions/41678524/how-to-tail-docker-into-jq",
        "title": "How to tail docker into jq?"
    },
    {
        "tags": [
            "arrays",
            "json",
            "bash",
            "curl",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 8390191,
                    "reputation": 19,
                    "user_id": 6299161,
                    "user_type": "registered",
                    "profile_image": "https://graph.facebook.com/1260084150676140/picture?type=large",
                    "display_name": "Kunal Saha",
                    "link": "https://stackoverflow.com/users/6299161/kunal-saha"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1484586709,
                "post_id": 41681227,
                "comment_id": 70560303,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1484586944,
                "post_id": 41681227,
                "comment_id": 70560435,
                "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": 19375,
                    "reputation": 447959,
                    "user_id": 45375,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/39f6e2dc52425b1e08027c01bb880be0?s=256&d=identicon&r=PG",
                    "display_name": "mklement0",
                    "link": "https://stackoverflow.com/users/45375/mklement0"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1484587295,
                "post_id": 41681227,
                "comment_id": 70560616,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1484587691,
                "post_id": 41681227,
                "comment_id": 70560845,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1484598908,
                "last_edit_date": 1484598908,
                "creation_date": 1484586818,
                "answer_id": 41681604,
                "question_id": 41681227,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "As @mklement0 pointed out, you could just write:\r\n\r\n    $ jq &#39;.status.hostgroup_summary[].hosts_up&#39; input.json\r\n    9\r\n\r\nPlease note, however, that the `.keyname` trick only works if the key name is alphanumeric and has a leading alphabetic character (it being understood that _ counts as an alphabetic character here).  In general, the form .[&quot;KEY&quot;] is more robust.  Thus, one of the many other alternatives would be:\r\n\r\n    jq &#39;.[&quot;status&quot;][&quot;hostgroup_summary&quot;][] | .[&quot;hosts_up&quot;]&#39;\r\n\r\n\r\nTo emit an object, you can use the `{ &quot;KEY&quot; }` abbreviation:\r\n\r\n    $ jq &#39;.status.hostgroup_summary[] | { &quot;hosts_up&quot; }&#39; input.json\r\n    {\r\n      &quot;hosts_up&quot;: 9\r\n    }\r\n\r\nIf you want an approach that is completely agnostic about the exact location (or locations) of the &quot;hosts_up&quot; key, consider:\r\n\r\n    $ jq &#39;.. | .hosts_up? | select(.)&#39;\r\n\r\nThis will fetch all truthy values associated with a &quot;hosts_up&quot; key, if there are any.  (Truthy here means neither null nor false.)  If you want to fetch all values associated with the given key, you&#39;d have to check for the key&#39;s presence:\r\n\r\n    $ jq &#39;.. | select(type == &quot;object&quot; and has(&quot;hosts_up&quot;)) | .hosts_up&#39;\r\n\r\nWith recent versions of jq, this last can be shortened to:\r\n\r\n    $ jq &#39;.. | objects | select(has(&quot;hosts_up&quot;)) | .hosts_up&#39;",
                "title": "JQ not parsing desired output, can&#39;t fetch numbers with string"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": -3,
                "last_activity_date": 1484589209,
                "last_edit_date": 1495540390,
                "creation_date": 1484589209,
                "answer_id": 41682273,
                "question_id": 41681227,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "\r\n\r\n    | jq -r &#39;.[] | .[] | .[] | .hosts_up&#39;  \r\n\r\nAbove guys.. your downvotes encouraged me to google more and more to find the answer for it and hopefully i found the exact answer for it. \r\n\r\nReference - https://stackoverflow.com/questions/39798542/using-jq-to-fetch-key-value-from-json-output?rq=1 \r\n\r\nI&#39;m a system admin and i can&#39;t show all my hit and trial things all along here.. hope you gonna understand !\r\n",
                "title": "JQ not parsing desired output, can&#39;t fetch numbers with string"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1484590436,
                "last_edit_date": 1495539949,
                "creation_date": 1484590091,
                "answer_id": 41682517,
                "question_id": 41681227,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "With your sample input, **extracting the value of interest** is straightforward, using the **appropriately constructed path** to the key of interest:\r\n\r\n    $ jq &#39;.status.hostgroup_summary[0].hosts_up&#39; file\r\n    9\r\n\r\nSubkey `hostgroup_summary` of top-level key `status` is an _array_, hence the need to use `[0]` to target the first element.\r\n\r\nA value of any JSON type can be retrieved this way, whether it is a number or not, and technically the output is always a _string_, though `jq` by default preserves the JSON value formatting (unquoted output of numbers and Booleans, double-quoted output otherwise; arrays as in JSON).  \r\nFor scalar values, you can add option `-r` (raw output) to omit the double quotes.\r\n\r\n----------\r\n\r\nIf the **array contained _multiple_ entries and you want to extract them _all_**, simply use `[]` instead of `[0]`:\r\n\r\n    $ jq &#39;.status.hostgroup_summary[].hosts_up&#39; file\r\n    9\r\n\r\nNote with only a single array element the results are the same, but if you had multiple ones, each value would print on a separate line.\r\n\r\n----------\r\n\r\nTo **return the entry/ies *as a whole***, as JSON strings containing the key as well, use the following, as also demonstrated in [peak&#39;s](https://stackoverflow.com/a/41681604/45375) answer:\r\n\r\n    $ jq &#39;.status.hostgroup_summary[] | { &quot;hosts_up&quot; }&#39; file\r\n    {\r\n      &quot;hosts_up&quot;: 9\r\n    }\r\n\r\n----------\r\n\r\nOn a side note: If your path contains **keys that do not start with an ASCII letter, digit, or `_`**, you must **double-quote** them; e.g.\r\n\r\n    $ jq &#39;.status.&quot;0key&quot;&#39; &lt;&lt;&lt;&#39;{ &quot;status&quot;: { &quot;0key&quot;: 9 } }&#39; # Note the &quot;...&quot; around 0key\r\n    9\r\n\r\n\r\n\r\n",
                "title": "JQ not parsing desired output, can&#39;t fetch numbers with string"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1484598908,
        "creation_date": 1484585474,
        "last_edit_date": 1484586105,
        "question_id": 41681227,
        "body_markdown": "My json will look like.\r\n\r\n    {\r\n      &quot;cgi_json_version&quot;: &quot;1.8.0&quot;,\r\n    \r\n      &quot;status&quot;: {\r\n    \r\n        &quot;hostgroup_summary&quot;: [\r\n    \r\n          { &quot;hostgroup_name&quot;: &quot;ESXI&quot;,\r\n            &quot;hosts_up&quot;: 9, &quot;hosts_down&quot;: 0,\r\n            &quot;hosts_down_unacknowledged&quot;: 0, &quot;hosts_down_scheduled&quot;: 0,\r\n            &quot;hosts_down_acknowledged&quot;: 0, &quot;hosts_down_disabled&quot;: 0,\r\n            &quot;hosts_unreachable&quot;: 0, &quot;hosts_unreachable_unacknowledged&quot;: 0,\r\n            &quot;hosts_unreachable_scheduled&quot;: 0, &quot;hosts_unreachable_acknowledged&quot;: 0,\r\n            &quot;hosts_unreachable_disabled&quot;: 0, &quot;hosts_pending&quot;: 0,\r\n            &quot;services_ok&quot;: 0, &quot;services_warning&quot;: 0,\r\n            &quot;services_warning_unacknowledged&quot;: 0, &quot;services_warning_host_problem&quot;: 0,\r\n            &quot;services_warning_scheduled&quot;: 0, &quot;services_warning_acknowledged&quot;: 0,\r\n            &quot;services_warning_disabled&quot;: 0, &quot;services_unknown&quot;: 0,\r\n            &quot;services_unknown_unacknowledged&quot;: 0,\r\n            &quot;services_unknown_host_problem&quot;: 0, &quot;services_unknown_scheduled&quot;: 0,\r\n            &quot;services_unknown_acknowledged&quot;: 0, &quot;services_unknown_disabled&quot;: 0,\r\n            &quot;services_critical&quot;: 0, &quot;services_critical_unacknowledged&quot;: 0,\r\n            &quot;services_critical_host_problem&quot;: 0, &quot;services_critical_scheduled&quot;: 0,\r\n            &quot;services_critical_acknowledged&quot;: 0, &quot;services_critical_disabled&quot;: 0,\r\n            &quot;services_pending&quot;: 0 \r\n          }\r\n    \r\n        ]\r\n    \r\n      }\r\n    \r\n    }\r\n\r\nI want to fetch just **hosts_up : 9** or simply the number **9**, tried many examples but it didn&#39;t went well, help me.\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/41681227/jq-not-parsing-desired-output-cant-fetch-numbers-with-string",
        "title": "JQ not parsing desired output, can&#39;t fetch numbers with string"
    },
    {
        "tags": [
            "json",
            "key",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1442058,
                    "reputation": 1085,
                    "user_id": 1397555,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/59b8a19f4d77ce702757fc50956e452e?s=256&d=identicon&r=PG",
                    "display_name": "Alex Hall",
                    "link": "https://stackoverflow.com/users/1397555/alex-hall"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1516335743,
                "post_id": 41712363,
                "comment_id": 83653475,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 8,
                "is_accepted": false,
                "score": 8,
                "last_activity_date": 1484722057,
                "creation_date": 1484722057,
                "answer_id": 41713019,
                "question_id": 41712363,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Tho dot in `storage_server.disk_total&quot; needs to be escaped to prevent it from being interpreted as an object key separator. so you can use:\r\n\r\n    jq &#39;.stats.&quot;storage_server.disk_total&quot;&#39;\r\n\r\nassuming that `XXXXXXXXXX` is a valid JSON number in your real JSON.",
                "title": "Basic jq usage. How to get nested value"
            },
            {
                "up_vote_count": 20,
                "is_accepted": true,
                "score": 20,
                "last_activity_date": 1484725348,
                "last_edit_date": 1484725348,
                "creation_date": 1484722371,
                "answer_id": 41713087,
                "question_id": 41712363,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "1. For learning how to construct jq queries, it is more useful to look at the [tutorial][1] and [manual][2] than the &quot;man&quot; page. There&#39;s also a [FAQ][3].\r\n2. The inner key name has a period in it, and therefore the `.keyname` shorthand cannot be used for it.  So you could write:\r\n&lt;p&gt;&lt;/p&gt;\r\n       .stats[&quot;storage_server.disk_total&quot;] \r\n\r\nor if your jq allows it:\r\n\r\n       .stats.&quot;storage_server.disk_total&quot; \r\n\r\nThese are both abbreviations for:\r\n\r\n       .stats | .[&quot;storage_server.disk_total&quot;] \r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/tutorial/\r\n  [2]: https://stedolan.github.io/jq/manual/\r\n  [3]: https://github.com/stedolan/jq/wiki/FAQ",
                "title": "Basic jq usage. How to get nested value"
            },
            {
                "up_vote_count": 31,
                "is_accepted": false,
                "score": 31,
                "last_activity_date": 1512129428,
                "creation_date": 1512129428,
                "answer_id": 47592887,
                "question_id": 41712363,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "To get *deeply* nested values by their key:\r\n\r\n    $ jq &#39;.. |.&quot;storage_server.disk_total&quot;? | select(. != null)&#39;\r\n\r\n[`..` is a shortcut for the zero-argument `recurse`](https://stedolan.github.io/jq/manual/#RecursiveDescent:..) -- an analog of  the XPath `//` operator.",
                "title": "Basic jq usage. How to get nested value"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 29,
        "last_activity_date": 1557082816,
        "creation_date": 1484719138,
        "last_edit_date": 1557082816,
        "question_id": 41712363,
        "body_markdown": "This must be incredibly simple but the man page makes no sense to me.\r\n`curl example.com/json` gives me\r\n\r\n    {\r\n     &quot;stats&quot;: {\r\n      &quot;storage_server.disk_total&quot;: XXXXXXXXXX\r\n     },\r\n     &quot;counters&quot;: {}\r\n    }\r\nand I want to extract the value `XXXXXXXXXX` of the disk_total. What is the syntax to do this?",
        "link": "https://stackoverflow.com/questions/41712363/basic-jq-usage-how-to-get-nested-value",
        "title": "Basic jq usage. How to get nested value"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2251762,
                    "reputation": 292345,
                    "user_id": 1983854,
                    "user_type": "registered",
                    "accept_rate": 96,
                    "profile_image": "https://i.sstatic.net/KiqLo.png?s=256",
                    "display_name": "fedorqui",
                    "link": "https://stackoverflow.com/users/1983854/fedorqui"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1484734069,
                "post_id": 41716141,
                "comment_id": 70627786,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1484733993,
                "creation_date": 1484733993,
                "answer_id": 41716455,
                "question_id": 41716141,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "To select a block you need to use the expression described in the docs:\r\n\r\n&gt; [**select(boolean_expression)**][1]\r\n&gt; \r\n&gt; The function select(foo) produces its input unchanged if foo returns\r\n&gt; true for that input, and produces no output otherwise.\r\n&gt; \r\n&gt; It’s useful for filtering lists: [1,2,3] | map(select(. &gt;= 2)) will\r\n&gt; give you [2,3].\r\n&gt; \r\n \tjq &#39;.[] | select(.id == &quot;second&quot;)&#39;\r\n     Input\t[{&quot;id&quot;: &quot;first&quot;, &quot;val&quot;: 1}, {&quot;id&quot;: &quot;second&quot;, &quot;val&quot;: 2}]\r\n     Output\t{&quot;id&quot;: &quot;second&quot;, &quot;val&quot;: 2}\r\n\r\nSo in this case you need to say:\r\n\r\n    $ jq &#39;.[] | select(.keyProp==11111111111111)&#39; file\r\n    {\r\n      &quot;values&quot;: [\r\n        &quot;VALUE1&quot;\r\n      ],\r\n      &quot;keyProp&quot;: 11111111111111\r\n    }\r\n\r\nTo extract the list in `value`, just say so:\r\n\r\n    $ jq &#39;.[] | select(.keyProp==11111111111111).values&#39; file\r\n    [\r\n      &quot;VALUE1&quot;\r\n    ]\r\n\r\nYou can even extract the first value by using indexes:\r\n\r\n    $ jq &#39;.[] | select(.keyProp==11111111111111).values[0]&#39; file\r\n    &quot;VALUE1&quot;\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/#Builtinoperatorsandfunctions\r\n\r\n\r\n",
                "title": "Extracting element from array in JSON with jq returns &quot;Cannot index array with string&quot;"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1484734057,
        "creation_date": 1484733133,
        "last_edit_date": 1484734057,
        "question_id": 41716141,
        "body_markdown": "I have a JSON file: \r\n\r\n    $ cat ~/tmp/example1.json\r\n    [\r\n      {\r\n        &quot;keyProp&quot;: 11111111111111,\r\n        &quot;values&quot;: [\r\n          &quot;VALUE1&quot;\r\n        ]\r\n      },\r\n      {\r\n        &quot;keyProp&quot;: 2222,\r\n        &quot;values&quot;: [\r\n          &quot;VALUE2&quot;\r\n        ]\r\n      }\r\n    ]\r\n\r\nI want to use jq to select values where `keyProp==11111111111111`. Expected output is &#39;VALUE2&#39;\r\n\r\nI have tried but without result:\r\n\r\n    cat ~/tmp/example1.json | jq &#39;select(.keyProp==11111111111111)&#39;\r\n    jq: error (at &lt;stdin&gt;:14): Cannot index array with string &quot;keyProp&quot;\r\n\r\n",
        "link": "https://stackoverflow.com/questions/41716141/extracting-element-from-array-in-json-with-jq-returns-cannot-index-array-with-s",
        "title": "Extracting element from array in JSON with jq returns &quot;Cannot index array with string&quot;"
    },
    {
        "tags": [
            "json",
            "bash",
            "mongodb",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1143565,
                    "reputation": 535973,
                    "user_id": 1126841,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa05233b2357f8d11c22ef4cfc7bb85c?s=256&d=identicon&r=PG",
                    "display_name": "chepner",
                    "link": "https://stackoverflow.com/users/1126841/chepner"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1484757421,
                "post_id": 41718679,
                "comment_id": 70644057,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1484752264,
                "last_edit_date": 1484752264,
                "creation_date": 1484743256,
                "answer_id": 41719711,
                "question_id": 41718679,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here&#39;s one approach.  To illustrate, I&#39;ve used awk as it can read the list of files in small batches and because it has the ability to execute jq and mongoimport.  You will probably need to make some adjustments to make the whole thing more robust, to test for errors, and so on.  \r\n\r\nThe idea is either to generate a script that can be reviewed and then executed, or to use awk&#39;s system() command to execute the commands directly.  First, let&#39;s generate the script:\r\n\r\n\r\n     ls *.json | awk -v group=10 -v tmpfile=json.tmp &#39;\r\n      function out() {\r\n        print &quot;jq -s . &quot; files &quot; &gt; &quot; tmpfile;\r\n        print &quot;mongoimport --writeConcern 0 --db mydb --collection all --quiet --file &quot; tmpfile;\r\n        print &quot;rm &quot; tmpfile;\r\n        files=&quot;&quot;;\r\n      }\r\n      BEGIN {n=1; files=&quot;&quot;;\r\n        print &quot;test -r &quot; tmpfile &quot; &amp;&amp; rm &quot; tmpfile;\r\n      }\r\n      n % group == 0 {\r\n        out();\r\n      }\r\n      { files = files &quot; \\&quot;&quot;$0 &quot;\\&quot;&quot;;\r\n        n++;\r\n      }\r\n      END { if (files) {out();}}\r\n    &#39;\r\n\r\n\r\nOnce you&#39;ve verified this works, you can either execute the generated script, or change the &quot;print ...&quot; lines to use &quot;system(....)&quot;\r\n\r\n### Using jq to generate the script\r\n\r\nHere&#39;s a jq-only approach for generating the script.\r\nSince the number of files is very large, the following uses features that were only introduced in jq 1.5, so its memory usage is similar to the awk script above:\r\n\r\n    def read(n):\r\n      # state: [answer, hold]\r\n      foreach (inputs, null) as $i\r\n        ([null, null];\r\n\t     if $i == null then .[0] = .[1] \r\n           elif .[1]|length == n then [.[1],[$i]] \r\n           else [null, .[1] + [$i]]\r\n           end;\r\n         .[0] | select(.) );\r\n\r\n    &quot;test -r json.tmp &amp;&amp; rm json.tmp&quot;,\r\n     (read($group|tonumber)\r\n     | map(&quot;\\&quot;\\(.)\\&quot;&quot;) \r\n     | join(&quot; &quot;)\r\n     | (&quot;jq -s . \\(.) &gt; json.tmp&quot;, mongo(&quot;json.tmp&quot;), &quot;rm json.tmp&quot;) )\r\n\r\n\r\nInvocation:\r\n\r\n\r\n    ls *.json | jq -nRr --arg group 10 -f generate.jq",
                "title": "Bash loop to merge files in batches for mongoimport"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1484750392,
                "creation_date": 1484750392,
                "answer_id": 41722243,
                "question_id": 41718679,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is what I came up with. It seems to work and is importing at roughly 80 a second into an external hard drive.\r\n\r\n    #!/bin/bash\r\n    files=(*.json)\r\n    for((I=0;I&lt;${#files[*]};I+=500)); do jq -c &#39;.&#39; ${files[@]:I:500} | mongoimport --writeConcern 0 --numInsertionWorkers 16 --db mydb --collection all --quiet;echo $I; done\r\n\r\nHowever, some are failing.  I&#39;ve imported 105k files but only 98547 appeared in the mongo collection.  I think it&#39;s because some documents are &gt; 16mb.",
                "title": "Bash loop to merge files in batches for mongoimport"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 3,
        "last_activity_date": 1484752264,
        "creation_date": 1484740152,
        "last_edit_date": 1484740755,
        "question_id": 41718679,
        "body_markdown": "I have a directory with 2.5 million small JSON files in it.  It&#39;s 104gb on disk.  They&#39;re multi-line files.\r\n\r\nI would like to create a set of JSON arrays from the files so that I can import them using mongoimport in a reasonable amount of time.  The files can be no bigger than 16mb, but I&#39;d be happy even if I managed to get them in sets of ten.\r\n\r\nSo far, I can use this to do them one at a time at about 1000/minute:\r\n\r\n    for i in *.json; do mongoimport --writeConcern 0 --db mydb --collection all --quiet --file $i; done\r\n\r\nI think I can use &quot;jq&quot; to do this, but I have no idea how to make the bash loop pass 10 files at a time to jq.\r\nNote that using bash find results in an error as there are too many files.\r\n\r\nWith jq you can use --slurp to create arrays, and -c to make multiline json single line.  However, I can&#39;t see how to combine the two into a single command.\r\n\r\nPlease help with both parts of the problem if possible.",
        "link": "https://stackoverflow.com/questions/41718679/bash-loop-to-merge-files-in-batches-for-mongoimport",
        "title": "Bash loop to merge files in batches for mongoimport"
    },
    {
        "tags": [
            "json",
            "bash",
            "parameter-passing",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 21,
                "is_accepted": true,
                "score": 21,
                "last_activity_date": 1485017417,
                "last_edit_date": 1495540375,
                "creation_date": 1484951424,
                "answer_id": 41773407,
                "question_id": 41772776,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "**`jq` is data-type-aware**:\r\n\r\n* `.ID`, as defined in the *JSON* input, is a _number_, \r\n\r\n* but any *command-line argument* passed with `--arg` (such as `v` here) is invariably a _string_ (whether you quote the value or not), \r\n\r\nso, in order to compare them, you must **use an explicit type conversion**, such as with [`tonumber/1`](https://stedolan.github.io/jq/manual/v1.4/#Builtinoperatorsandfunctions):\r\n\r\n    jq --arg v &#39;2&#39; &#39;.jobStatus[] | select(.ID == ($v | tonumber)) | .status&#39; test.txt\r\n\r\n----------\r\n\r\nGiven that you&#39;re only passing a _scalar_ argument here, the following solution, using `--argjson` (`jq` v1.5+) is a bit of an overkill, but it is an **alternative to explicit type conversion** in that **passing a *JSON* argument in effect passes _typed_ data**:\r\n\r\n    jq --argjson v &#39;{ &quot;ID&quot;: 2 }&#39; &#39;.jobStatus[] | select(.ID == $v.ID) | .status&#39; test.txt\r\n\r\n----------\r\n\r\n[peak&#39;s answer](https://stackoverflow.com/a/41773512/45375) demonstrates that **even `--argjson v 2` works** (in which case comparing to `$v` works directly), which is certainly the **most *concise*** solution, but may require an **explanation**:\r\n\r\n * Even though `2` may not _look_ like JSON, it is: it is a valid JSON text containing a single *value* of type *number* (see [json.org](http://json.org)).\r\n \r\n  * Specifically, it is the fact that `2` is an _unquoted_ token that starts with a *digit* that makes it a number in the context of *JSON* (the JSON _string_-value equivalent is `&quot;2&quot;`, which from the shell would have to be passed as `&#39;&quot;2&quot;&#39;` - note the embedded double quotes).\r\n\r\n * Therefore `jq` interprets `--argjson -v 2` as a _number_, and comparison `.ID == $v` works as intended (note that the same applies to `--argjson -v &#39;2&#39;` / `--argjson -v &quot;2&quot;`, where the shell removes the quotes before `jq` sees the value).  \r\nBy contrast, anything you pass with `--arg` is always a _string_ value that is used as-is.\r\n\r\n * In other words: `--argjson`, whose purpose is to accept arbitrary JSON texts as strings (such as `&#39;{ &quot;ID&quot;: 2 }&#39;` in the example above), can also be used to pass number-string _scalars_ to force their interpretation as numbers.  \r\nThe same technique also works with Boolean strings `true` and `false`.\r\n\r\n----------\r\n\r\n&lt;sup&gt;Tip of the hat to [peak](https://stackoverflow.com/users/997358/peak) for his help.&lt;/sup&gt;\r\n\r\n",
                "title": "Numeric argument passed with jq --arg not matching data with =="
            },
            {
                "up_vote_count": 7,
                "is_accepted": false,
                "score": 7,
                "last_activity_date": 1484953613,
                "last_edit_date": 1484953613,
                "creation_date": 1484951952,
                "answer_id": 41773512,
                "question_id": 41772776,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Assuming you want to check for the JSON value `2`, you have a choice to make - either convert the argument of --arg to a number, or use --argjson with a numeric argument. These alternatives are illustrated by the following:\r\n\r\n    jq --arg v 2 &#39;.jobStatus[] | select(.ID == ($v|tonumber) | .status&#39; \r\n\r\n    jq --argjson v 2 &#39;.jobStatus[] | select(.ID == $v) | .status&#39;\r\n\r\nNote that --argjson requires a relatively recent version of jq.\r\n\r\nOf course, if you want to &quot;normalize&quot; .ID so that it&#39;s always treated as a string, you could write:\r\n\r\n    jq --arg v 2 &#39;.jobStatus[] | select((.ID|tostring) == $v) | .status&#39;",
                "title": "Numeric argument passed with jq --arg not matching data with =="
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 10,
        "last_activity_date": 1485017417,
        "creation_date": 1484948452,
        "last_edit_date": 1484971899,
        "question_id": 41772776,
        "body_markdown": "Here is a sample JSON response from my curl:\r\n\r\n    {\r\n      &quot;success&quot;: true,\r\n      &quot;message&quot;: &quot;jobStatus&quot;,\r\n      &quot;jobStatus&quot;: [\r\n        {\r\n          &quot;ID&quot;: 9,\r\n          &quot;status&quot;: &quot;Successful&quot;\r\n        },\r\n        {\r\n          &quot;ID&quot;: 2,\r\n          &quot;status&quot;: &quot;Successful&quot;\r\n        },\r\n       {\r\n          &quot;ID&quot;: 99,\r\n          &quot;status&quot;: &quot;Failed&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\nI want to check the status of ID=2. Here is the command I tried:\r\n\r\n    cat test.txt|jq --arg v &quot;2&quot; &#39;.jobStatus[]|select(.ID == $v)|.status&#39;\r\n\r\nresponse: there is none\r\n\r\nI tried value `2` without quotes and still no result.\r\n\r\nBy contrast, if I try the command with a _literal_ `2`, it works:\r\n\r\n    cat test.txt | jq &#39;.jobStatus[]|select(.ID == 2)|.status&#39;\r\n\r\nresponse:\r\n\r\n    &quot;Successful&quot;\r\n\r\nI&#39;m stuck. Can anyone help me identify the problem?\r\n\r\n",
        "link": "https://stackoverflow.com/questions/41772776/numeric-argument-passed-with-jq-arg-not-matching-data-with",
        "title": "Numeric argument passed with jq --arg not matching data with =="
    },
    {
        "tags": [
            "jq",
            "notation",
            "arity"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1511204118,
                "last_edit_date": 1511204118,
                "creation_date": 1485036918,
                "answer_id": 41785129,
                "question_id": 41784823,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The notation name/arity gives the name and arity of the function.  &quot;arity&quot; is the number of arguments (i.e., parameters), so for example explode/0 means you&#39;d just write `explode` without any arguments, and map/1 means you&#39;d write something like `map(f)`. \r\n\r\nThe fact that 0-arity functions are invoked by name, without any parentheses, makes the notation especially handy.  The fact that a function name can have multiple definitions at any one time (each definition having a distinct arity) makes it easy to distinguish between them.\r\n\r\nThis notation is not used in jq programs, but it is used in the output of the (new) built-in filter, `builtins/0`.\r\n\r\nBy contrast, in some other programming languages, it (or some close variant, e.g. module:name/arity in Erlang) is also part of the language.\r\n\r\n### Why?\r\n\r\nThere are various difficulties which typically arise when attempting to graft a notation that&#39;s suitable for languages in which method-dispatch is based on types onto ones in which dispatch is based solely on arity.\r\n\r\nThe first, as already noted, has to do with 0-arity functions. This is especially problematic for jq as 0-arity functions are invoked in jq without parentheses.\r\n\r\nThe second is that, in general, jq functions do not require their arguments to be any one jq type.  Having to write something like `nth(string+number)` rather than just `nth/1` would be tedious at best. \r\n\r\nThis is why the manual strenuously avoids using &quot;name(type)&quot;-style notation.  Thus we see, for example, `startswith(str)`, rather than `startswith(string)`.  That is, the parameter names in the documentation are clearly just names, though of course they often give strong type hints.\r\n\r\nIf you&#39;re wondering why the &#39;name/arity&#39; convention isn&#39;t documented in the manual, it&#39;s probably largely because the documentation was mostly written before jq supported multi-arity functions.\r\n\r\nIn summary -- any notational scheme can be made to work, but `name/arity` is (1) concise; (2) precise in the jq context; (3) easy-to-learn; and (4) widely in use for arity-oriented languages, at least on this planet.",
                "title": "What does the jq notation &lt;function&gt;/&lt;number&gt; mean?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1511204118,
        "creation_date": 1485034766,
        "last_edit_date": 1495542258,
        "question_id": 41784823,
        "body_markdown": "In various web pages, I see references to jq functions with a slash and a number following them. For example:\r\n\r\n    walk/1\r\n\r\nI found the above notation used on a [stackoverflow][1] page.\r\n\r\nI could not find in the [jq Manual][2] page a definition as to what this notation means. I&#39;m guessing it might indicate that the `walk` function that takes 1 argument. If so, I wonder why a more meaningful notation isn&#39;t used such  as is used with signatures in C++, Java, and other languages:\r\n\r\n    &lt;function&gt;(type1, type2, ..., typeN)\r\n\r\nCan anyone confirm what the notation `&lt;function&gt;/&lt;number&gt;` means? Are other variants used?\r\n\r\n\r\n  [1]: https://stackoverflow.com/questions/31930041/using-jq-or-alternative-command-line-tools-to-diff-json-files\r\n  [2]: https://stedolan.github.io/jq/manual/",
        "link": "https://stackoverflow.com/questions/41784823/what-does-the-jq-notation-function-number-mean",
        "title": "What does the jq notation &lt;function&gt;/&lt;number&gt; mean?"
    },
    {
        "tags": [
            "json",
            "filter",
            "key",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1485227531,
                "creation_date": 1485227531,
                "answer_id": 41819398,
                "question_id": 41819201,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Huzzah. Simple enough really :)\r\n\r\n    cat LogSample.txt | jq  &#39;. | {Id: .Id, client: {ip: .client.ip}}&#39;\r\nBasically define the object yourself :)",
                "title": "How do I simplify a JSON object using JQ?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1485232604,
                "last_edit_date": 1485232604,
                "creation_date": 1485229502,
                "answer_id": 41819661,
                "question_id": 41819201,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "It looks like it will be simplest if you construct the object you want.  Based on your example, you could do so using the following filter:\r\n\r\n    { timestamp,\r\n      client: { ip: .client.ip },\r\n      clientRequest: {bytes: .clientRequest.bytes }\r\n    }\r\n\r\n\r\nBy contrast, `map` expects its input to be an array, whereas your input is a JSON object.\r\n\r\nPlease also note that jq provides direct ways to remove keys as well, e.g. using `del/1`.",
                "title": "How do I simplify a JSON object using JQ?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 3,
        "last_activity_date": 1621967577,
        "creation_date": 1485226169,
        "last_edit_date": 1621967577,
        "question_id": 41819201,
        "body_markdown": "I&#39;ve got a huge JSON object and I want to filter it down, to a small % of the available fields. I&#39;ve searched some similar questions, such as [enter link description here][1] but that is for an array of objects. I have a JSON object that looks something like: \r\n\r\n    {\r\n    &quot;timestamp&quot;:1455408955250999808,\r\n    &quot;client&quot;:  \r\n        {\r\n        &quot;ip&quot;:&quot;76.72.172.208&quot;,\r\n        &quot;srcPort&quot;:0,\r\n        &quot;country&quot;:&quot;us&quot;,\r\n        &quot;deviceType&quot;:&quot;desktop&quot;},\r\n    &quot;clientRequest&quot;:\r\n        {\r\n        &quot;bytes&quot;:410,\r\n        &quot;bodyBytes&quot;:0}\r\n      }\r\n\r\nWhat I&#39;m trying to do is create a new JSON object that looks likes:\r\n\r\n    {\r\n    &quot;timestamp&quot;:1455408955250999808,\r\n    &quot;client&quot;:  \r\n        {\r\n        &quot;ip&quot;:&quot;76.72.172.208&quot;,\r\n         }\r\n    &quot;clientRequest&quot;:\r\n        {\r\n        &quot;bytes&quot;:410\r\n        }\r\n    }\r\n\r\nSo effectively filter down the data. I&#39;ve tried:\r\n`| jq &#39;map({client.ip: .client.ip, timestamp: .timestamp})&#39;` and I continue to get:\r\n    \r\n    jq: error (at &lt;stdin&gt;:0): Cannot index number with string &quot;client&quot;\r\nEven the most simple `| jq &#39;map({timestamp: .timestamp})&#39;` is showing the same error.\r\n\r\nI thought I could access the K,V pairs and use the map function as the person did for his array in the question linked above. Any help much appreciated.\r\n\r\n  [1]: https://stackoverflow.com/questions/27838154/how-do-i-remove-all-keys-except-one-with-jq",
        "link": "https://stackoverflow.com/questions/41819201/how-do-i-simplify-a-json-object-using-jq",
        "title": "How do I simplify a JSON object using JQ?"
    },
    {
        "tags": [
            "json",
            "filter",
            "key",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1485250316,
                "post_id": 41823497,
                "comment_id": 70836269,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 2656759,
                    "reputation": 1937,
                    "user_id": 2297299,
                    "user_type": "registered",
                    "accept_rate": 47,
                    "profile_image": "https://www.gravatar.com/avatar/59d8340b2c48870ce68c935fb7967266?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "HectorOfTroy407",
                    "link": "https://stackoverflow.com/users/2297299/hectoroftroy407"
                },
                "reply_to_user": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1485257390,
                "post_id": 41823497,
                "comment_id": 70840979,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 7991,
                    "reputation": 207724,
                    "user_id": 14104,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/otetW.jpg?s=256",
                    "display_name": "epascarello",
                    "link": "https://stackoverflow.com/users/14104/epascarello"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1485277807,
                "post_id": 41823497,
                "comment_id": 70855048,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 42463,
                    "reputation": 28878,
                    "user_id": 123695,
                    "user_type": "registered",
                    "accept_rate": 89,
                    "profile_image": "https://www.gravatar.com/avatar/c1e4202cb329b1e3343a571dff94c68c?s=256&d=identicon&r=PG",
                    "display_name": "Michael Mior",
                    "link": "https://stackoverflow.com/users/123695/michael-mior"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1660141473,
                "post_id": 41823497,
                "comment_id": 129463387,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 9,
                "is_accepted": false,
                "score": 9,
                "last_activity_date": 1485268962,
                "last_edit_date": 1485268962,
                "creation_date": 1485265334,
                "answer_id": 41829748,
                "question_id": 41823497,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "This is where object addition comes in very handy, especially since `$obj + null` yields `$obj` (if `$obj` is a JSON object):\r\n\r\n    .student |  {name} + if has(&quot;quote&quot;) then {quote} else null end\r\n\r\nor equivalently:\r\n\r\n    def maybe(k): if has(k) then {(k): .[k]} else null end;\r\n    .student |  {name} + maybe(&quot;quote&quot;)\r\n\r\n\r\nA slightly different approach, with subtly different semantics, would be:\r\n\r\n    .student |  {name} + ((select(.quote) | {quote}) // null)\r\n\r\nOf course other variations are possible.\r\n\r\n",
                "title": "JQ create field only if it exists"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1485277518,
                "creation_date": 1485277518,
                "answer_id": 41834145,
                "question_id": 41823497,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "If you know what the keys are ahead of time and they&#39;re straight properties, just build up an array of the keys you want and check if the object contains those keys.\r\n\r\n    $ jq --argjson keys &#39;[&quot;name&quot;,&quot;quote&quot;]&#39; &#39;\r\n    def copy_keys($keys): . as $o\r\n        | reduce $keys[] as $k ({}; if ($o|has($k)) then .[$k] = $o[$k] else . end)\r\n        ;\r\n    .student | copy_keys($keys)&#39; text.txt\r\n\r\nBut the way you worded your question, _&quot;Or more generally, create ALL fields only if they exist in the object being inspected,&quot;_ you just want all the keys in the object as long as it has a key. Why not just get the object?\r\n\r\n    $ jq &#39;.student&#39; text.txt",
                "title": "JQ create field only if it exists"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 3,
        "last_activity_date": 1660141438,
        "creation_date": 1485247037,
        "last_edit_date": 1660141438,
        "question_id": 41823497,
        "body_markdown": "In jq, how do I ensure a k,v is only created if it exists in the object being inspected? For example, let&#39;s say I have an object like:\r\n\r\n    {\r\n     &quot;student&quot;:{\r\n        &quot;name&quot;: &quot;george&quot;,\r\n        &quot;age&quot; : &quot;15&quot;,\r\n        &quot;quote&quot;: &quot;Hello I am George&quot;\r\n        }\r\n     }\r\n\r\nAnd I do `cat text.txt | jq &#39;{name: .student.name, quote: .student.quote}&#39;\r\n` to create:\r\n\r\n      {\r\n       &quot;name&quot;: &quot;george&quot;,\r\n       &quot;quote&quot;: &quot;Hello I am George&quot;\r\n       }\r\n\r\nHowever, some of the entries are incomplete, and I don&#39;t want to write an empty K,V. Let&#39;s say I get:\r\n\r\n    {\r\n     &quot;student&quot;:{\r\n        &quot;name&quot;: &quot;Shirley&quot;\r\n      }\r\n    } \r\n\r\nWith the current jq above this would create:\r\n\r\n     {\r\n      &quot;name&quot;: &quot;Shirley&quot;,\r\n      &quot;quote&quot;: null,\r\n      }\r\n\r\nIs there a way I can tell jq to only create the `&#39;quote&#39;` key if it exists (i.e. is not null)? Or more generally, create ALL keys only if they exist in the object being inspected.",
        "link": "https://stackoverflow.com/questions/41823497/jq-create-field-only-if-it-exists",
        "title": "JQ create field only if it exists"
    },
    {
        "tags": [
            "python",
            "json",
            "subprocess",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1891393,
                    "reputation": 9621,
                    "user_id": 1709364,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/40e026958109464eb03fd70b67fab155?s=256&d=identicon&r=PG",
                    "display_name": "jasonharper",
                    "link": "https://stackoverflow.com/users/1709364/jasonharper"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1485378897,
                "post_id": 41861503,
                "comment_id": 70907251,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 8439264,
                    "reputation": 233,
                    "user_id": 6332399,
                    "user_type": "registered",
                    "accept_rate": 85,
                    "profile_image": "https://www.gravatar.com/avatar/86ae5a313e6bd3ad41a629687f3af437?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "j doe",
                    "link": "https://stackoverflow.com/users/6332399/j-doe"
                },
                "reply_to_user": {
                    "account_id": 1891393,
                    "reputation": 9621,
                    "user_id": 1709364,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/40e026958109464eb03fd70b67fab155?s=256&d=identicon&r=PG",
                    "display_name": "jasonharper",
                    "link": "https://stackoverflow.com/users/1709364/jasonharper"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1485379024,
                "post_id": 41861503,
                "comment_id": 70907326,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1485380197,
                "post_id": 41861503,
                "comment_id": 70907932,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "user_type": "does_not_exist",
                    "display_name": "user554546"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1485541253,
                "post_id": 41861503,
                "comment_id": 70983388,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 8439264,
                    "reputation": 233,
                    "user_id": 6332399,
                    "user_type": "registered",
                    "accept_rate": 85,
                    "profile_image": "https://www.gravatar.com/avatar/86ae5a313e6bd3ad41a629687f3af437?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "j doe",
                    "link": "https://stackoverflow.com/users/6332399/j-doe"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1485541371,
                "post_id": 41861503,
                "comment_id": 70983442,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "user_type": "does_not_exist",
                    "display_name": "user554546"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1485541796,
                "post_id": 41861503,
                "comment_id": 70983657,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1485380140,
                "creation_date": 1485380140,
                "answer_id": 41862080,
                "question_id": 41861503,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Open the output file yourself, and you won&#39;t need to rely on shell behavior (which is, obviously, not working in the present case) to do it for you.\r\n\r\n    subprocess.call([&#39;jq&#39;, &#39;.[]&#39;, &#39;data.txt&#39;],\r\n      cwd=r&#39;C:/Users/john/Desktop/swag&#39;,\r\n      stdout=open(&#39;C:/Users/john/Desktop/swag/newfile.json&#39;, &#39;w&#39;))\r\n",
                "title": "JQ command not working in python"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1485380140,
        "creation_date": 1485377816,
        "last_edit_date": 1485379675,
        "question_id": 41861503,
        "body_markdown": "So I have a jq command that converts my json array into a json object. The command works normally in the windows terminal, but when I try to implement it into my python program i get this: jq: error: \r\n     \r\n    Could not open file &gt;newfile.json: Invalid argument.\r\nHere is my jq command which works and puts the transformed json into newfile.json:\r\n              \r\n    jq &quot;.[]&quot; data.txt &gt;newfile.json\r\n\r\nHere is my subprocess call in my python program:\r\n\r\n     subprocess.call(&#39;jq &quot;.[]&quot; data.txt &gt;newfile.json&#39;, cwd=r&#39;C:/Users/john/Desktop/swag&#39;, shell=True)\r\n\r\n",
        "link": "https://stackoverflow.com/questions/41861503/jq-command-not-working-in-python",
        "title": "JQ command not working in python"
    },
    {
        "tags": [
            "environment-variables",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1485424821,
                "creation_date": 1485424821,
                "answer_id": 41870900,
                "question_id": 41868687,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You don&#39;t need to use `jq` here if you use environment variables and substitute them with [`envsubst`][1] like this :\r\n\r\n    export number=3000\r\n    envsubst &lt; test.json\r\n\r\n  [1]: https://www.gnu.org/software/gettext/manual/html_node/envsubst-Invocation.html",
                "title": "How to pass a variable to jq when the json is in a file?"
            },
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1485508132,
                "last_edit_date": 1485508132,
                "creation_date": 1485429239,
                "answer_id": 41872247,
                "question_id": 41868687,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Like this:\r\n\r\n    # That&#39;s not json, it&#39;s a .jq file\r\n    cat test.jq\r\n    {&quot;number&quot;:$number}\r\n\r\n    jq -n --arg number 3000 -f test.jq\r\n    {\r\n      &quot;number&quot;: &quot;3000&quot;\r\n    }\r\n\r\n---\r\n\r\nBtw, the above example gives you `&quot;3000&quot;` as a *string*. If you want it to be a number you need to use `--argjson`:\r\n\r\n    jq -n --argjson number 3000 -f test.jq\r\n    {\r\n      &quot;number&quot;: 3000\r\n    }\r\n\r\nor as a string\r\n\r\n    jq -n --argjson number &#39;&quot;3000&quot;&#39; -f test.jq\r\n    {\r\n      &quot;number&quot;: &quot;3000&quot;\r\n    }",
                "title": "How to pass a variable to jq when the json is in a file?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1485521528,
        "creation_date": 1485416018,
        "last_edit_date": 1485521528,
        "question_id": 41868687,
        "body_markdown": "I&#39;m trying to recreate [this SO question](https://stackoverflow.com/questions/30991616/replace-jq-predefined-variable-with-number) but with storing the json in a file instead of passing the string on the command line. Here&#39;s what I&#39;m doing:\r\n\r\n\r\n    $ cat test.json \r\n    {&quot;number&quot;:$number}\r\n\r\n    $ jq --arg number 3000 test.json \r\n    jq: error: test/0 is not defined at &lt;top-level&gt;, line 1:\r\n    test.json\r\n    jq: 1 compile error\r\n\r\n\r\nWhat am I doing wrong?",
        "link": "https://stackoverflow.com/questions/41868687/how-to-pass-a-variable-to-jq-when-the-json-is-in-a-file",
        "title": "How to pass a variable to jq when the json is in a file?"
    },
    {
        "tags": [
            "json",
            "bash",
            "csv",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1852014,
                    "reputation": 24882,
                    "user_id": 1678362,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/8ba023d18099cde022b9e4394d5714c0?s=256&d=identicon&r=PG",
                    "display_name": "Aaron",
                    "link": "https://stackoverflow.com/users/1678362/aaron"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1485446842,
                "post_id": 41877739,
                "comment_id": 70937623,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1485447681,
                "creation_date": 1485447681,
                "answer_id": 41878117,
                "question_id": 41877739,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You can use the `+=` operator, once you have extracted the correct fields from the CSV file. I don&#39;t recommend using `bash` for that, but as long as you don&#39;t have any quoted commas in field values, you can get away with a simple `while` loop.\r\n\r\n    {\r\n        read   # Skip the header\r\n        while IFS=, read -r id name slug; do\r\n            jq --args id &quot;$id&quot; \\\r\n               --args name &quot;$name&quot; \\\r\n               --args slug &quot;$slug&quot; \\\r\n               &#39;features[0].properties += {id: $id, name: $name, slug: $slug}&#39; &quot;$name.json&quot; &gt; tmp &amp;&amp; mv tmp &quot;$name.json&quot;\r\n        done\r\n    } &lt; ids.csv",
                "title": "Add JSON Pair to JSON File Based on CSV"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1485447681,
        "creation_date": 1485446642,
        "question_id": 41877739,
        "body_markdown": "I have a csv, ids.csv, in this format:\r\n\r\n    id,name,slug\r\n    12345,Case A,case-a-12345\r\n    12824,Case B,case-b-12824\r\n\r\nand a bunch of json files in a folder that match a name in the csv, like Case A.json, in this format:\r\n\r\n    {\r\n      &quot;type&quot;: &quot;mass&quot;\r\n      &quot;features&quot;: [\r\n      {\r\n          &quot;type&quot;: &quot;sub&quot;,\r\n          &quot;properties&quot;: {\r\n            &quot;key1&quot;: &quot;value1&quot;,\r\n            &quot;key2&quot;: &quot;value2&quot;\r\n          }\r\n        }\r\n      ]\r\n    }\r\n\r\nand I want to match the name in the csv to the name of the json file and add in the id, name, and slug to the properties so I get this:\r\n\r\n    {\r\n      &quot;type&quot;: &quot;mass&quot;\r\n      &quot;features&quot;: [\r\n      {\r\n          &quot;type&quot;: &quot;sub&quot;,\r\n          &quot;properties&quot;: {\r\n            &quot;key1&quot;: &quot;value1&quot;,\r\n            &quot;key2&quot;: &quot;value2&quot;,\r\n            &quot;id&quot;: &quot;12345&quot;,\r\n            &quot;name&quot;: &quot;Case A&quot;,\r\n            &quot;slug&quot;: &quot;case-a-12345\r\n\r\n          }\r\n        }\r\n      ]\r\n    }\r\n\r\nSo far I only know how to add values using jq like such:\r\n\r\n    jq &#39;.features[0].properties | .key3=&quot;value3&quot;&#39;\r\n\r\nHow do I go about extracting my value from a csv, matching it with the right json file, and applying it to all my json files?\r\n\r\n\r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/41877739/add-json-pair-to-json-file-based-on-csv",
        "title": "Add JSON Pair to JSON File Based on CSV"
    },
    {
        "tags": [
            "amazon-redshift",
            "jq",
            "inspec"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3959308,
                    "reputation": 53394,
                    "user_id": 3266847,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/U0oyt.png?s=256",
                    "display_name": "Benjamin W.",
                    "link": "https://stackoverflow.com/users/3266847/benjamin-w"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1485529056,
                "post_id": 41896618,
                "comment_id": 70975802,
                "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": 1485542858,
                "post_id": 41896618,
                "comment_id": 70984174,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 6732592,
                    "reputation": 21,
                    "user_id": 5188385,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/0302995bb562be3a99f9a386e22871d5?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "user5188385",
                    "link": "https://stackoverflow.com/users/5188385/user5188385"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1485861476,
                "post_id": 41896618,
                "comment_id": 71091095,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1487281743,
                "creation_date": 1487281743,
                "answer_id": 42285319,
                "question_id": 41896618,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here&#39;s a `jq` filter to flatten this out. Note that the &quot;piping&quot; between filters is **essential**. You must flatten each parent array before you flatten it&#39;s child or you get a cartesian product of them all (which is _very_ bad). \r\n\r\n    jq &#39;.profiles[] \r\n         | { Name: .name , Controls: .controls[] } \r\n         | { Name: .Name, Desc: .Controls.desc , Title: .Controls.title , Results: .Controls.results[] } \r\n         | { Name: .Name, Desc: .Desc , Title: .Title , StartTime: .Results.start_time , RunTime: .Results.run_time , Result: .Results.status }&#39;\r\n\r\n*Line breaks added to the code for clarity*\r\n\r\nOutput: \r\n\r\n    {\r\n      &quot;Name&quot;: &quot;java&quot;,\r\n      &quot;Desc&quot;: &quot;identify java in PATH system&quot;,\r\n      &quot;Title&quot;: &quot;identify java in system&quot;,\r\n      &quot;StartTime&quot;: &quot;2017-01-20 05:04:47 +0000&quot;,\r\n      &quot;RunTime&quot;: 0.000895896,\r\n      &quot;Result&quot;: &quot;passed&quot;\r\n    }\r\n    …etc\r\n\r\nOnce you&#39;ve flattened it this far I would consider saving it as CSV instead as that will be somewhat simpler to load into Redshift.\r\n\r\n     jq &#39;.profiles[] \r\n         | { Name: .name , Controls: .controls[] } \r\n         | { Name: .Name, Desc: .Controls.desc , Title: .Controls.title , Results: .Controls.results[] } \r\n         | [ .Name, .Desc , .Title , .Results.start_time , .Results.run_time , .Results.status ] \r\n         | @csv &#39;\r\n\r\nOutput: \r\n\r\n    &quot;\\&quot;java\\&quot;,\\&quot;identify java in PATH system\\&quot;,\\&quot;identify java in system\\&quot;,\\&quot;2017-01-20 05:04:47 +0000\\&quot;,0.000895896,\\&quot;passed\\&quot;&quot;\r\n    …etc\r\n   ",
                "title": "How to get a simple JSON data file from a complex JSON file using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1487281743,
        "creation_date": 1485528384,
        "last_edit_date": 1485528986,
        "question_id": 41896618,
        "body_markdown": "I have a complex json file, nested to 4th and 5th levels and I am trying to get the below result using jq. Any help would be appreciated:\r\n\r\n\r\n    {\r\n      &quot;Name&quot;: &quot;unix-global&quot;,\r\n      &quot;Title&quot;: &quot;AWS cli should be installed&quot;,\r\n      &quot;desc&quot;: &quot;System Package aws-cli should be installed&quot;,\r\n      &quot;result&quot;: &quot;passed&quot;\r\n    } \r\n    {\r\n      &quot;Name&quot;: &quot;unix-global&quot;,\r\n      &quot;Title&quot;: &quot;AWS cli should be installed&quot;,\r\n      &quot;desc&quot;: &quot;Service besclient should be installed&quot;,\r\n      &quot;result&quot;: &quot;failed&quot;\r\n    }\r\n\r\n\r\nThis is a json file that i get as a result of running an inspec profile. The real aim is to extract the only needed info into a simple json so that I can finally update a AWS Redshift database.\r\n\r\n    {\r\n      &quot;version&quot;: &quot;1.7.1&quot;,\r\n      &quot;profiles&quot;: [{\r\n        &quot;name&quot;: &quot;java&quot;,\r\n        &quot;title&quot;: &quot;InSpec Java in system&quot;,\r\n        &quot;maintainer&quot;: &quot;awim&quot;,\r\n        &quot;copyright&quot;: &quot;awim / mtaqwim&quot;,\r\n        &quot;copyright_email&quot;: &quot;muhammadtaqwiem@gmail.com&quot;,\r\n        &quot;license&quot;: &quot;All Rights Reserved&quot;,\r\n        &quot;summary&quot;: &quot;An InSpec Compliance Profile&quot;,\r\n        &quot;version&quot;: &quot;0.0.1&quot;,\r\n        &quot;supports&quot;: [],\r\n        &quot;controls&quot;: [{\r\n          &quot;title&quot;: &quot;identify java in system&quot;,\r\n          &quot;desc&quot;: &quot;identify java in PATH system&quot;,\r\n          &quot;impact&quot;: 0.3,\r\n          &quot;refs&quot;: [],\r\n          &quot;tags&quot;: {},\r\n          &quot;code&quot;: &quot;control &#39;java-1.0&#39; do\\n  impact 0.3\\n  title &#39;identify java in system&#39;\\n  desc &#39;identify java in PATH system&#39;\\n\\n  describe java_info do\\n    it{ should exist }\\n    its(:version){ should match &#39;1.7&#39;}\\n  end\\nend&quot;,\r\n          &quot;source_location&quot;: {\r\n            &quot;ref&quot;: &quot;inspec/java/controls/java_1.0.rb&quot;,\r\n            &quot;line&quot;: 6\r\n          },\r\n          &quot;id&quot;: &quot;java-1.0&quot;,\r\n          &quot;results&quot;: [{\r\n            &quot;status&quot;: &quot;passed&quot;,\r\n            &quot;code_desc&quot;: &quot;java_info should exist&quot;,\r\n            &quot;run_time&quot;: 0.000895896,\r\n            &quot;start_time&quot;: &quot;2017-01-20 05:04:47 +0000&quot;\r\n          }, {\r\n            &quot;status&quot;: &quot;passed&quot;,\r\n            &quot;code_desc&quot;: &quot;java_info version should match \\&quot;1.7\\&quot;&quot;,\r\n            &quot;run_time&quot;: 0.067581113,\r\n            &quot;start_time&quot;: &quot;2017-01-20 05:04:47 +0000&quot;\r\n          }]\r\n        }, {\r\n          &quot;title&quot;: &quot;run java from specific path&quot;,\r\n          &quot;desc&quot;: &quot;run java from specific path&quot;,\r\n          &quot;impact&quot;: 1.0,\r\n          &quot;refs&quot;: [],\r\n          &quot;tags&quot;: {},\r\n          &quot;code&quot;: &quot;control &#39;java-2.0&#39; do\\n  impact 1.0\\n  title &#39;run java from specific path&#39;\\n  desc &#39;run java from specific path&#39;\\n\\n  describe java_info(java_path) do\\n    it{ should exist }\\n    its(:version){ should match &#39;1.7&#39;}\\n  end\\nend&quot;,\r\n          &quot;source_location&quot;: {\r\n            &quot;ref&quot;: &quot;inspec/java/controls/java_2.0.rb&quot;,\r\n            &quot;line&quot;: 8\r\n          },\r\n          &quot;id&quot;: &quot;java-2.0&quot;,\r\n          &quot;results&quot;: [{\r\n            &quot;status&quot;: &quot;skipped&quot;,\r\n            &quot;code_desc&quot;: &quot;java_info&quot;,\r\n            &quot;skip_message&quot;: &quot;Can&#39;t find file \\&quot;/opt/jdk/current\\&quot;&quot;,\r\n            &quot;resource&quot;: &quot;java_info&quot;,\r\n            &quot;run_time&quot;: 1.6512e-05,\r\n            &quot;start_time&quot;: &quot;2017-01-20 05:04:47 +0000&quot;\r\n          }]\r\n        }, {\r\n          &quot;title&quot;: &quot;identify java home&quot;,\r\n          &quot;desc&quot;: &quot;identify java home match to specific path&quot;,\r\n          &quot;impact&quot;: 0.1,\r\n          &quot;refs&quot;: [],\r\n          &quot;tags&quot;: {},\r\n          &quot;code&quot;: &quot;control &#39;java-3.0&#39; do\\n  impact 0.1\\n  title &#39;identify java home&#39;\\n  desc &#39;identify java home match to specific path&#39;\\n\\n  describe java_info(java_path) do\\n    its(:java_home){ should match java_path}\\n  end\\nend&quot;,\r\n          &quot;source_location&quot;: {\r\n            &quot;ref&quot;: &quot;inspec/java/controls/java_3.0.rb&quot;,\r\n            &quot;line&quot;: 8\r\n          },\r\n          &quot;id&quot;: &quot;java-3.0&quot;,\r\n          &quot;results&quot;: [{\r\n            &quot;status&quot;: &quot;skipped&quot;,\r\n            &quot;code_desc&quot;: &quot;java_info&quot;,\r\n            &quot;skip_message&quot;: &quot;Can&#39;t find file \\&quot;/opt/jdk/current\\&quot;&quot;,\r\n            &quot;resource&quot;: &quot;java_info&quot;,\r\n            &quot;run_time&quot;: 6.139e-06,\r\n            &quot;start_time&quot;: &quot;2017-01-20 05:04:47 +0000&quot;\r\n          }]\r\n        }],\r\n        &quot;groups&quot;: [{\r\n          &quot;title&quot;: &quot;which(UNIX)/where(Windows) java installed&quot;,\r\n          &quot;controls&quot;: [&quot;java-1.0&quot;],\r\n          &quot;id&quot;: &quot;controls/java_1.0.rb&quot;\r\n        }, {\r\n          &quot;title&quot;: &quot;which(UNIX)/where(Windows) java installed&quot;,\r\n          &quot;controls&quot;: [&quot;java-2.0&quot;],\r\n          &quot;id&quot;: &quot;controls/java_2.0.rb&quot;\r\n        }, {\r\n          &quot;title&quot;: &quot;which(UNIX)/where(Windows) java installed&quot;,\r\n          &quot;controls&quot;: [&quot;java-3.0&quot;],\r\n          &quot;id&quot;: &quot;controls/java_3.0.rb&quot;\r\n        }],\r\n        &quot;attributes&quot;: []\r\n      }],\r\n      &quot;other_checks&quot;: [],\r\n      &quot;statistics&quot;: {\r\n        &quot;duration&quot;: 0.069669698\r\n      }\r\n    }\r\n\r\n",
        "link": "https://stackoverflow.com/questions/41896618/how-to-get-a-simple-json-data-file-from-a-complex-json-file-using-jq",
        "title": "How to get a simple JSON data file from a complex JSON file using jq"
    },
    {
        "tags": [
            "json",
            "dictionary",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1852014,
                    "reputation": 24882,
                    "user_id": 1678362,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/8ba023d18099cde022b9e4394d5714c0?s=256&d=identicon&r=PG",
                    "display_name": "Aaron",
                    "link": "https://stackoverflow.com/users/1678362/aaron"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1485530336,
                "post_id": 41896783,
                "comment_id": 70976761,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1485542418,
                "creation_date": 1485542418,
                "answer_id": 41900865,
                "question_id": 41896783,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Yes. You could use the --slurpfile option but your dictionary is already a single JSON entity (a JSON object in your case), so it would be simpler to read the dictionary using the --argfile option.\r\n\r\nAssuming that:\r\n\r\n* your jq filter is in a file, say `merge.jq`;\r\n* your dictionary is in dictionary.json;\r\n* your input stream is in input.json\r\n\r\nthe jq invocation would look like this:\r\n\r\n    jq -f merge.jq --argfile dict dictionary.json input.json\r\n\r\nWith the above, you would of course refer to the dictionary as $dict in merge.jq\r\n\r\n(Of course you could specify the filter on the jq command line, if that&#39;s what you prefer.)\r\n\r\nNow, over to you!\r\n\r\n ",
                "title": "is it possible to use jq to replace a value in one json file from a another dictionary json file?"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1485542465,
                "creation_date": 1485542465,
                "answer_id": 41900883,
                "question_id": 41896783,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Sure. You might want to transform your first file in an easier to consume format first: map the `.type` to the `.field` properties to an object (to use as a dictionary)\r\n\r\n    reduce .[] as $i ({}; .[$i.field] = $i.type)\r\n\r\nThen you could go through your second file to use these mappings to update the values.  Use `--argfile` to read the contents of the first file into a variable.\r\n\r\n    $ jq --argfile file1 file1.json &#39;\r\n    (reduce $file1[] as $i ({}; .[$i.field] = $i.type)) as $map\r\n        | with_entries(.value = { ($map[.key]): .value })\r\n    &#39; file2.json\r\n\r\nwhich yields:\r\n\r\n    {\r\n      &quot;col1&quot;: {\r\n        &quot;int&quot;: 123\r\n      },\r\n      &quot;col2&quot;: {\r\n        &quot;string&quot;: &quot;foo&quot;\r\n      }\r\n    }\r\n    {\r\n      &quot;col1&quot;: {\r\n        &quot;int&quot;: 123\r\n      },\r\n      &quot;col2&quot;: {\r\n        &quot;string&quot;: &quot;foo&quot;\r\n      }\r\n    }\r\n\r\n",
                "title": "is it possible to use jq to replace a value in one json file from a another dictionary json file?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1485702758,
        "creation_date": 1485528872,
        "last_edit_date": 1485702758,
        "question_id": 41896783,
        "body_markdown": "I have two json file, one contains a map key name and a type, the other is a flat json file.\r\n\r\neg. first file contains something like this:\r\n\r\n    [ { &quot;field&quot;: &quot;col1&quot;, &quot;type&quot;: &quot;int&quot; }, { &quot;field&quot; : &quot;col2&quot;, &quot;type&quot; : &quot;string&quot; }]\r\n\r\nsecond file is a large jsons object file separated by line break:\r\n\r\n    { &quot;col1&quot;:123, &quot;col2&quot;: &quot;foo&quot;}\r\n    { &quot;col1&quot;:123, &quot;col2&quot;: &quot;foo&quot;}\r\n    ...\r\n\r\n\r\n\r\n\r\ncan I use JQ to generate an output json like this:\r\n\r\n    { &quot;col1&quot;:{ &quot;int&quot; : 123 }, &quot;col2&quot;: { &quot;string&quot; : &quot;foo&quot;} }\r\n    { &quot;col1&quot;:{ &quot;int&quot; : 123 }, &quot;col2&quot;: { &quot;string&quot; : &quot;foo&quot;} }\r\n\r\n    ....\r\n\r\n\r\n\r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/41896783/is-it-possible-to-use-jq-to-replace-a-value-in-one-json-file-from-a-another-dict",
        "title": "is it possible to use jq to replace a value in one json file from a another dictionary json file?"
    },
    {
        "tags": [
            "json",
            "linux",
            "bash",
            "ubuntu",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3708106,
                    "reputation": 3393,
                    "user_id": 6165935,
                    "user_type": "registered",
                    "profile_image": "https://lh4.googleusercontent.com/-5SjwIcK5M8I/AAAAAAAAAAI/AAAAAAAAAFQ/xyQQHb_jXoQ/s256-rj/photo.jpg",
                    "display_name": "Michael Vehrs",
                    "link": "https://stackoverflow.com/users/6165935/michael-vehrs"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1485769993,
                "post_id": 41929906,
                "comment_id": 71046167,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1485803469,
                "last_edit_date": 1485803469,
                "creation_date": 1485761299,
                "answer_id": 41930814,
                "question_id": 41929906,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "To tackle both the first question and the main goal, you&#39;ll probably want to define a convenience function, which is here specified according to your one-liner:\r\n\r\n    def convert: strptime(&quot;%Y-%m-%dT%H:%M:%S.%z&quot;) | mktime;\r\n\r\nThe filter to answer the first question could then be written as follows:\r\n\r\n    map( ( .startdate |= convert) | (.enddate |= convert) )\r\n\r\nTo select the objects of interest, you could use the above def with this filter:\r\n\r\n    now as $now\r\n    | map( select((.startdate|convert &gt;= $now) and (.enddate|convert &gt;= $now)))\r\n\r\n\r\nUnfortunately, jq&#39;s current support for time zones is virtually nil, so I&#39;m not sure how you&#39;ll want to convert back to &quot;local time&quot;. With some ingenuity and string manipulation, it could be done in jq, though maybe not in the most general way.\r\n\r\n\r\n",
                "title": "Convert all time stamps in JSON file to unix time stamp in bash(Ubuntu)"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 4,
        "last_activity_date": 1485803469,
        "creation_date": 1485756592,
        "question_id": 41929906,
        "body_markdown": "I am trying to convert all time stamps in a file to the Unix time format preferably using jq/bash/python.\r\n\r\nThe original format is kinda odd:\r\n\r\n    %Y-%m-%dT%H:%M:%S.%z\r\n\r\nThe sample file content from GoToMeeting API:\r\n\r\n    [\r\n      {\r\n        &quot;Last Name&quot;: &quot;John&quot;,\r\n        &quot;Subject&quot;: &quot;Meet Now&quot;,\r\n        &quot;meetingId&quot;: &quot;983329197&quot;,\r\n        &quot;meetingType&quot;: &quot;immediate&quot;,\r\n        &quot;First Name&quot;: &quot;Doe&quot;,\r\n        &quot;Conference Info&quot;: &quot;111-222-333&quot;,\r\n        &quot;startdate&quot;: &quot;2017-01-25T04:50:25.+0000&quot;,\r\n        &quot;enddate&quot;: &quot;2017-01-25T05:50:25.+0000&quot;,\r\n        &quot;status&quot;: &quot;INACTIVE&quot;\r\n      },\r\n      {\r\n        &quot;Last Name&quot;: &quot;John&quot;,\r\n        &quot;Subject&quot;: &quot;dumb meeting&quot;,\r\n        &quot;meetingId&quot;: &quot;569996685&quot;,\r\n        &quot;meetingType&quot;: &quot;scheduled&quot;,\r\n        &quot;First Name&quot;: &quot;Doe&quot;,\r\n        &quot;Conference Info&quot;: &quot;111-222-333&quot;,\r\n        &quot;startdate&quot;: &quot;2017-02-15T10:00:00.+0000&quot;,\r\n        &quot;enddate&quot;: &quot;2017-02-15T10:30:00.+0000&quot;,\r\n        &quot;status&quot;: &quot;INACTIVE&quot;\r\n      }\r\n    ]\r\n\r\nI was able to convert just one single value to Unix by running this:\r\n\r\nInput:\r\n\r\n    jq &#39;strptime(&quot;%Y-%m-%dT%H:%M:%S.%z&quot;) | mktime&#39;;\r\n    &quot;2015-03-05T04:50:25.+0000&quot;\r\n    \r\nOutput:\r\n\r\n    1425531025\r\n\r\n\r\nThe main goal of this is to filter out all dates older than the current time and then convert it to local time.",
        "link": "https://stackoverflow.com/questions/41929906/convert-all-time-stamps-in-json-file-to-unix-time-stamp-in-bashubuntu",
        "title": "Convert all time stamps in JSON file to unix time stamp in bash(Ubuntu)"
    },
    {
        "tags": [
            "arrays",
            "json",
            "indexof",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 30,
                "is_accepted": true,
                "score": 28,
                "last_activity_date": 1486018589,
                "last_edit_date": 1486018589,
                "creation_date": 1485869604,
                "answer_id": 41958933,
                "question_id": 41958475,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "*So I provided a strategy for a solution to the OP, which OP quickly accepted. Subsequently @peak and @Jeff Mercado offered better and more complete solutions.  So I have turned this into a community wiki.  Please improve this answer if you can.*\r\n\r\nA straightforward solution (pointed out by @peak) is to use the builtin function, `index`:\r\n\r\n    map(.name == &quot;something&quot;) | index(true)\r\n\r\nThe `jq` documentation confusingly suggests that `index` operates on strings, but it operates on arrays as well.  Thus `index(true)` returns the index of the first `true` in the array of booleans produced by the map.  If there is no item satisfying the condition, the result is null.\r\n\r\njq expresions are evaluated in a [&quot;lazy&quot; manner](https://github.com/stedolan/jq/wiki/Advanced-Topics#lazy-evaluation), but `map` will traverse the entire input array.  We can verify this by rewriting the above code and introducing some debug statements:\r\n\r\n    [ .[] | debug | .name == &quot;something&quot; ] | index(true)\r\n\r\nAs suggested by @peak, the key to doing better is to use the `break` statement introduced in jq 1.5:\r\n\r\n    label $out | \r\n    foreach .[] as $item (\r\n      -1; \r\n      .+1; \r\n      if $item.name == &quot;something&quot; then \r\n        ., \r\n        break $out \r\n      else \r\n        empty\r\n      end\r\n    ) // null\r\n\r\nNote that the `//` is no comment; it is the alternative operator.  If the name is not found the `foreach` will return `empty` which will be converted to null by the alternative operator.\r\n\r\nAnother approach is to recursively process the array:\r\n\r\n    def get_index(name): \r\n      name as $name | \r\n      if (. == []) then\r\n        null\r\n      elif (.[0].name == $name) then \r\n        0 \r\n      else \r\n        (.[1:] | get_index($name)) as $result |\r\n        if ($result == null) then null else $result+1 end      \r\n    end;\r\n    get_index(&quot;something&quot;)\r\n\r\nHowever this recursive implementation will use stack space proportional to the length of the array in the worst case as pointed out by @Jeff Mercado.  In version 1.5 `jq` introduced [Tail Call Optimization (TCO)](https://github.com/stedolan/jq/wiki/Advanced-Topics#lazy-evaluationgener) which will allow us to optimize this away using a local helper function (note that this is minor adaptation to a solution provided by @Jeff Mercado so as to be consistent with the above examples):\r\n\r\n    def get_index(name): \r\n      name as $name | \r\n      def _get_index:\r\n        if (.i &gt;= .len) then\r\n          null\r\n        elif (.array[.i].name == $name) then\r\n          .i\r\n        else\r\n          .i += 1 | _get_index\r\n        end;\r\n      { array: ., i: 0, len: length } | _get_index;\r\n    get_index(&quot;something&quot;)\r\n\r\nAccording to @peak obtaining the length of an array in `jq` is a constant time operation, and apparently indexing an array is inexpensive as well.  I will try to find a citation for this.\r\n\r\nNow let&#39;s try to actually measure.  Here is an example of measuring the simple solution:\r\n\r\n    #!/bin/bash\r\n\r\n    jq -n &#39; \r\n\r\n      def get_index(name): \r\n        name as $name |\r\n        map(.name == $name) | index(true)\r\n      ;\r\n\r\n      def gen_input(n):  \r\n        n as $n |\r\n        if ($n == 0) then \r\n          []\r\n        else\r\n          gen_input($n-1) + [ { &quot;name&quot;: $n, &quot;urgent&quot;:false } ]\r\n        end\r\n      ;  \r\n\r\n      2000 as $n |\r\n      gen_input($n) as $i |\r\n      [(0 | while (.&lt;$n; [ ($i | get_index(.)), .+1 ][1]))][$n-1]\r\n    &#39;\r\n\r\nWhen I run this on my machine, I get the following:\r\n\r\n    $ time ./simple\r\n    1999\r\n\r\n    real\t0m10.024s\r\n    user\t0m10.023s\r\n    sys\t    0m0.008s\r\n\r\nIf I replace this with the &quot;fast&quot; version of get_index:\r\n\r\n    def get_index(name): \r\n      name as $name |\r\n      label $out | \r\n      foreach .[] as $item (\r\n        -1; \r\n        .+1; \r\n      if $item.name == $name then \r\n        ., \r\n        break $out \r\n      else \r\n        empty\r\n      end\r\n    ) // null;\r\n\r\nThen I get:\r\n\r\n    $ time ./fast\r\n    1999\r\n\r\n    real\t0m13.165s\r\n    user\t0m13.173s\r\n    sys\t    0m0.000s\r\n\r\nAnd if I replace it with the &quot;fast&quot; recursive version:\r\n\r\n    def get_index(name): \r\n      name as $name | \r\n      def _get_index:\r\n        if (.i &gt;= .len) then\r\n          null\r\n        elif (.array[.i].name == $name) then\r\n          .i\r\n        else\r\n          .i += 1 | _get_index\r\n        end;\r\n      { array: ., i: 0, len: length } | _get_index;\r\n\r\nI get:\r\n\r\n    $ time ./fast-recursive \r\n    1999\r\n\r\n    real\t0m52.628s\r\n    user\t0m52.657s\r\n    sys \t0m0.005s\r\n\r\nOuch!  But we can do better.  @peak mentioned an undocumented switch `--debug-dump-disasm` which lets you see how `jq` is compiling your code.  With this you can see that modifying and passing the object to `_indexof` and then extracting the array, length, and index is expensive.  Refactoring to just pass the index is a *huge* improvement, and a further refinement to avoid testing the index against the length makes it competitive with the iterative version:\r\n\r\n    def indexof($name):\r\n      (.+[{name: $name}]) as $a | # add a &quot;sentinel&quot;\r\n      length as $l | # note length sees original array\r\n      def _indexof:\r\n        if ($a[.].name == $name) then\r\n          if (. != $l) then . else null end\r\n        else\r\n          .+1 | _indexof\r\n        end\r\n      ;\r\n\r\n\r\n      0 | _indexof\r\n    ;\r\n\r\nI get:\r\n\r\n    $ time ./fast-recursive2\r\n    null\r\n\r\n    real\t0m13.238s\r\n    user\t0m13.243s\r\n    sys  \t0m0.005s\r\n\r\nSo it appears that if each element is equally likely, and you want an average case performance, you should stick with the simple implementation. (C-coded functions tend to be fast!)\r\n",
                "title": "Getting the object array index in jq"
            },
            {
                "up_vote_count": 13,
                "is_accepted": false,
                "score": 13,
                "last_activity_date": 1485927739,
                "last_edit_date": 1485927739,
                "creation_date": 1485882789,
                "answer_id": 41963541,
                "question_id": 41958475,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The solution originally proposed by @Jim-D using foreach would only work as intended for arrays of JSON objects, and both the originally proposed solutions are very inefficient.  Their behavior in the absence of an item satisfying the condition might also have been surprising.\r\n\r\n### Solution using `index/1`\r\n\r\nIf you just want a quick-and-easy solution, you can use the builtin function, `index`, as follows:\r\n\r\n    map(.name == &quot;something&quot;) | index(true)\r\n\r\nIf there is no item satisfying the condition, then the result will be `null`.\r\n\r\nIncidentally, if you wanted ALL indices for which the condition is true, then the above is easily transformed into a super-fast solution by simply changing `index` to `indices`:\r\n\r\n    map(.name == &quot;something&quot;) | indices(true)\r\n\r\n\r\n### Efficient solution\r\nHere is a generic and efficient function that returns the index (i.e. offset) of the first occurrence of the item in the input array for which (item|f) is truthy (neither null nor false), and `null` otherwise.  (In jq, javascript, and many others, the index into arrays is always 0-based.)\r\n\r\n    # 0-based index of item in input array such that f is truthy, else null\r\n    def which(f):\r\n      label $out\r\n      | foreach .[] as $x (-1; .+1; if ($x|f) then ., break $out else empty end)\r\n      // null ;\r\n\r\nExample usage:\r\n\r\n    which(.name == &quot;something&quot;)\r\n\r\n",
                "title": "Getting the object array index in jq"
            },
            {
                "up_vote_count": 5,
                "is_accepted": false,
                "score": 5,
                "last_activity_date": 1486265782,
                "last_edit_date": 1486265782,
                "creation_date": 1485883059,
                "answer_id": 41963623,
                "question_id": 41958475,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Converting an array to entries will give you access to both the index and value in the array of the items.  You could use that to then find the value you&#39;re looking for and get its index.\r\n\r\n    def indexof(predicate):\r\n        reduce to_entries[] as $i (null;\r\n            if (. == null) and ($i.value | predicate) then\r\n                $i.key\r\n            else\r\n                .\r\n            end\r\n        );\r\n    indexof(.name == &quot;something&quot;)\r\n\r\nThis however does not short circuit and will go through the entire array to find the index.  You&#39;ll want to return as soon as the first index has been found.  Taking a more functional approach might be more appropriate.\r\n\r\n    def indexof(predicate):\r\n        def _indexof:\r\n            if .i &gt;= .len then\r\n                null\r\n            elif (.arr[.i] | predicate) then\r\n                .i\r\n            else\r\n                .i += 1 | _indexof\r\n            end;\r\n        { arr: ., i: 0, len: length } | _indexof;\r\n    indexof(.name == &quot;something&quot;)\r\n\r\nNote that the arguments are passed in to the inner function in this way to take advantage of [some optimizations](https://github.com/stedolan/jq/wiki/Advanced%20Topics#recursion-and-tail-recursion-optimization).  Namely to take advantage of TCO, the function must not accept any additional parameters.\r\n\r\nA still faster version can be obtained by recognizing that the array and its length do not vary:\r\n\r\n    def indexof(predicate):\r\n      . as $in\r\n      | length as $len\r\n      |  def _indexof:\r\n           if . &gt;= $len then null\r\n           elif ($in[.] | predicate) then .\r\n           else . + 1 | _indexof\r\n           end;\r\n      0 | _indexof;\r\n\r\n",
                "title": "Getting the object array index in jq"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1611830281,
                "creation_date": 1611830281,
                "answer_id": 65935400,
                "question_id": 41958475,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is another version which seems to be slightly faster than the optimized versions from @peak and @jeff-mercado:\r\n```\r\nlabel $out | . as $elements | range(length) |\r\nselect($elements[.].name == &quot;something&quot;) | . , break $out\r\n```\r\n\r\nIMO it is easier to read although it still relies on the `break` (to get the first match only).\r\n\r\nI was doing 100 iterations on a ~1,000,000 element array (with the last element being the one to match). I only counted the user and kernel times, not the wall clock time. On average this solution took 3.4s, @peak&#39;s solution took 3.5s, and @jeff-mercado&#39;s took 3.6s. This matched what I was seeing in one off runs although to be fair I did have a run where this solution to 3.6s on average so there is unlikely to be any statistical significant difference between each solution.",
                "title": "Getting the object array index in jq"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": 29,
        "last_activity_date": 1611830281,
        "creation_date": 1485868196,
        "last_edit_date": 1485889008,
        "question_id": 41958475,
        "body_markdown": "I have a json object that looks like this (prodused by `i3-msg -t get_workspaces`.\r\n\r\n    [\r\n      {\r\n        &quot;name&quot;: &quot;1&quot;,\r\n        &quot;urgent&quot;: false\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;2&quot;,\r\n        &quot;urgent&quot;: false\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;something&quot;,\r\n        &quot;urgent&quot;: false\r\n      }\r\n    ]\r\n\r\n\r\nI am trying to use `jq` to figure out which index number in the list is based on a `select` query. `jq` have something called `index()`, but it seams to support only strings?\r\n\r\nUsing something like ` i3-msg -t get_workspaces | jq &#39;.[] | select(.name==&quot;something&quot;)&#39;` gives me the object I want. But I want it&#39;s index. In this case `2` (starting counting at 0)\r\n\r\nIs this possible using `jq` alone?",
        "link": "https://stackoverflow.com/questions/41958475/getting-the-object-array-index-in-jq",
        "title": "Getting the object array index in jq"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1485873651,
                "post_id": 41960261,
                "comment_id": 71099322,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1485880802,
                "last_edit_date": 1485880802,
                "creation_date": 1485873856,
                "answer_id": 41960377,
                "question_id": 41960261,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You can use [`select`](https://stedolan.github.io/jq/manual/#select(boolean_expression)) to restrict the content of the array to objects whose `dockerContainerName` differs from `null` : \r\n\r\n\tjq &#39;.[] | select(.dockerContainerName != null)&#39; &lt;&lt;EOF\r\n\t[\r\n\t  {\r\n\t\t&quot;dockerContainerName&quot;: null,\r\n\t\t&quot;servers&quot;: []\r\n\t  },\r\n\t  {\r\n\t\t&quot;dockerContainerName&quot;: &quot;my_awesome_container&quot;,\r\n\t\t&quot;servers&quot;: [\r\n\t\t  &quot;serverX01&quot;,\r\n\t\t  &quot;serverX02&quot;\r\n\t\t]\r\n      }\r\n\t]\r\n\tEOF\r\n\r\n\t{\r\n\t  &quot;dockerContainerName&quot;: &quot;my_awesome_container&quot;,\r\n\t  &quot;servers&quot;: [\r\n\t\t&quot;serverX01&quot;,\r\n\t\t&quot;serverX02&quot;\r\n\t  ]\r\n\t}\r\n\r\n",
                "title": "JSON Parsing with jq if-then-else issues"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1485880802,
        "creation_date": 1485873540,
        "last_edit_date": 1485873616,
        "question_id": 41960261,
        "body_markdown": "I am writing a script that will parse a JSON file and extract out some docker container names and the servers that they are running on.  I then need to do some other things in bash with the info I get.  I am new to using `jq` but here is what I have gotten so far.\r\n\r\nI run the following:\r\n\r\n    cat env.json | jq &#39;[.env.service.config | .[] | {dockerContainerName:.dockerConfig.dockerImageName,servers:[.allocation[].serverName]}]&#39;\r\n\r\nThis gives me an output of:\r\n\r\n    [\r\n      {\r\n        &quot;dockerContainerName&quot;: null,\r\n        &quot;servers&quot;: []\r\n      },\r\n      {\r\n        &quot;dockerContainerName&quot;: &quot;my_awesome_container&quot;,\r\n        &quot;servers&quot;: [\r\n          &quot;serverX01&quot;,\r\n          &quot;serverX02&quot;\r\n        ]\r\n      },\r\n    ...\r\n    ...\r\n    ]\r\n\r\n\r\nAs you can see from the result some of the service configs do not have a dockerConfig.dockerImageName.  I need to limit what comes back to filter out the ones that do not have a dockerConfig.  I have tried using an if-then-else but can&#39;t seem to get it to work correctly.\r\n\r\nAny ideas out there?\r\n",
        "link": "https://stackoverflow.com/questions/41960261/json-parsing-with-jq-if-then-else-issues",
        "title": "JSON Parsing with jq if-then-else issues"
    },
    {
        "tags": [
            "json",
            "bash",
            "loops",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6469508,
                    "reputation": 758,
                    "user_id": 5010116,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/sIte7.jpg?s=256",
                    "display_name": "Top Sekret",
                    "link": "https://stackoverflow.com/users/5010116/top-sekret"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1485893963,
                "post_id": 41966417,
                "comment_id": 71112194,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 10150150,
                    "reputation": 21,
                    "user_id": 7497034,
                    "user_type": "registered",
                    "profile_image": "https://lh4.googleusercontent.com/-p_xa4bhyZ24/AAAAAAAAAAI/AAAAAAAAAdw/O4xrNCm0Fe4/s256-rj/photo.jpg",
                    "display_name": "Eric Graham",
                    "link": "https://stackoverflow.com/users/7497034/eric-graham"
                },
                "reply_to_user": {
                    "account_id": 6469508,
                    "reputation": 758,
                    "user_id": 5010116,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/sIte7.jpg?s=256",
                    "display_name": "Top Sekret",
                    "link": "https://stackoverflow.com/users/5010116/top-sekret"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1485894149,
                "post_id": 41966417,
                "comment_id": 71112283,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 6469508,
                    "reputation": 758,
                    "user_id": 5010116,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/sIte7.jpg?s=256",
                    "display_name": "Top Sekret",
                    "link": "https://stackoverflow.com/users/5010116/top-sekret"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1485894177,
                "post_id": 41966417,
                "comment_id": 71112297,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 10150150,
                    "reputation": 21,
                    "user_id": 7497034,
                    "user_type": "registered",
                    "profile_image": "https://lh4.googleusercontent.com/-p_xa4bhyZ24/AAAAAAAAAAI/AAAAAAAAAdw/O4xrNCm0Fe4/s256-rj/photo.jpg",
                    "display_name": "Eric Graham",
                    "link": "https://stackoverflow.com/users/7497034/eric-graham"
                },
                "reply_to_user": {
                    "account_id": 6469508,
                    "reputation": 758,
                    "user_id": 5010116,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/sIte7.jpg?s=256",
                    "display_name": "Top Sekret",
                    "link": "https://stackoverflow.com/users/5010116/top-sekret"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1485894275,
                "post_id": 41966417,
                "comment_id": 71112353,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 10150150,
                    "reputation": 21,
                    "user_id": 7497034,
                    "user_type": "registered",
                    "profile_image": "https://lh4.googleusercontent.com/-p_xa4bhyZ24/AAAAAAAAAAI/AAAAAAAAAdw/O4xrNCm0Fe4/s256-rj/photo.jpg",
                    "display_name": "Eric Graham",
                    "link": "https://stackoverflow.com/users/7497034/eric-graham"
                },
                "reply_to_user": {
                    "account_id": 6469508,
                    "reputation": 758,
                    "user_id": 5010116,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/sIte7.jpg?s=256",
                    "display_name": "Top Sekret",
                    "link": "https://stackoverflow.com/users/5010116/top-sekret"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1485894367,
                "post_id": 41966417,
                "comment_id": 71112413,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": -1,
                "last_activity_date": 1485894564,
                "creation_date": 1485894564,
                "answer_id": 41966920,
                "question_id": 41966417,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "First:\r\n\r\n  \tfor i in cat /Users/egraham/Downloads/test2 | jq .[] | jq .value; do echo $i done\r\n\r\nSecond:\r\n\r\n  \tfor i in cat /Users/egraham/Downloads/test2 | jq .[] | jq .addr; do echo $i done\r\n\r\nI don&#39;t know any way to get it without running the commands separately. I don&#39;t know AWK, but maybe it&#39;s something worth considering.",
                "title": "extract 2 values from JSON object and use as variables in loop using jq and bash"
            },
            {
                "up_vote_count": 5,
                "is_accepted": false,
                "score": 5,
                "last_activity_date": 1485896141,
                "creation_date": 1485896141,
                "answer_id": 41967324,
                "question_id": 41966417,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You can do this:\r\n\r\n    jq -rc &#39;.populator.value + &quot; &quot; + .populator.addr&#39; file.json |\r\n    while read -r value addr; do\r\n        echo do something with &quot;$value&quot; and &quot;$addr&quot;\r\n    done\r\n\r\n",
                "title": "extract 2 values from JSON object and use as variables in loop using jq and bash"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1485900140,
                "creation_date": 1485900140,
                "answer_id": 41968313,
                "question_id": 41966417,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "If spaces or tabs or other special characters make using &#39;read -r&#39; problematic, and if your shell has &quot;readarray&quot;, then it could be used:\r\n\r\n    $ readarray -t v &lt; &lt;(jq -rc &#39;.populator | (.value,.addr)&#39; file.json)\r\n\r\nThe values would then be available as ${v[0]} and ${v[1]}\r\n    \r\nThis approach is especially useful if there are more than two values of interest, or if the number of values is variable or not known beforehand.\r\n\r\nIf your shell does not have `readarray`, then you can still use the array-oriented approach, e.g. along the lines of:\r\n\r\n    i=-1; while read -r a ; do i=$((i+1)); v[$i]=&quot;$a&quot; ; done\r\n\r\n\r\n ",
                "title": "extract 2 values from JSON object and use as variables in loop using jq and bash"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1486007814,
        "creation_date": 1485892671,
        "last_edit_date": 1486007814,
        "question_id": 41966417,
        "body_markdown": "I am new to jq. I am trying to write a simple script that loops through a JSON file, gets two values within each object and assigns them to two separate variables I can use with a curl REST call. I see both values as output when I echo $i but how can I get value and addr as separate variables? \r\n\r\n    for i in `cat /Users/egraham/Downloads/test2  | jq .[] | jq .&quot;value,.addr&quot;`; do",
        "link": "https://stackoverflow.com/questions/41966417/extract-2-values-from-json-object-and-use-as-variables-in-loop-using-jq-and-bash",
        "title": "extract 2 values from JSON object and use as variables in loop using jq and bash"
    },
    {
        "tags": [
            "json",
            "shell",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1486018038,
                "last_edit_date": 1495539930,
                "creation_date": 1486017645,
                "answer_id": 41995743,
                "question_id": 41995666,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "`+` does not append elements to arrays. You want to merge arrays using `|= .+ [...] ` as explained in [this answer][1]\r\n\r\n    jq &#39;.firsttag.secondtag[0].thirdtag[0].interestingtag |= .+ [{&quot;refId&quot;: &quot;D&quot;, &quot;refID&quot;: &quot;C&quot;}]&#39; myfile.json\r\n\r\n  [1]: https://stackoverflow.com/questions/25414854/add-json-array-element-with-jq-cmdline",
                "title": "Adding a new array to already existing JSON file jq bash"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1486026959,
        "creation_date": 1486017324,
        "last_edit_date": 1486026959,
        "question_id": 41995666,
        "body_markdown": "Assume I have the following large json\r\n\r\n        {\r\n        &quot;firsttag&quot;: {\r\n        &quot;secondtag&quot;: [\r\n          {\r\n            &quot;thirdtag&quot;: [\r\n              {\r\n                &quot;someothertag&quot;: [\r\n                  {\r\n                    &quot;sample&quot;:&quot;else&quot;\r\n                  },\r\n                  {                    \r\n                    &quot;targetBlank&quot;: true,                    \r\n                  }\r\n                ],            \r\n                &quot;interestingtag&quot;: [\r\n                  {\r\n                    &quot;refId&quot;: &quot;A&quot;,\r\n                    &quot;target&quot;: &quot;abc&quot;,\r\n                  },\r\n                  {\r\n                    &quot;refId&quot;: &quot;B&quot;,\r\n                    &quot;target&quot;: &quot;bbb&quot;,\r\n                  },\r\n                  {\r\n                    &quot;refId&quot;: &quot;C&quot;,\r\n                    &quot;target&quot;: &quot;ccc&quot;,\r\n                  }\r\n                ],                \r\n              },\r\n          },\r\n      &quot;overwrite&quot;: true\r\n    }\r\n\r\nMy JSON might not be syntactically perfect but that&#39;s becuase I&#39;ve edited out some stuff. Now what I want to do is, I want to add another input under `interestingtag` that&#39;s similar to the others. For example, I desire it like\r\n\r\n    &quot;interestingtag&quot;: [\r\n                  {\r\n                    &quot;refId&quot;: &quot;A&quot;,\r\n                    &quot;target&quot;: &quot;abc&quot;\r\n                  },\r\n                  {\r\n                    &quot;refId&quot;: &quot;B&quot;,\r\n                    &quot;target&quot;: &quot;bbb&quot;\r\n                  },\r\n                  {\r\n                    &quot;refId&quot;: &quot;C&quot;,\r\n                    &quot;target&quot;: &quot;ccc&quot;\r\n                  },\r\n                  {\r\n                    &quot;refId&quot;: &quot;D&quot;,\r\n                    &quot;target&quot;: &quot;ddd&quot;\r\n                  }\r\n                ],\r\n\r\nBut I&#39;m not able to figure out how to do it. I can retrieve the right location using\r\n\r\n    jq &#39;.firsttag.secondtag[0].thirdtag[0].interestingtag&#39; myfile.json\r\n\r\nBut when I try the simple\r\n\r\n    jq &#39;.firsttag.secondtag[0].thirdtag[0].interestingtag + {&quot;refId&quot;: &quot;D&quot;, &quot;refID&quot;: &quot;C&quot;}&#39; myfile.json\r\n\r\nI get a \r\n\r\n    jq: error: array and object cannot be added\r\n\r\nAny idea how I can do this? Or what I&#39;m doing wrong?\r\n\r\nThanks for the help.\r\n\r\n",
        "link": "https://stackoverflow.com/questions/41995666/adding-a-new-array-to-already-existing-json-file-jq-bash",
        "title": "Adding a new array to already existing JSON file jq bash"
    },
    {
        "tags": [
            "json",
            "shell",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1486061326,
                "last_edit_date": 1486061326,
                "creation_date": 1486055834,
                "answer_id": 42008393,
                "question_id": 41999706,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "In general, any expression that generates multiple values combined with another expression that generates multiple values will create a cartesian product.\r\n\r\ni.e.,\r\n\r\n    &quot;\\(1,2) \\(3,4)&quot;\r\n\r\ngenerates strings `&quot;1 3&quot;`, `&quot;2 3&quot;`, `&quot;1 4&quot;`, and `&quot;2 4&quot;`.\r\n\r\nYou can do the same given an array of values.  `[]` will take the array and generate a result for each of the items.  So combining these concepts, you could do something like this:\r\n\r\n    $ jq --argjson langs &#39;[&quot;en&quot;,&quot;fr&quot;]&#39; &#39;[(.[]|{x:.a,b}) + {language:$langs[]}]&#39; input.json\r\n\r\nBut this could further be reduced to simply:\r\n\r\n    $ jq --argjson langs &#39;[&quot;en&quot;,&quot;fr&quot;]&#39; &#39;[.[]|{x:.a,b,language:$langs[]}]&#39; input.json\r\n\r\nor\r\n\r\n    $ jq --argjson langs &#39;[&quot;en&quot;,&quot;fr&quot;]&#39; &#39;map({x:.a,b,language:$langs[]})&#39; input.json\r\n",
                "title": "How to make a cartesian product in jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1486061326,
        "creation_date": 1486031238,
        "last_edit_date": 1486033833,
        "question_id": 41999706,
        "body_markdown": "\r\nLet say I have input\r\n\r\n    [  \r\n       {  \r\n          &quot;a&quot;:1,\r\n          &quot;b&quot;:2\r\n       },\r\n       {  \r\n          &quot;a&quot;:3,\r\n          &quot;b&quot;:4\r\n       }\r\n    ]\r\n\r\nand I tried,\r\n\r\n    echo &#39;[{&quot;a&quot;: 1, &quot;b&quot;: 2}, {&quot;a&quot;: 3, &quot;b&quot;: 4}]&#39; | jq &#39;[{x: .[].a, y: .[].b}]&#39;\r\n\r\nand I would like to get\r\n\r\n\r\n    [  \r\n       {  \r\n          &quot;x&quot;:1,\r\n          &quot;b&quot;:2,\r\n          &quot;language&quot;:&quot;en&quot;\r\n       },\r\n       {  \r\n          &quot;x&quot;:1,\r\n          &quot;b&quot;:2,\r\n          &quot;language&quot;:&quot;fr&quot;\r\n       }...\r\n    ]\r\n\r\n\r\nMeaning I need to for all items in array I need output two items, one with added `&quot;lanuage&quot;: &quot;en&quot;` key value pair and one with `&quot;lanuage&quot;: &quot;ru&quot;`\r\n\r\n\r\nEDIT. In case it&#39;s not clear enoug. I need a catesian product of input array of objects `is` with another array `xs`, which would give me pairs `(i, x)`. For each pair I want to output object that have all (key, value) pairs of `i` plus some key (`language` in my case) with with value of `x`.\r\n\r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/41999706/how-to-make-a-cartesian-product-in-jq",
        "title": "How to make a cartesian product in jq?"
    },
    {
        "tags": [
            "arrays",
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 24,
                "is_accepted": false,
                "score": 24,
                "last_activity_date": 1486106631,
                "last_edit_date": 1486106631,
                "creation_date": 1486069556,
                "answer_id": 42012281,
                "question_id": 42011086,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You can merge your files with _add_ (jq 1.3+):\r\n\r\n    jq -s &#39;.[0].list=[.[].list|add]|.[0]&#39; *.json\r\n\r\nor _flatten_ (jq 1.5+):\r\n\r\n    jq -s &#39;.[0].list=([.[].list]|flatten)|.[0]&#39; *.json\r\n\r\n`[.[].list]` - creates an array of all &quot;list&quot; arrays\r\n\r\n     [\r\n      [\r\n        {\r\n          &quot;name&quot;: &quot;Ajay&quot;\r\n        }\r\n      ],\r\n      [\r\n        {\r\n          &quot;name&quot;: &quot;Al&quot;\r\n        }\r\n      ]\r\n    ]\r\n\r\n`[.[].list]|flatten` - _flatten_ it (or `.[].list|add` - _add_ all the arrays together)\r\n\r\n    [\r\n      {\r\n        &quot;name&quot;: &quot;Ajay&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;Al&quot;\r\n      }\r\n    ]\r\n\r\n`.[0].list=([.[].list]|flatten)|.[0]` - replace the first &quot;list&quot; with the merged one, output it.\r\n\r\n    {\r\n      &quot;title&quot;: &quot;NamesBook&quot;,\r\n      &quot;list&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;Ajay&quot;\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;Al&quot;\r\n        }\r\n      ]\r\n    }",
                "title": "Merge Arrays of JSON"
            },
            {
                "up_vote_count": 15,
                "is_accepted": false,
                "score": 15,
                "last_activity_date": 1689224662,
                "last_edit_date": 1689224662,
                "creation_date": 1486074337,
                "answer_id": 42013459,
                "question_id": 42011086,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Assuming every file will have the same `title` and you&#39;re simply combining the `list` contents, you could do this:\r\n\r\n```\r\n$ jq &#39;reduce inputs as $i (.; .list += $i.list)&#39; blahblah.json blueblue.json\r\n```\r\n\r\nThis just takes the first item and adds to its list, the list of all the other inputs.\r\n\r\n----\r\n\r\nSince it appears this question got hijacked to answer a different problem... might as well offer answers to that too...\r\n\r\nGiven a _stream_ of arrays, to combine the contents to a single array, I would write it:\r\n\r\n```\r\n$ jq -n &#39;[inputs[]]&#39; input.json\r\n$ jq &#39;[.[],inputs[]]&#39; input.json\r\n```\r\n\r\nI wouldn&#39;t use slurp (-s) if I don&#39;t need to. Performance difference may be negligible, but is an unnecessary step. Though with larger inputs, you wouldn&#39;t want to use it anyway.\r\n\r\nIn such cases, you&#39;ll want to stream it in and you could filter out the ends of the arrays (the single item arrays).\r\n\r\n```\r\n$ jq --stream -n &#39;[inputs|select(length==2)[1]]&#39; input.json\r\n```",
                "title": "Merge Arrays of JSON"
            },
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1486152641,
                "creation_date": 1486152641,
                "answer_id": 42032275,
                "question_id": 42011086,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The OP did not specify what should happen if there are objects for which .title is not &quot;NamesBook&quot;.  If the intent is to select objects with .title equal to &quot;NamesBook&quot;, one could write:\r\n\r\n    map(select(.title == &quot;NamesBook&quot;))\r\n    | {title: .[0].title, list: map( .list ) | add}\r\n\r\nThis assumes that jq is invoked with the -s option.\r\n\r\nIncidentally, `add` is the way to go here: simple and fast.",
                "title": "Merge Arrays of JSON"
            },
            {
                "up_vote_count": 57,
                "is_accepted": false,
                "score": 57,
                "last_activity_date": 1642637668,
                "last_edit_date": 1642637668,
                "creation_date": 1588949014,
                "answer_id": 61681712,
                "question_id": 42011086,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Let me also provide just what the **title asks for**, because I&#39;m sure a lot of people that stepped on this question look for something simpler.\r\n\r\nAny of the following (added [math2001](https://stackoverflow.com/users/6164984/math2001) and [pmf](https://stackoverflow.com/users/2158479/pmf) answers):\r\n\r\n```bash\r\necho -e &#39;[&quot;a&quot;,&quot;b&quot;]\\n[&quot;c&quot;,&quot;d&quot;]&#39; | jq -s &#39;add&#39;\r\n```\r\n\r\n```bash\r\necho -e &#39;[&quot;a&quot;,&quot;b&quot;]\\n[&quot;c&quot;,&quot;d&quot;]&#39; | jq -s &#39;flatten(1)&#39;\r\n```\r\n\r\n```bash\r\necho -e &#39;[&quot;a&quot;,&quot;b&quot;]\\n[&quot;c&quot;,&quot;d&quot;]&#39; | jq -s &#39;map(.[])&#39;\r\n```\r\n\r\n```bash\r\necho -e &#39;[&quot;a&quot;,&quot;b&quot;]\\n[&quot;c&quot;,&quot;d&quot;]&#39; | jq -s &#39;[.[][]]&#39;\r\n```\r\n\r\n```bash\r\necho -e &#39;[&quot;a&quot;,&quot;b&quot;]\\n[&quot;c&quot;,&quot;d&quot;]&#39; | jq &#39;.[]&#39; | jq -s\r\n```\r\n\r\nresults in:\r\n\r\n&gt; [   \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\nNote: Also any of the above can **apply** to **arrays of objects**.",
                "title": "Merge Arrays of JSON"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": 45,
        "last_activity_date": 1689224662,
        "creation_date": 1486064931,
        "last_edit_date": 1486073960,
        "question_id": 42011086,
        "body_markdown": "So my objective is to merge json files obtain this format:\r\n\r\n    {\r\n      &quot;title&quot;: &quot;NamesBook&quot;,\r\n      &quot;list&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;Ajay&quot;\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;Al&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\nAnd I have files that look like this format:\r\n\r\nblahblah.json\r\n\r\n    {\r\n      &quot;title&quot;: &quot;NamesBook&quot;,\r\n      &quot;list&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;Ajay&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\nblueblue.json\r\n\r\n    {\r\n      &quot;title&quot;: &quot;NamesBook&quot;,\r\n      &quot;list&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;Al&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\nI can store the list array of all my names in a variable with the following:\r\n\r\n    x = jq -s &#39;.[].list&#39; *.json\r\n\r\nAnd then I was planning on appending the variable to an empty array in a file I created, out.json, which looks like this:\r\n\r\n    {\r\n      &quot;type&quot;: &quot;NamesBook&quot;,\r\n      &quot;list&quot;: []\r\n    }\r\n\r\nHowever, when my script runs over the line\r\n\r\n    jq &#39;.list[] += &quot;$x&quot;&#39; out.json&#39;\r\n\r\nIt brings up a jq error:\r\n\r\n&gt; Cannot iterate over null.\r\n\r\nEven when I add a random element, the same error shows up. Tips on how I should proceed? Are there other tools in jq to help achieve merging arrays?",
        "link": "https://stackoverflow.com/questions/42011086/merge-arrays-of-json",
        "title": "Merge Arrays of JSON"
    },
    {
        "tags": [
            "json",
            "regex",
            "key",
            "match",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 44,
                "is_accepted": true,
                "score": 44,
                "last_activity_date": 1486297215,
                "last_edit_date": 1486297215,
                "creation_date": 1486296122,
                "answer_id": 42051804,
                "question_id": 42051601,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Your statement does not work, because you try to feed the data object into match, but match can only work on strings.\r\n\r\nThe following expression will do what you want. The `to_entries` converts the object to an array of keys and values. Then we iterate over this array by using `map` and `select` all entries where the `.key` (now a string) has a `match`. Finally we just print out the value of every element.\r\n\r\n    .data | to_entries | map(select(.key | match(&quot;what a burger&quot;;&quot;i&quot;))) | map(.value)\r\n\r\nHowever, two comments:\r\n\r\n* The `[a,a,3]` is not allowed in JSON, because `a` is not a number.\r\n* It works because the keys ARE actually different, even if only the letter case is not equal. If at least two keys are identical, you will run into problems, because keys should be unique. In fact, `jq` will only output one of the elements then.",
                "title": "Pattern matching field names with jq"
            },
            {
                "up_vote_count": 29,
                "is_accepted": false,
                "score": 29,
                "last_activity_date": 1486380825,
                "last_edit_date": 1486380825,
                "creation_date": 1486326306,
                "answer_id": 42056902,
                "question_id": 42051601,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here&#39;s a slightly briefer alternative:\r\n\r\n    .data | with_entries(select(.key|match(&quot;what a burger&quot;;&quot;i&quot;)))[]\r\n\r\nAfter rectifying the input, and using jq&#39;s -c option, this would produce the two lines:\r\n\r\n    [1,2,3]\r\n    [&quot;a&quot;,&quot;a&quot;,3]\r\n",
                "title": "Pattern matching field names with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 43,
        "last_activity_date": 1575247492,
        "creation_date": 1486294669,
        "last_edit_date": 1575247492,
        "question_id": 42051601,
        "body_markdown": "This is a very basic (probably silly) question but I can&#39;t get it to work...\r\n\r\nI have a JSON file with this structure:\r\n\r\n    {\r\n        &quot;data&quot;: {\r\n            &quot;what a burger&quot;: [1,2,3],\r\n            &quot;wap&quot;: [66],\r\n            &quot;the map&quot;: [11,20],\r\n            &quot;H. Incandenza&quot;: [1,1],\r\n            &quot;What a burger&quot;: [a,a,3]\r\n        }\r\n    }\r\n\r\nI would like to extract the values of the fields within *data* whose &quot;name&quot; matches a certain pattern. For example, I would like to extract all the case-insensitive coincidences of &quot;what a burger&quot; to get\r\n\r\n    [1,2,3],[a,a,3]\r\n\r\nMy guess would be something like\r\n\r\n    jq &#39;.data | match(&quot;what a burger&quot;;&quot;i&quot;)&#39;\r\n\r\nbut this results in\r\n\r\n    jq: error (at &lt;stdin&gt;:9): object ({&quot;what a bu...) cannot be matched, as it is not a string\r\n\r\nCheers.",
        "link": "https://stackoverflow.com/questions/42051601/pattern-matching-field-names-with-jq",
        "title": "Pattern matching field names with jq"
    },
    {
        "tags": [
            "json",
            "shell",
            "sh",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 49492,
                    "reputation": 316217,
                    "user_id": 147356,
                    "user_type": "registered",
                    "accept_rate": 54,
                    "profile_image": "https://www.gravatar.com/avatar/b9506717d24256a090524dd5505d3207?s=256&d=identicon&r=PG",
                    "display_name": "larsks",
                    "link": "https://stackoverflow.com/users/147356/larsks"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1486472349,
                "post_id": 42090354,
                "comment_id": 71350996,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 8527615,
                    "reputation": 95,
                    "user_id": 6405323,
                    "user_type": "registered",
                    "accept_rate": 85,
                    "profile_image": "https://www.gravatar.com/avatar/914a1a5d76605590b075821c047f29e2?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Daniel",
                    "link": "https://stackoverflow.com/users/6405323/daniel"
                },
                "reply_to_user": {
                    "account_id": 49492,
                    "reputation": 316217,
                    "user_id": 147356,
                    "user_type": "registered",
                    "accept_rate": 54,
                    "profile_image": "https://www.gravatar.com/avatar/b9506717d24256a090524dd5505d3207?s=256&d=identicon&r=PG",
                    "display_name": "larsks",
                    "link": "https://stackoverflow.com/users/147356/larsks"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1486475789,
                "post_id": 42090354,
                "comment_id": 71353516,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 8527615,
                    "reputation": 95,
                    "user_id": 6405323,
                    "user_type": "registered",
                    "accept_rate": 85,
                    "profile_image": "https://www.gravatar.com/avatar/914a1a5d76605590b075821c047f29e2?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Daniel",
                    "link": "https://stackoverflow.com/users/6405323/daniel"
                },
                "reply_to_user": {
                    "account_id": 49492,
                    "reputation": 316217,
                    "user_id": 147356,
                    "user_type": "registered",
                    "accept_rate": 54,
                    "profile_image": "https://www.gravatar.com/avatar/b9506717d24256a090524dd5505d3207?s=256&d=identicon&r=PG",
                    "display_name": "larsks",
                    "link": "https://stackoverflow.com/users/147356/larsks"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1486489664,
                "post_id": 42090354,
                "comment_id": 71363599,
                "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": 1486489807,
                "post_id": 42090354,
                "comment_id": 71363672,
                "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": 1486489868,
                "post_id": 42090354,
                "comment_id": 71363717,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1486497074,
                "last_edit_date": 1486497074,
                "creation_date": 1486483329,
                "answer_id": 42094469,
                "question_id": 42090354,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The key to success here is simplicity. Just one invocation of jq:\r\n\r\n    jq  &#39;.objects[] | select(.conference==&quot;JOG1_VMR6&quot;) | .connect_time&#39;\r\n\r\nAll those `grep` invocations could also be greatly simplified, or eliminated altogether -- consider, for example:\r\n\r\n    jq -n -r &#39;&quot;2017-01-26T19:20:01.096940&quot; | sub(&quot;.*T(?&lt;t&gt;..:..:..).*&quot;; .t)&#39;\r\n    19:20:01 \r\n\r\nor just:\r\n\r\n    jq -n -r &#39;&quot;2017-01-26T19:20:01.096940&quot; | .[11:19]&#39;\r\n    19:20:01 \r\n",
                "title": "Shell Script more complex jq select"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1486497074,
        "creation_date": 1486471819,
        "last_edit_date": 1486489641,
        "question_id": 42090354,
        "body_markdown": "I just like to find a way to search with jq with a shellscript, let explain it better:\r\n\r\nI have this json file:\r\n\r\n       {\r\n          &quot;meta&quot;: {\r\n            &quot;limit&quot;: 200,\r\n            &quot;next&quot;: null,\r\n            &quot;offset&quot;: 0,\r\n            &quot;previous&quot;: null,\r\n            &quot;total_count&quot;: 2\r\n          },\r\n          &quot;objects&quot;: [\r\n            {\r\n              &quot;bandwidth&quot;: 768,\r\n              &quot;call_direction&quot;: &quot;in&quot;,\r\n              &quot;call_uuid&quot;: &quot;84e6098a-d0a9-44ed-846e-074b6d563cfb&quot;,\r\n              &quot;conference&quot;: &quot;JOG1_VMR6&quot;,\r\n              &quot;connect_time&quot;: &quot;2017-01-26T19:20:01.096940&quot;,\r\n              &quot;destination_alias&quot;: &quot;9892@192.168.20.11&quot;,\r\n              &quot;display_name&quot;: &quot;JG - Sala 2&quot;,\r\n              &quot;encryption&quot;: &quot;On&quot;,\r\n              &quot;has_media&quot;: true,\r\n              &quot;id&quot;: &quot;92dab287-0091-4d57-bdff-f37cce6c586e&quot;,\r\n              &quot;is_muted&quot;: false,\r\n              &quot;is_on_hold&quot;: false,\r\n              &quot;is_presentation_supported&quot;: true,\r\n              &quot;is_presenting&quot;: false,\r\n              &quot;is_streaming&quot;: false,\r\n              &quot;license_count&quot;: 1,\r\n              &quot;license_type&quot;: &quot;port&quot;,\r\n              &quot;media_node&quot;: &quot;192.168.20.11&quot;,\r\n              &quot;parent_id&quot;: &quot;&quot;,\r\n              &quot;participant_alias&quot;: &quot;h323:192.168.51.153&quot;,\r\n              &quot;protocol&quot;: &quot;H323&quot;,\r\n              &quot;remote_address&quot;: &quot;192.168.51.153&quot;,\r\n              &quot;remote_port&quot;: 11000,\r\n              &quot;resource_uri&quot;: &quot;/api/admin/status/v1/participant/92dab287-0091-4d57-bdff-f37cce6c586e/&quot;,\r\n              &quot;role&quot;: &quot;chair&quot;,\r\n              &quot;service_tag&quot;: &quot;JOG1&quot;,\r\n              &quot;service_type&quot;: &quot;conference&quot;,\r\n              &quot;signalling_node&quot;: &quot;192.168.20.11&quot;,\r\n              &quot;source_alias&quot;: &quot;h323:192.168.51.153&quot;,\r\n              &quot;system_location&quot;: &quot;CUSTOMER-JG-LAN&quot;,\r\n              &quot;vendor&quot;: &quot;TANDBERG (Tandberg 529)&quot;\r\n            },\r\n            {\r\n              &quot;bandwidth&quot;: 1280,\r\n              &quot;call_direction&quot;: &quot;in&quot;,\r\n              &quot;call_uuid&quot;: &quot;dd60c9a2-22e0-4685-9a3d-8573e5e6cc75&quot;,\r\n              &quot;conference&quot;: &quot;Sala_Teste-Turn-up&quot;,\r\n              &quot;connect_time&quot;: &quot;2017-01-27T01:42:11.103894&quot;,\r\n              &quot;destination_alias&quot;: &quot;5001&quot;,\r\n              &quot;display_name&quot;: &quot;John&quot;,\r\n              &quot;encryption&quot;: &quot;On&quot;,\r\n              &quot;has_media&quot;: true,\r\n              &quot;id&quot;: &quot;dd60c9a2-22e0-4685-9a3d-8573e5e6cc75&quot;,\r\n              &quot;is_muted&quot;: false,\r\n              &quot;is_on_hold&quot;: false,\r\n              &quot;is_presentation_supported&quot;: false,\r\n              &quot;is_presenting&quot;: false,\r\n              &quot;is_streaming&quot;: false,\r\n              &quot;license_count&quot;: 1,\r\n              &quot;license_type&quot;: &quot;port&quot;,\r\n              &quot;media_node&quot;: &quot;172.24.25.106&quot;,\r\n              &quot;parent_id&quot;: &quot;&quot;,\r\n              &quot;participant_alias&quot;: &quot;John&quot;,\r\n              &quot;protocol&quot;: &quot;WebRTC&quot;,\r\n              &quot;remote_address&quot;: &quot;179.65.15.9&quot;,\r\n              &quot;remote_port&quot;: 62794,\r\n              &quot;resource_uri&quot;: &quot;/api/admin/status/v1/participant/dd60c9a2-22e0-4685-9a3d-8573e5e6cc75/&quot;,\r\n              &quot;role&quot;: &quot;chair&quot;,\r\n              &quot;service_tag&quot;: &quot;JOG&quot;,\r\n              &quot;service_type&quot;: &quot;conference&quot;,\r\n              &quot;signalling_node&quot;: &quot;172.24.25.106&quot;,\r\n              &quot;source_alias&quot;: &quot;John&quot;,\r\n              &quot;vendor&quot;: &quot;Mozilla/5.0 (Windows NT 6.1) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/55.0.2883.87 Safari/537.36&quot;\r\n            }\r\n          ]\r\n        }\r\n\r\nI wish to find an element inside the &quot;conference&quot; Json TAG, when I find the Conference name I wonder how to bring &quot;connect_time&quot; once I had found the conference value:\r\n\r\nHere an exemple what I mean:\r\nconference&quot;: &quot;JOG1_VMR6&quot; \r\n\r\nI wanna find what is the &quot;connect_time&quot; in this particular to parser it so I built this part of code bellow:\r\n\r\n    time=$(cat service.html 2&gt;/dev/null | jq  &#39;.objects[] | select(.conference==&#39;JOG1_VMR6&#39;)&#39; | jq  &quot;.connect_time&quot; |  grep -o &quot;[^\\&quot;]*&quot; | grep -o &quot;[^T][0-9].*&quot; | grep -o &quot;[0-9]\\{2\\}:[0-9]\\{2\\}:[0-9].&quot;)\r\n\r\n \r\n  \r\nBut the select(.conference==&#39;JOG1_VMR6&#39;)&#39; is showing compile error in the shell and won&#39;t bring me the &quot;connect_time&quot;: &quot;2017-01-26T19:20:01.096940&quot; so I can&#39;t parser it correct.\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/42090354/shell-script-more-complex-jq-select",
        "title": "Shell Script more complex jq select"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 129,
                "is_accepted": true,
                "score": 129,
                "last_activity_date": 1614630970,
                "last_edit_date": 1614630970,
                "creation_date": 1486498929,
                "answer_id": 42099242,
                "question_id": 42097410,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use the [select-expression](https://stedolan.github.io/jq/manual/#select(boolean_expression)) in `jq` to do what you intend to achieve, something as,\r\n\r\n    jq &#39;.result \r\n      | select(.property_history != null) \r\n      | .property_history \r\n      | map(select(.event_name == &quot;Sold&quot;))[0].date&#39;\r\n",
                "title": "How to check for presence of &#39;key&#39; in jq before iterating over the values"
            },
            {
                "up_vote_count": 40,
                "is_accepted": false,
                "score": 40,
                "last_activity_date": 1681482367,
                "last_edit_date": 1681482367,
                "creation_date": 1486499803,
                "answer_id": 42099505,
                "question_id": 42097410,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Technically, to test for the presence of a property, you should use `has/1`, but in the present context, it would probably be better to use the postfix `?` operator, e.g.:\r\n\r\n    $ jq &#39;.result \r\n      | .property_history[]?\r\n      | select(.event_name == &quot;Sold&quot;) \r\n      | .date&#39;\r\n    &quot;08/30/2004&quot;\r\n\r\nIf there is a possibility that the value of .result is not a JSON object, then you could replace the second line above by:\r\n\r\n    try(.property_history[])\r\n\r\n    ",
                "title": "How to check for presence of &#39;key&#39; in jq before iterating over the values"
            },
            {
                "up_vote_count": 5,
                "is_accepted": false,
                "score": 5,
                "last_activity_date": 1618832910,
                "last_edit_date": 1618832910,
                "creation_date": 1611963530,
                "answer_id": 65963147,
                "question_id": 42097410,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The trick is to use [//](https://stedolan.github.io/jq/manual/#Alternativeoperator://) together with [empty](https://stedolan.github.io/jq/manual/#empty):\r\n\r\n```\r\njq &#39;.result.property_history // empty | map(select(.event_name == &quot;Sold&quot;))[0:1][].date&#39;\r\n```\r\n\r\nAnother alternative is to use an additional select:\r\n\r\n```javascript\r\njq &#39;.result.property_history | select(.) | map(select(.event_name == &quot;Sold&quot;))[0:1][].date&#39;\r\n```\r\n",
                "title": "How to check for presence of &#39;key&#39; in jq before iterating over the values"
            },
            {
                "up_vote_count": 7,
                "is_accepted": false,
                "score": 7,
                "last_activity_date": 1621982376,
                "creation_date": 1621982376,
                "answer_id": 67696403,
                "question_id": 42097410,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "General pattern:\r\n\r\n    try (...) // &quot;default_value&quot;\r\n\r\nWith your logic:\r\n\r\n    jq &#39;try (.result.property_history | map(select(.event_name == &quot;Sold&quot;))[0].date) // &quot;default_value&quot;&#39;\r\n\r\n`try` (without a catch) returns empty if the expression fails. `//` provides a default value if the value is empty.",
                "title": "How to check for presence of &#39;key&#39; in jq before iterating over the values"
            },
            {
                "up_vote_count": 44,
                "is_accepted": false,
                "score": 44,
                "last_activity_date": 1689806665,
                "last_edit_date": 1689806665,
                "creation_date": 1626386630,
                "answer_id": 68401250,
                "question_id": 42097410,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "use `has(&quot;mykey1&quot;)` (for objects) or `has(0)` (for arrays):\r\n```console\r\njq &#39;has(&quot;name&quot;)&#39; &lt;&lt;&lt; &#39;{&quot;name&quot;: &quot;hello&quot;}&#39;\r\n```\r\n\r\noutput:\r\n```console\r\ntrue\r\n```",
                "title": "How to check for presence of &#39;key&#39; in jq before iterating over the values"
            },
            {
                "up_vote_count": 7,
                "is_accepted": false,
                "score": 7,
                "last_activity_date": 1684368126,
                "creation_date": 1684368126,
                "answer_id": 76276907,
                "question_id": 42097410,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The shortest you can use (with the bonus that the **exit code will be set**):\r\n\r\n```shell\r\n# Example that exits with code 0\r\njq -e &#39;has(&quot;result&quot;)&#39;\r\n\r\n# Example that exists with code 0\r\njq -e &#39;.result[].property_history | has(&quot;price&quot;)&#39;\r\n\r\n# Example that exists with code 1\r\njq -e &#39;.result[].property_history | has(&quot;dummyKey&quot;)&#39;\r\n```\r\n\r\nIn these examples, because of setting the flag `-e`, if `has` returned true, the exit code will be set to 0, otherwise 1. Which saves unnecessary additional steps.",
                "title": "How to check for presence of &#39;key&#39; in jq before iterating over the values"
            }
        ],
        "is_answered": true,
        "answer_count": 6,
        "score": 120,
        "last_activity_date": 1701206793,
        "creation_date": 1486492580,
        "last_edit_date": 1701206793,
        "question_id": 42097410,
        "body_markdown": "I get `Cannot iterate over null (null)` from the below query because `.property_history` is not present in `result` object.\r\n\r\nHow do I check for the presence of `.property_history` key before proceeding with `map(...)`?\r\n\r\nI tried using something like\r\n```\r\nsold_year= `echo &quot;$content&quot; | jq &#39;if has(&quot;property_history&quot;) then \r\nmap(select(.event_name == &quot;Sold&quot;))[0].date&#39; else null end\r\n```\r\n\r\n**Original Query:**\r\n\r\n```\r\nsold_year=`echo &quot;$content&quot; | jq &#39;.result.property_history | map(select(.event_name == &quot;Sold&quot;))[0].date&#39;`\r\n```\r\n\r\n**JSON:**\r\n\r\n```\r\n{\r\n    &quot;result&quot;:{\r\n        &quot;property_history&quot;:[\r\n            {\r\n                &quot;date&quot;:&quot;01/27/2016&quot;,\r\n                &quot;price_changed&quot;:0,\r\n                &quot;price&quot;:899750,\r\n                &quot;event_name&quot;:&quot;Listed&quot;,\r\n                &quot;sqft&quot;:0\r\n            },\r\n            {\r\n                &quot;date&quot;:&quot;12/15/2015&quot;,\r\n                &quot;price_changed&quot;:0,\r\n                &quot;price&quot;:899750,\r\n                &quot;event_name&quot;:&quot;Listed&quot;,\r\n                &quot;sqft&quot;:2357\r\n            },\r\n            {\r\n                &quot;date&quot;:&quot;08/30/2004&quot;,\r\n                &quot;price_changed&quot;:0,\r\n                &quot;price&quot;:739000,\r\n                &quot;event_name&quot;:&quot;Sold&quot;,\r\n                &quot;sqft&quot;:2357\r\n            }\r\n        ]\r\n    }\r\n}\r\n```\r\n\r\n",
        "link": "https://stackoverflow.com/questions/42097410/how-to-check-for-presence-of-key-in-jq-before-iterating-over-the-values",
        "title": "How to check for presence of &#39;key&#39; in jq before iterating over the values"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1486577645,
                "creation_date": 1486577645,
                "answer_id": 42120637,
                "question_id": 42120456,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Just try wrap the whole expression within an array constructor, `[]`\r\n\r\n    jq &#39;[.[] | select(.name ==&quot;XML&quot;) | .good]&#39;\r\n    [\r\n      false,\r\n      true,\r\n      false\r\n    ]\r\n\r\nOr in a same line using the `--compact-output` flag\r\n\r\n    jq --compact-output &#39;[.[] | select(.name ==&quot;XML&quot;) | .good ]&#39;\r\n    [false,true,false]\r\n\r\n",
                "title": "how can I reshape jq output?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1486577829,
                "creation_date": 1486577829,
                "answer_id": 42120686,
                "question_id": 42120456,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "In short: gather the results as an array, and use the -c option, e.g.\r\n\r\n    $ jq -c &#39;map( select(.name ==&quot;XML&quot;) | .good )&#39;\r\n\r\nOutput:\r\n\r\n    [false,true,false]",
                "title": "how can I reshape jq output?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1486577829,
        "creation_date": 1486577094,
        "last_edit_date": 1486577377,
        "question_id": 42120456,
        "body_markdown": "I have the following json data:\r\n\r\n\r\n    [\r\n         {&quot;name&quot;:&quot;JSON&quot;, &quot;good&quot;:true}, \r\n         {&quot;name&quot;:&quot;XML&quot;, &quot;good&quot;:false},\r\n         {&quot;name&quot;:&quot;JSON&quot;, &quot;good&quot;:false},\r\n         {&quot;name&quot;:&quot;HTML&quot;, &quot;good&quot;:false},\r\n         {&quot;name&quot;:&quot;XML&quot;, &quot;good&quot;:true},\r\n         {&quot;name&quot;:&quot;XML&quot;, &quot;good&quot;:false}\r\n      ]\r\n\r\nby using : \r\n   \r\n    jq &#39;.[] | select(.name ==&quot;XML&quot;) | .good&#39;, result will be :\r\n    false\r\n    true\r\n    false\r\n\r\nHow can I make it like **[false,true,false]** as a record?\r\n ",
        "link": "https://stackoverflow.com/questions/42120456/how-can-i-reshape-jq-output",
        "title": "how can I reshape jq output?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1486608490,
                "post_id": 42126776,
                "comment_id": 71422564,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 2662970,
                    "reputation": 35,
                    "user_id": 7381296,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/QHhud.png?s=256",
                    "display_name": "mrh53",
                    "link": "https://stackoverflow.com/users/7381296/mrh53"
                },
                "reply_to_user": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1486611319,
                "post_id": 42126776,
                "comment_id": 71423254,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1486612970,
                "creation_date": 1486612970,
                "answer_id": 42127998,
                "question_id": 42126776,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Based on my understanding of the question, I believe that using --argfile rather than --slurpfile would simplify things.\r\n\r\nThe following filter will adjust $retobj based on the contents of  thermostats2.json:\r\n\r\n\r\n    . as $in\r\n    | reduce [&quot;location&quot;,\r\n              (.location | keys[]),\r\n              &quot;setpoints&quot;,\r\n              [&quot;day&quot;,&quot;night&quot;,&quot;away&quot;][]] as $path\r\n        ( $retobj;\r\n\t      setpath( $path; ($in | getpath($path)) ) )\r\n\r\n\r\nInvocation:\r\n    jq --argfile retobj ret.json -f query.jq thermostats2.json\r\n    \r\n",
                "title": "jq trying to iterate over two sets of values"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1486612970,
        "creation_date": 1486604176,
        "last_edit_date": 1486612587,
        "question_id": 42126776,
        "body_markdown": "Update:  I have experimented with extracting the paths I desire to update and using those paths relative to the local and returned objects (read below) in a setpath(paths;getpath(paths)) construction.  I can now iterate over the $paths array and make the desired updates to the local json object.\r\n\r\nUsing the thermostats2.json file below and a ret.json that differs from thermostats2.json only in:\r\n\r\n {&quot;location&quot;:{&quot;livingroom&quot;:{&quot;setpoints&quot;:{&quot;day&quot;:&quot;25000&quot;}}}} #vs{&quot;day&quot;:&quot;23000&quot;}\r\n\r\nmy script now looks like:\r\n\r\n    . as $obj |\r\n    \r\n    # obtain location keys from $obj as they may have changed locally prior to $retobj being processed\r\n    \r\n    ($obj.location | keys? ) as $locs |\r\n    \r\n    # setpoints are fixed in this code as [&quot;day&quot;,&quot;night&quot;,&quot;away&quot;]\r\n    \r\n    [&quot;day&quot;,&quot;night&quot;,&quot;away&quot;] as $setpoints |\r\n    \r\n    [path($obj.location[($locs[])].setpoints[($setpoints[])])] as $paths |\r\n    \r\n    reduce\r\n      range(0; $paths|length) as $i\r\n    (.; . | setpath($paths[$i];( $retobj[0] | getpath($paths[$i])))  ) | .\r\n\r\nI don&#39;t need the $obj variable at this time but I have not cleaned that up yet.  Please comment if you see problems with this approach or if this looks like a good solution.  I will answer this question if the comments indicate it should be.\r\n\r\n\r\nI have a json object that contains several location objects each, in turn, containing several setpoint objects, among other data.  A remote application is provided this json object and returns updates to the values of the setpoint objects, if required.  I would like to update the local json object rather than replace it with the returned object.\r\n\r\nI do not want to assume the returned object&#39;s location keys are identical to those of the local object as the local object may have been maintained while the remote object was being modified.\r\n\r\nI have figured out how to extract the location keys from the local file and create an array containing the setpoint keys whose values I am interested in updating.  I have also been able to figure out how to reduce the updated values from the returned object into an array.\r\n\r\nWhat I have not figured out is how to iterate over the locations and the setpoints together in order to update the values in the local json object.\r\n\r\nI invoke jq with:\r\n\r\n    # usage : jq --slurpfile retobj ret.json --from-file query.jq thermostats2.json\r\n    \r\n    query.jq contains:\r\n    # use $obj as the local object to be updated with values returned in $retobj\r\n    # $retobj is not permitted to modify the structure of $obj\r\n    \r\n    . as $obj |\r\n    \r\n    # obtain location keys from $obj as they may have changed locally prior to $retobj being processed\r\n    \r\n    ($obj.location | keys? ) as $locs |\r\n    \r\n    # setpoints are fixed in this code as [&quot;day&quot;,&quot;night&quot;,&quot;away&quot;]\r\n    \r\n    [&quot;day&quot;,&quot;night&quot;,&quot;away&quot;] as $setpoints |\r\n    reduce $retobj[0].location[($locs[])].setpoints[($setpoints[])] as $item\r\n    ( []; . + [$item] )\r\n     | . as $vals |\r\n    $vals\r\n\r\n \r\nthermostats2.json:\r\n\r\n    { &quot;mode&quot;:&quot;Home&quot;,\r\n      &quot;location&quot;: {\r\n        &quot;livingroom&quot;: {\r\n    \t&quot;scale&quot;:&quot;Celcius&quot;,\r\n    \t&quot;current&quot;: {\r\n    \t    &quot;valid&quot;:&quot;YES&quot;,\r\n    \t    &quot;reading&quot;:&quot;23000&quot;,\r\n    \t    &quot;time&quot;:&quot;000000&quot;\r\n    \t},\r\n    \t&quot;previous&quot;: {\r\n    \t    &quot;reading&quot;:&quot;23000&quot;,\r\n    \t    &quot;time&quot;:&quot;000000&quot;\r\n    \t},\r\n    \t&quot;setpoints&quot;: {\r\n    \t    &quot;schedule&quot;: {\r\n    \t\t&quot;weekday&quot;: {&quot;day&quot;:&quot;0600&quot;,\r\n    \t\t\t    &quot;night&quot;:&quot;2100&quot;\r\n    \t\t\t   },\r\n    \t\t&quot;weekend&quot;: {&quot;day&quot;:&quot;0630&quot;,\r\n    \t\t\t    &quot;night&quot;:&quot;2200&quot;\r\n    \t\t\t   }\r\n    \t    },\r\n    \t    &quot;active&quot;:&quot;day&quot;,\r\n    \t    &quot;day&quot;:&quot;23000&quot;,\r\n    \t    &quot;night&quot;:&quot;15556&quot;,\r\n    \t    &quot;away&quot;:&quot;12778&quot;\r\n    \t}\r\n        },\r\n        &quot;familyroom&quot;: {\r\n    \t&quot;scale&quot;:&quot;Celcius&quot;,\r\n    \t&quot;current&quot;: {\r\n    \t    &quot;valid&quot;:&quot;YES&quot;,\r\n    \t    &quot;reading&quot;:&quot;23000&quot;,\r\n    \t    &quot;time&quot;:&quot;000000&quot;\r\n    \t},\r\n    \t&quot;previous&quot;: {\r\n    \t    &quot;reading&quot;:&quot;23000&quot;,\r\n    \t    &quot;time&quot;:&quot;000000&quot;\r\n    \t},\r\n    \t&quot;setpoints&quot;: {\r\n    \t    &quot;schedule&quot;: {\r\n    \t\t&quot;weekday&quot;: {&quot;day&quot;:&quot;0600&quot;,\r\n    \t\t\t    &quot;night&quot;:&quot;2100&quot;\r\n    \t\t\t   },\r\n    \t\t&quot;weekend&quot;: {&quot;day&quot;:&quot;0630&quot;,\r\n    \t\t\t    &quot;night&quot;:&quot;2200&quot;\r\n    \t\t\t   }\r\n    \t\t\r\n    \t    },\r\n    \t    &quot;active&quot;:&quot;day&quot;,\r\n    \t    &quot;day&quot;:&quot;23000&quot;,\r\n    \t    &quot;night&quot;:&quot;15556&quot;,\r\n    \t    &quot;away&quot;:&quot;12778&quot;\r\n    \t}\r\n        },\r\n        &quot;28-000005e2fdef&quot;: {\r\n    \t&quot;scale&quot;:&quot;Celcius&quot;,\r\n    \t&quot;current&quot;: {\r\n    \t    &quot;valid&quot;:&quot;YES&quot;,\r\n    \t    &quot;reading&quot;:&quot;23000&quot;,\r\n    \t    &quot;time&quot;:&quot;000000&quot;\r\n    \t},\r\n    \t&quot;previous&quot;: {\r\n    \t    &quot;reading&quot;:&quot;23000&quot;,\r\n    \t    &quot;time&quot;:&quot;000000&quot;\r\n    \t},\r\n    \t&quot;setpoints&quot;: {\r\n    \t    &quot;schedule&quot;: {\r\n    \t\t&quot;weekday&quot;: {&quot;day&quot;:&quot;0600&quot;,\r\n    \t\t\t    &quot;night&quot;:&quot;2100&quot;\r\n    \t\t\t   },\r\n    \t\t&quot;weekend&quot;: {&quot;day&quot;:&quot;0630&quot;,\r\n    \t\t\t    &quot;night&quot;:&quot;2200&quot;\r\n    \t\t\t   }\r\n    \t    },\r\n    \t    &quot;active&quot;:&quot;day&quot;,\r\n    \t    &quot;day&quot;:&quot;23000&quot;,\r\n    \t    &quot;night&quot;:&quot;15556&quot;,\r\n    \t    &quot;away&quot;:&quot;12778&quot;\r\n    \t}\r\n        }\r\n      }\r\n    }\r\n\r\nWhat I cannot find is any means to set the values for the same objects in $obj, i.e. effectively:\r\n\r\n$obj[0].location[($locs[])].setpoints[($setpoints[])] = $vals\r\n\r\nI understand that, as a novice, I am not likely choosing the preferred approach for solving this type of problem.  I am also struggling with embracing the filter paradigm in some of the built-in functions, particularly foreach.\r\n\r\nto recap my goal, I wish to:\r\n\r\nget the proper object values in $retobj via location keys derived from the local obj and the setpoint keys defined in the filter, and set the same paths in local object to those values.\r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/42126776/jq-trying-to-iterate-over-two-sets-of-values",
        "title": "jq trying to iterate over two sets of values"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1486683358,
                "creation_date": 1486683358,
                "answer_id": 42148959,
                "question_id": 42148703,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "    .outputLayout.fields[] |= (.isIdentifier = (.displayName == &quot;LoadSeqNum&quot;) )\r\n\r\nOr equivalently but perhaps a little less cryptically:\r\n\r\n    .outputLayout.fields |= map( .isIdentifier = (.displayName == &quot;LoadSeqNum&quot;) )\r\n\r\n",
                "title": "How to add tag inside a nest depending on a variable while keeping rest of json"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1486683358,
        "creation_date": 1486682046,
        "question_id": 42148703,
        "body_markdown": "I&#39;m failry new to jq and I&#39;ve learned to do most things on my own but I&#39;m hitting my head on my keyboard for this one.   Look at the following json\r\n\r\n\r\nJSON:\r\n\r\n      {\r\n      &quot;importType&quot;: &quot;Upsert&quot;,\r\n      &quot;immediateDeployment&quot;: false,\r\n      &quot;isIgnoreNulls&quot;: false,\r\n      &quot;isOverwriteNullsOnly&quot;: false,\r\n      &quot;isPreferredandSync&quot;: false,\r\n      &quot;outputLayout&quot;: {\r\n        &quot;fields&quot;: [\r\n          {\r\n            &quot;name&quot;: &quot;TEMP_KEY&quot;,\r\n            &quot;type&quot;: &quot;String&quot;,\r\n            &quot;length&quot;: &quot;2000&quot;,\r\n            &quot;displayName&quot;: &quot;TEMP_KEY&quot;\r\n          },\r\n          {\r\n            &quot;name&quot;: &quot;LoadSeqNum&quot;,\r\n            &quot;type&quot;: &quot;String&quot;,\r\n            &quot;length&quot;: &quot;2000&quot;,\r\n            &quot;displayName&quot;: &quot;LoadSeqNum&quot;\r\n          }\r\n        ]\r\n      }\r\n    }\r\n\r\nWhat I&#39;m trying to do is inside of .outputLayout.fields[] I want to create a new pair called &quot;isIdentifier&quot; where it is true if the .outputLayout.fields[].name is LoadSeqNum and false if it&#39;s not but I need to keep the rest of the json just as it is.  So target should look as following:\r\n\r\nGoal:\r\n\r\n      {\r\n      &quot;importType&quot;: &quot;Upsert&quot;,\r\n      &quot;immediateDeployment&quot;: false,\r\n      &quot;isIgnoreNulls&quot;: false,\r\n      &quot;isOverwriteNullsOnly&quot;: false,\r\n      &quot;isPreferredandSync&quot;: false,\r\n      &quot;outputLayout&quot;: {\r\n        &quot;fields&quot;: [\r\n          {\r\n            &quot;name&quot;: &quot;TEMP_KEY&quot;,\r\n            &quot;type&quot;: &quot;String&quot;,\r\n            &quot;length&quot;: &quot;2000&quot;,\r\n            &quot;displayName&quot;: &quot;TEMP_KEY&quot;\r\n            &quot;isIdentifier&quot;: false\r\n          },\r\n          {\r\n            &quot;name&quot;: &quot;LoadSeqNum&quot;,\r\n            &quot;type&quot;: &quot;String&quot;,\r\n            &quot;length&quot;: &quot;2000&quot;,\r\n            &quot;displayName&quot;: &quot;LoadSeqNum&quot;\r\n            &quot;isIdentifier&quot;: true\r\n          }\r\n        ]\r\n      }\r\n    }\r\n\r\nI tried this:\r\n\r\n    jq &#39;.outputLayout.fields[] | . + {&quot;isIdentifier&quot;: (if (.name)==&quot;LoadSeqNum&quot; then true else false end)}&#39;\r\n\r\nBut of course I&#39;m missing all the higher level things.  When I try to do:\r\n\r\n    .outputLayout.fields[].isIdentifier=(if (.outputLayout.fields[].name)==&quot;LoadSeqNum&quot; then true else false end)\r\n\r\nI get the whole thing twice, once with both true and the other one with both false.  I understand why it&#39;s doing that but I&#39;m having a tough time figuring out what would work.  Any help or point in right direction?",
        "link": "https://stackoverflow.com/questions/42148703/how-to-add-tag-inside-a-nest-depending-on-a-variable-while-keeping-rest-of-json",
        "title": "How to add tag inside a nest depending on a variable while keeping rest of json"
    },
    {
        "tags": [
            "python",
            "bookmarks",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 476555,
                    "reputation": 47257,
                    "user_id": 887539,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/5baef9617bdee6db2f534c118bcbccee?s=256&d=identicon&r=PG",
                    "display_name": "Andreas Louv",
                    "link": "https://stackoverflow.com/users/887539/andreas-louv"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1486725416,
                "post_id": 42156950,
                "comment_id": 71481274,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1486743117,
                "last_edit_date": 1486743117,
                "creation_date": 1486737428,
                "answer_id": 42161948,
                "question_id": 42156950,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The Chrome bookmark format is not &quot;flat&quot; so it&#39;s not obvious what CSV output you want, but starting with .roots.other.children[] as you suggest, here&#39;s a start:\r\n\r\n    jq -r &#39;.roots.other.children[]\r\n           | [.date_added,.id,.name,.sync_transaction_version,.type,.url,\r\n              (.meta_info|tostring)]\r\n           | @csv&#39; \r\n\r\n\r\nNotice how `tostring` is used here to &quot;flatten&quot; `.meta_info`.  Notice also that the fields of interest have been specified explicitly -- this is to guard against the possibility that their ordering may not always be uniform within the bookmarks file.\r\n",
                "title": "using jq for parsing chrome bookmarks to csv"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1486743117,
        "creation_date": 1486722198,
        "last_edit_date": 1486722604,
        "question_id": 42156950,
        "body_markdown": "Is it possible to parse Chrome bookmarks with jq in one line?\r\n(for csv output)\r\n\r\nWith `jq &#39;.roots.other.children[]&#39;` Bookmarks\r\nI get separate lines\r\n\r\n",
        "link": "https://stackoverflow.com/questions/42156950/using-jq-for-parsing-chrome-bookmarks-to-csv",
        "title": "using jq for parsing chrome bookmarks to csv"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1486829088,
                "creation_date": 1486829088,
                "answer_id": 42178033,
                "question_id": 42177558,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "After rectifying the JSON input, the following filter produces the output shown below:\r\n\r\n    .[] | select( .tags | index(&quot;tags1&quot;) ) | .title\r\n\r\nOutput:\r\n\r\n    &quot;t1&quot;\r\n    &quot;t2&quot;\r\n\r\n",
                "title": "How to filter an array of objects based on values of string in an inner array with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1486829088,
        "creation_date": 1486826648,
        "last_edit_date": 1495541335,
        "question_id": 42177558,
        "body_markdown": "I have a json file like this:\r\n\r\n```[{\r\n    &quot;path&quot;: &quot;p1&quot;\r\n    &quot;title&quot;: &quot;t1&quot;\r\n    &quot;tags&quot;: [&quot;tags1&quot;]\r\n},\r\n{\r\n    &quot;path&quot;: &quot;p2&quot;\r\n    &quot;title&quot;: &quot;t2&quot;\r\n    &quot;tags&quot;: [&quot;tags1&quot;, &quot;tag2&quot;]\r\n},\r\n{\r\n    &quot;path&quot;: &quot;p3&quot;\r\n    &quot;title&quot;: &quot;t3&quot;\r\n    &quot;tags&quot;: [&quot;tags2&quot;]\r\n}\r\n]\r\n```\r\nand I would like to filter (using `jq`) the value based on tags and get the title as output.\r\n\r\nFor instance, I would filter all the values that have _tags1_(and the output would be `t1` and `t2`).\r\n\r\nHow can I do that ?\r\n\r\nThank you for your answers.\r\n\r\nP.S. : I found this question : [https://stackoverflow.com/questions/26701538/how-to-filter-an-array-of-objects-based-on-values-in-an-inner-array-with-jq](https://stackoverflow.com/questions/26701538/how-to-filter-an-array-of-objects-based-on-values-in-an-inner-array-with-jq) that almost have the answer but I was not able to adapt it.",
        "link": "https://stackoverflow.com/questions/42177558/how-to-filter-an-array-of-objects-based-on-values-of-string-in-an-inner-array-wi",
        "title": "How to filter an array of objects based on values of string in an inner array with jq"
    },
    {
        "tags": [
            "json",
            "jq",
            "jsonlines"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 878759,
                    "reputation": 4118,
                    "user_id": 134044,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/eff44fbba202a5b3a99073258ad3d3d2?s=256&d=identicon&r=PG",
                    "display_name": "NeilG",
                    "link": "https://stackoverflow.com/users/134044/neilg"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1634505555,
                "post_id": 42178636,
                "comment_id": 123036603,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": -2,
                "last_activity_date": 1486832867,
                "creation_date": 1486832867,
                "answer_id": 42178695,
                "question_id": 42178636,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Found: it&#39;s\r\n\r\n    map(tostring) | reduce .[] as $item (&quot;&quot;; . + $item + &quot;\\n&quot;)\r\n\r\nYou also need to use ```--raw-output```.",
                "title": "How to use jq to output JSONL (one independent JSON object per line)"
            },
            {
                "up_vote_count": 70,
                "is_accepted": false,
                "score": 70,
                "last_activity_date": 1666655504,
                "last_edit_date": 1666655504,
                "creation_date": 1486833216,
                "answer_id": 42178760,
                "question_id": 42178636,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The answer to the original question is to use the filter `.[]` together with the `-c` command-line option:\r\n\r\n    $ jq -c &#39;.[]&#39;\r\n\r\n---\r\n\r\nIf the input file is very large (notably, if it is too large to fit into memory), it may be better to use jq&#39;s `--stream` command-line option, or a companion tool.  If the preservation of numerical precision is important, then you may wish to consider `jm`, which is particularly easy to use: invoking `jm` without any parameters suffices.  See the jq Cookbook: https://github.com/stedolan/jq/wiki/Cookbook",
                "title": "How to use jq to output JSONL (one independent JSON object per line)"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1585695729,
                "creation_date": 1585695729,
                "answer_id": 60961240,
                "question_id": 42178636,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If the input array is too large to fit into memory, you can use jq&#39;s so-called &quot;streaming parser&quot;.  \r\n\r\nHere is an illustration using a generic approach, that is, it makes no assumptions about the items in the top-level array:\r\n\r\n```\r\n$ echo &#39;[{&quot;foo&quot;:&quot;bar&quot;},99,null,{&quot;foo&quot;:&quot;baz&quot;}]&#39; |\r\n  jq -cn --stream &#39;fromstream( inputs|(.[0] |= .[1:]) | select(. != [[]]) )&#39;\r\n{&quot;foo&quot;:&quot;bar&quot;}\r\n99\r\nnull\r\n{&quot;foo&quot;:&quot;baz&quot;}\r\n$ \r\n```",
                "title": "How to use jq to output JSONL (one independent JSON object per line)"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1717419435,
                "creation_date": 1717419435,
                "answer_id": 78570403,
                "question_id": 42178636,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Following this question/answer, noticed that many tools generating JSON (in my case I&#39;m exporting from a database) use ambiguous line endings -- `jq` doesn&#39;t play nicely with making `JSONL` if there&#39;s strange carriage returns.\r\n\r\nsomething like:\r\n\r\n```\r\ncat db.output.json| tr -d &#39;\\r\\n&#39; | jq -c &#39;.[]&#39;&gt;db.output.jsonl\r\n```\r\n\r\nfixed the behavior where\r\n\r\n```\r\njq -c &#39;.[]&#39;\r\n```\r\nfrom the accepted answer didn&#39;t create `JSONL`.\r\n\r\nI&#39;d leave just as a comment but my poor lil reputation won&#39;t allow it :(",
                "title": "How to use jq to output JSONL (one independent JSON object per line)"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": 54,
        "last_activity_date": 1717419435,
        "creation_date": 1486832530,
        "last_edit_date": 1486875472,
        "question_id": 42178636,
        "body_markdown": "My request sounds trivial but I could not find a way to do it. I have as input an array of JSON objects:\r\n\r\n    [\r\n        {\r\n            &quot;foo&quot;: 1,\r\n            &quot;bar&quot;: 2\r\n        },\r\n        {\r\n            &quot;foo&quot;: 3,\r\n            &quot;bar&quot;: 4\r\n        },\r\n        (...)\r\n    ]\r\n\r\nand I want as output the JSONL version of the same, aka one object per line, not an array:\r\n\r\n        { &quot;foo&quot;: 1, &quot;bar&quot;: 2 }\r\n        { &quot;foo&quot;: 3, &quot;bar&quot;: 4 }\r\n        (...)\r\n\r\nThis is **not** the same as using ```--compact-output```, as that would preserve the array and give me:\r\n\r\n        [ { &quot;foo&quot;: 1, &quot;bar&quot;: 2 }, { &quot;foo&quot;: 3, &quot;bar&quot;: 4 }, (...) ]\r\n\r\nThank you in advance.",
        "link": "https://stackoverflow.com/questions/42178636/how-to-use-jq-to-output-jsonl-one-independent-json-object-per-line",
        "title": "How to use jq to output JSONL (one independent JSON object per line)"
    },
    {
        "tags": [
            "json",
            "parent-child",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 476555,
                    "reputation": 47257,
                    "user_id": 887539,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/5baef9617bdee6db2f534c118bcbccee?s=256&d=identicon&r=PG",
                    "display_name": "Andreas Louv",
                    "link": "https://stackoverflow.com/users/887539/andreas-louv"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1487026588,
                "post_id": 42214984,
                "comment_id": 71591481,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1487027339,
                "creation_date": 1487027339,
                "answer_id": 42215170,
                "question_id": 42214984,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "For this particular case, you could do this:\r\n\r\n    $ jq &#39;.a |= (.b = {}) + .b&#39; input.json\r\n\r\nHere we&#39;re updating object `a` with the original contents with `b` replaced with an empty object and combining it with the contents of the original `b`.\r\n\r\n\r\nIf that was too hard to reason about, this might be easier to follow:\r\n\r\n    $ jq &#39;.a |=\r\n        with_entries(if .key == &quot;b&quot;\r\n            then (.value = {}), (.value | to_entries[])\r\n            else .\r\n        end)&#39; input.json\r\n",
                "title": "Jq: How to move the child members to parent?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1487049268,
                "creation_date": 1487049268,
                "answer_id": 42218358,
                "question_id": 42214984,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "This is just a variant of @Jeff-Mercado&#39;s first solution, but may be slightly easier to follow (notably because there is only one reference to .b, and because the grouping on the RHS is explicit):\r\n\r\n     .a |= ({b:{}} + .b)\r\n\r\n",
                "title": "Jq: How to move the child members to parent?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1487077317,
                "creation_date": 1487077317,
                "answer_id": 42226904,
                "question_id": 42214984,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "To do this recursively for any field use:\r\n\r\n    walk\r\n    (\r\n        if (type == &quot;object&quot; and has(&quot;b&quot;)) then\r\n            .|=.b\r\n        else\r\n            .\r\n        end\r\n    )",
                "title": "Jq: How to move the child members to parent?"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 3,
        "last_activity_date": 1487077317,
        "creation_date": 1487026267,
        "last_edit_date": 1487049397,
        "question_id": 42214984,
        "body_markdown": "Consider the following json:\r\n\r\n    {\r\n      a: {\r\n        b: {\r\n          c: 1,\r\n          d: 2\r\n        }\r\n      }\r\n    }\r\n\r\nHow can I move all the properties of b to be under the parent a:\r\n\r\n    {\r\n      a: {\r\n        c: 1,\r\n        d: 2,\r\n        b: {}\r\n      }\r\n    }\r\n",
        "link": "https://stackoverflow.com/questions/42214984/jq-how-to-move-the-child-members-to-parent",
        "title": "Jq: How to move the child members to parent?"
    },
    {
        "tags": [
            "arrays",
            "json",
            "nested",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": false,
                "score": 5,
                "last_activity_date": 1487031211,
                "last_edit_date": 1487031211,
                "creation_date": 1487030037,
                "answer_id": 42215597,
                "question_id": 42215211,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "A very targeted solution would be:\r\n\r\n    path(.[0].organizations[0].spaces) as $target\r\n    | (getpath($target) | map(select(.name != &quot;name4&quot;))) as $new\r\n    | setpath($target; $new)\r\n\r\nIf permissible, though, you might consider:\r\n\r\n    walk(if type == &quot;object&quot; and .spaces|type == &quot;array&quot;\r\n         then .spaces |= map(select(.name != &quot;name4&quot;))\r\n         else . end)\r\n\r\n\r\nor:\r\n\r\n    del(.. | .spaces? // empty | .[] | select(.name == &quot;name4&quot;) )\r\n\r\n(If your jq does not have `walk/1` then its jq definition can easily be found by googling.)\r\n",
                "title": "Delete on nested array with jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1502869882,
                "creation_date": 1502869882,
                "answer_id": 45707986,
                "question_id": 42215211,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a solution using **select**, **reduce**, **tostream** and **delpaths**\r\n\r\n\tmap(  \r\n\t    select(.name == &quot;name1&quot;)\r\n\t  | reduce (tostream|select(length==2)) as [$p,$v] (\r\n\t      .\r\n\t    ; if [$p[-1],$v] == [&quot;name&quot;,&quot;name4&quot;] then delpaths([$p[:-1]]) else . end\r\n\t    )\r\n\t)",
                "title": "Delete on nested array with jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1641301485,
                "creation_date": 1641301485,
                "answer_id": 70579297,
                "question_id": 42215211,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use the below and it will remove the `&quot;name&quot;: &quot;name4&quot;` array only.\r\n\r\n    jq &#39;del(.[] | .organizations? | .[] | .spaces?|.[] | select(.name? == &quot;name4&quot;))&#39; yourJsonFile.json",
                "title": "Delete on nested array with jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1675370844,
                "creation_date": 1675370844,
                "answer_id": 75328767,
                "question_id": 42215211,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I took a similar approach as @peak but inverted it, so instead of selecting what you want and setting that in the output we&#39;re selecting what we don&#39;t want and deleting it.\r\n\r\n    [path(.organizations[0].spaces[]| select(.name == &quot;name4&quot;)] as $trash | delpaths($trash)",
                "title": "Delete on nested array with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": 5,
        "last_activity_date": 1675370844,
        "creation_date": 1487027560,
        "last_edit_date": 1487106587,
        "question_id": 42215211,
        "body_markdown": "this is my data structure:\r\n\r\n    [\r\n    \t{\r\n    \t\t&quot;name&quot;: &quot;name1&quot;,\r\n    \t\t&quot;organizations&quot;: [\r\n    \t\t\t{\r\n    \t\t\t\t&quot;name&quot;: &quot;name2&quot;,\r\n    \t\t\t\t&quot;spaces&quot;: [\r\n    \t\t\t\t\t{\r\n    \t\t\t\t\t\t&quot;name&quot;: &quot;name3&quot;,\r\n    \t\t\t\t\t\t&quot;otherkey&quot;:&quot;otherval&quot;\r\n    \t\t\t\t\t},\r\n    \t\t\t\t\t{\r\n    \t\t\t\t\t\t&quot;name&quot;: &quot;name4&quot;,\r\n    \t\t\t\t\t\t&quot;otherkey&quot;:&quot;otherval&quot;\r\n    \t\t\t\t\t}\r\n    \t\t\t\t]\r\n    \t\t\t}\r\n    \t\t]\r\n    \t},\r\n    \t{\r\n    \t\t&quot;name&quot;: &quot;name21&quot;,\r\n    \t\t&quot;organizations&quot;: [\r\n    \t\t\t{\r\n    \t\t\t\t&quot;name&quot;: &quot;name22&quot;,\r\n    \t\t\t\t&quot;spaces&quot;: [\r\n    \t\t\t\t\t{\r\n    \t\t\t\t\t\t&quot;name&quot;: &quot;name23&quot;,\r\n    \t\t\t\t\t\t&quot;otherkey&quot;:&quot;otherval&quot;\r\n    \t\t\t\t\t},\r\n    \t\t\t\t\t{\r\n    \t\t\t\t\t\t&quot;name&quot;: &quot;name24&quot;,\r\n    \t\t\t\t\t\t&quot;otherkey&quot;:&quot;otherval&quot;\r\n    \t\t\t\t\t}\r\n    \t\t\t\t]\r\n    \t\t\t}\r\n    \t\t]\r\n    \t}\r\n    ]\r\n\r\ni just want to keep name=name1, remove the nested array object with name=name4 and want to keep the rest of the object intact. I tried with map(select) but this will just give me the full object. Is it possible to work with del on specific subarrays and keep the rest as it is?\r\n\r\nresult should be the following. in addition i want to avoid enumeration all attributes to keep on outer objects:\r\n\r\n    [\r\n    \t{\r\n    \t\t&quot;name&quot;: &quot;name1&quot;,\r\n    \t\t&quot;organizations&quot;: [\r\n    \t\t\t{\r\n    \t\t\t\t&quot;name&quot;: &quot;name2&quot;,\r\n    \t\t\t\t&quot;spaces&quot;: [\r\n    \t\t\t\t\t{\r\n    \t\t\t\t\t\t&quot;name&quot;: &quot;name3&quot;,\r\n    \t\t\t\t\t\t&quot;otherkey&quot;:&quot;otherval&quot;\r\n    \t\t\t\t\t}\r\n    \t\t\t\t]\r\n    \t\t\t}\r\n    \t\t]\r\n    \t}\r\n    ]\r\n\r\nany idea? thanks!\r\n",
        "link": "https://stackoverflow.com/questions/42215211/delete-on-nested-array-with-jq",
        "title": "Delete on nested array with jq"
    },
    {
        "tags": [
            "json",
            "key",
            "traversal",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1487085399,
                "last_edit_date": 1487085399,
                "creation_date": 1487080789,
                "answer_id": 42228119,
                "question_id": 42227949,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Generally `walk()` is not required here. I would use `map()` like this:\r\n\r\n    jq &#39;map(select(.key!=&quot;something&quot;))&#39;\r\n\r\n---\r\n\r\nAbout the error you reported, you miss parentheses. It should be:\r\n\r\n    jq &#39;walk(if(type == &quot;object&quot; and (.key | test(&quot;something&quot;))) then del(.) else . end)&#39;\r\n                                     ^                        ^",
                "title": "Jq: testing a field during walk"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1492701722,
                "last_edit_date": 1492701722,
                "creation_date": 1487087395,
                "answer_id": 42230518,
                "question_id": 42227949,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "1. As @hek2mgl explained, the answer to your question about the error message is that `(X and Y | Z)` is parsed as `(X and Y) | Z`. \r\n\r\n2.  The main problem with your query is the occurrence of `del(.)`.  The &quot;.&quot; in this case refers to the object, and thus using del/1 here is simply wrong.  Since it&#39;s not clear exactly what you are trying to do, let me venture to guess that it is to delete the object (.) itself.  That can be done using `empty`:\r\n\r\n&lt;/&gt;\r\n\r\n    walk(if type == &quot;object&quot; and (.key | test(&quot;something&quot;))\r\n         then empty\r\n         else . end)\r\n\r\nMore robustly:\r\n\r\n    walk(if type == &quot;object&quot; and (.key | (type == &quot;string&quot; and test(&quot;something&quot;)))\r\n         then empty\r\n         else . end)\r\n\r\n",
                "title": "Jq: testing a field during walk"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 5,
        "last_activity_date": 1639488138,
        "creation_date": 1487080326,
        "last_edit_date": 1639488138,
        "question_id": 42227949,
        "body_markdown": "Consider following jq config:\r\n\r\n    walk \r\n    ( \r\n      if (type == &quot;object&quot; and .key | test(&quot;something&quot;)) then \r\n        del(.) \r\n      else \r\n        . \r\n      end\r\n    )\r\nAnd following JSON:\r\n```json\r\n[\r\n  {\r\n    &quot;key&quot;: &quot;something&quot;,\r\n    &quot;value&quot;: &quot;something&quot;\r\n  },\r\n  {\r\n    &quot;key&quot;: &quot;another thing&quot;,\r\n    &quot;value&quot;: &quot;another thing&quot;\r\n  },\r\n  {\r\n    &quot;key&quot;: &quot;something&quot;,\r\n    &quot;value&quot;: &quot;something&quot;\r\n  }\r\n]\r\n```\r\nHowever, jq throws following error:\r\n\r\n&gt; jq: error (at &lt;stdin&gt;:13): boolean (false) cannot be matched, as it is not a string\r\n\r\n13 is the last line of the input. What boolean value is it trying to match?",
        "link": "https://stackoverflow.com/questions/42227949/jq-testing-a-field-during-walk",
        "title": "Jq: testing a field during walk"
    },
    {
        "tags": [
            "arrays",
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 9518332,
                    "reputation": 9585,
                    "user_id": 7073944,
                    "user_type": "registered",
                    "accept_rate": 83,
                    "profile_image": "https://i.sstatic.net/BecHV.png?s=256",
                    "display_name": "Vanquished Wombat",
                    "link": "https://stackoverflow.com/users/7073944/vanquished-wombat"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1487151721,
                "post_id": 42245288,
                "comment_id": 71649534,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 1682782,
                    "reputation": 7693,
                    "user_id": 2096986,
                    "user_type": "registered",
                    "accept_rate": 37,
                    "profile_image": "https://www.gravatar.com/avatar/3a02e7c9d317839db7ad17f840320afd?s=256&d=identicon&r=PG",
                    "display_name": "Felipe",
                    "link": "https://stackoverflow.com/users/2096986/felipe"
                },
                "reply_to_user": {
                    "account_id": 9518332,
                    "reputation": 9585,
                    "user_id": 7073944,
                    "user_type": "registered",
                    "accept_rate": 83,
                    "profile_image": "https://i.sstatic.net/BecHV.png?s=256",
                    "display_name": "Vanquished Wombat",
                    "link": "https://stackoverflow.com/users/7073944/vanquished-wombat"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1487152152,
                "post_id": 42245288,
                "comment_id": 71649837,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 9518332,
                    "reputation": 9585,
                    "user_id": 7073944,
                    "user_type": "registered",
                    "accept_rate": 83,
                    "profile_image": "https://i.sstatic.net/BecHV.png?s=256",
                    "display_name": "Vanquished Wombat",
                    "link": "https://stackoverflow.com/users/7073944/vanquished-wombat"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1487153462,
                "post_id": 42245288,
                "comment_id": 71650872,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 1682782,
                    "reputation": 7693,
                    "user_id": 2096986,
                    "user_type": "registered",
                    "accept_rate": 37,
                    "profile_image": "https://www.gravatar.com/avatar/3a02e7c9d317839db7ad17f840320afd?s=256&d=identicon&r=PG",
                    "display_name": "Felipe",
                    "link": "https://stackoverflow.com/users/2096986/felipe"
                },
                "reply_to_user": {
                    "account_id": 9518332,
                    "reputation": 9585,
                    "user_id": 7073944,
                    "user_type": "registered",
                    "accept_rate": 83,
                    "profile_image": "https://i.sstatic.net/BecHV.png?s=256",
                    "display_name": "Vanquished Wombat",
                    "link": "https://stackoverflow.com/users/7073944/vanquished-wombat"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1487155281,
                "post_id": 42245288,
                "comment_id": 71652352,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 1682782,
                    "reputation": 7693,
                    "user_id": 2096986,
                    "user_type": "registered",
                    "accept_rate": 37,
                    "profile_image": "https://www.gravatar.com/avatar/3a02e7c9d317839db7ad17f840320afd?s=256&d=identicon&r=PG",
                    "display_name": "Felipe",
                    "link": "https://stackoverflow.com/users/2096986/felipe"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1487158168,
                "post_id": 42245288,
                "comment_id": 71654422,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 190,
                "is_accepted": true,
                "score": 189,
                "last_activity_date": 1670939167,
                "last_edit_date": 1670939167,
                "creation_date": 1487160081,
                "answer_id": 42248841,
                "question_id": 42245288,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The `|= .+ ` part in the filter adds a new element to the existing array. You can use `jq` with filter like:\r\n\r\n    jq &#39;.data.messages[3] |= . + {\r\n          &quot;date&quot;: &quot;2010-01-07T19:55:99.999Z&quot;, \r\n          &quot;xml&quot;: &quot;xml_samplesheet_2017_01_07_run_09.xml&quot;, \r\n          &quot;status&quot;: &quot;OKKK&quot;, \r\n          &quot;message&quot;: &quot;metadata loaded into iRODS successfullyyyyy&quot;\r\n    }&#39; inputJson\r\n\r\nTo avoid using the hardcoded length value `3` and dynamically add a new element, use `. | length` which returns the length, which can be used as the next array index, i.e.,\r\n\r\n    jq &#39;.data.messages[.data.messages| length] |= . + {\r\n          &quot;date&quot;: &quot;2010-01-07T19:55:99.999Z&quot;, \r\n          &quot;xml&quot;: &quot;xml_samplesheet_2017_01_07_run_09.xml&quot;, \r\n          &quot;status&quot;: &quot;OKKK&quot;, \r\n          &quot;message&quot;: &quot;metadata loaded into iRODS successfullyyyyy&quot;\r\n    }&#39; inputJson\r\n\r\n(or) as per peak&#39;s suggestion in the comments, using the `+=` operator alone\r\n\r\n    jq &#39;.data.messages += [{\r\n         &quot;date&quot;: &quot;2010-01-07T19:55:99.999Z&quot;,\r\n         &quot;xml&quot;: &quot;xml_samplesheet_2017_01_07_run_09.xml&quot;, \r\n         &quot;status&quot;: &quot;OKKK&quot;, \r\n         &quot;message&quot;: &quot;metadata loaded into iRODS successfullyyyyy&quot;\r\n    }]&#39;\r\n\r\nwhich produces the output you need:\r\n\r\n    {\r\n      &quot;report&quot;: &quot;1.0&quot;,\r\n      &quot;data&quot;: {\r\n        &quot;date&quot;: &quot;2010-01-07&quot;,\r\n        &quot;messages&quot;: [\r\n          {\r\n            &quot;date&quot;: &quot;2010-01-07T19:58:42.949Z&quot;,\r\n            &quot;xml&quot;: &quot;xml_samplesheet_2017_01_07_run_09.xml&quot;,\r\n            &quot;status&quot;: &quot;OK&quot;,\r\n            &quot;message&quot;: &quot;metadata loaded into iRODS successfully&quot;\r\n          },\r\n          {\r\n            &quot;date&quot;: &quot;2010-01-07T20:22:46.949Z&quot;,\r\n            &quot;xml&quot;: &quot;xml_samplesheet_2017_01_07_run_09.xml&quot;,\r\n            &quot;status&quot;: &quot;NOK&quot;,\r\n            &quot;message&quot;: &quot;metadata duplicated into iRODS&quot;\r\n          },\r\n          {\r\n            &quot;date&quot;: &quot;2010-01-07T22:11:55.949Z&quot;,\r\n            &quot;xml&quot;: &quot;xml_samplesheet_2017_01_07_run_09.xml&quot;,\r\n            &quot;status&quot;: &quot;NOK&quot;,\r\n            &quot;message&quot;: &quot;metadata was not validated by XSD schema&quot;\r\n          },\r\n          {\r\n            &quot;date&quot;: &quot;2010-01-07T19:55:99.999Z&quot;,\r\n            &quot;xml&quot;: &quot;xml_samplesheet_2017_01_07_run_09.xml&quot;,\r\n            &quot;status&quot;: &quot;OKKK&quot;,\r\n            &quot;message&quot;: &quot;metadata loaded into iRODS successfullyyyyy&quot;\r\n          }\r\n        ]\r\n      }\r\n    }\r\n\r\nUse [jq-play](https://jqplay.org/) to dry-run your `jq-filter` and optimize any way you want.",
                "title": "Add new element to existing JSON array with jq"
            },
            {
                "up_vote_count": 78,
                "is_accepted": false,
                "score": 78,
                "last_activity_date": 1564563042,
                "last_edit_date": 1564563042,
                "creation_date": 1487184636,
                "answer_id": 42257772,
                "question_id": 42245288,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Rather than using `|=`, consider using `+=`:\r\n\r\n    .data.messages += [{&quot;date&quot;: &quot;2010-01-07T19:55:99.999Z&quot;,\r\n       &quot;xml&quot;: &quot;xml_samplesheet_2017_01_07_run_09.xml&quot;,\r\n       &quot;status&quot;: &quot;OKKK&quot;, &quot;message&quot;: &quot;metadata loaded into iRODS successfullyyyyy&quot;}]\r\n\r\n### Prepend\r\nOn the other hand, if (as @NicHuang asked) you want to add the JSON object to the beginning of the array, you could use the pattern:\r\n\r\n     .data.messages |= [ _ ] + .\r\n\r\n \r\n\r\n\r\n",
                "title": "Add new element to existing JSON array with jq"
            },
            {
                "up_vote_count": 58,
                "is_accepted": false,
                "score": 58,
                "last_activity_date": 1566052257,
                "creation_date": 1566052257,
                "answer_id": 57537190,
                "question_id": 42245288,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Summary:   &quot;. +&quot;  is your saviour\r\n\r\nDetails: \r\n\r\nFor adding an entry to a list: You can append [list1] + [list2]  (and not [list]  + data)\r\n\r\n    $ echo &#39;[ &quot;data1&quot; ]&#39; | jq &#39;. + [ &quot;data2&quot; ]&#39;\r\n    [\r\n      &quot;data1&quot;,\r\n      &quot;data2&quot;\r\n    ]\r\n\r\n    $ echo &#39;[ {&quot;key1&quot;: &quot;value1&quot;} ]&#39; | jq &#39;. + [{&quot;key2&quot;: &quot;value2&quot;}]&#39;\r\n    [\r\n      {\r\n        &quot;key1&quot;: &quot;value1&quot;\r\n      },\r\n      {\r\n        &quot;key2&quot;: &quot;value2&quot;\r\n      }\r\n    ]\r\n\r\n\r\nFor adding a key/value to a dictionary:\r\n\r\n    $ echo &#39;{&quot;key1&quot;: &quot;value1&quot;}&#39; | jq &#39;. + {&quot;key2&quot;: &quot;value2&quot;}&#39;\r\n    {\r\n      &quot;key1&quot;: &quot;value1&quot;,\r\n      &quot;key2&quot;: &quot;value2&quot;\r\n    }\r\n\r\n\r\nReferences:\r\n\r\nhttps://gist.github.com/joar/776b7d176196592ed5d8\r\n\r\n\r\n\r\n",
                "title": "Add new element to existing JSON array with jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1726024407,
                "creation_date": 1726024407,
                "answer_id": 78971928,
                "question_id": 42245288,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "An alternative syntax is to iterate the existing values together with the new value(s). This is arguably better or worse:\r\n\r\n    .data.messages |= [\r\n        values, to, prepend,\r\n        .[],\r\n        values, to append,\r\n    ]\r\n\r\nAlternatively, if `.data.messages` may be null (nonexistent):\r\n\r\n    .data.messages |= [\r\n        values, to, prepend,\r\n        select(.)[],\r\n        values, to append,\r\n    ]\r\n\r\nExplanation:\r\n\r\n- Every &quot;normal&quot; value in jq is actually an iterator that yields 1 item\r\n- `expr[]` creates an iterator that yields all items in `expr`\r\n- `value, expr[]` joins the two iterators together, i.e. chaining `value` before `expr`\r\n- `select(.)` creates an iterator that yields 0 item if `.` is converted to false, which is the case for `null` and `[]`. It only yields something when the list is non-empty.\r\n- `select(.)[]` together yields the items if `.` is a non-null iterable value.",
                "title": "Add new element to existing JSON array with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": 131,
        "last_activity_date": 1726024407,
        "creation_date": 1487150672,
        "last_edit_date": 1613709187,
        "question_id": 42245288,
        "body_markdown": "I want to append an element to an array in a JSON file using the `jq``add` command, but it&#39;s not working. \r\n\r\n`report-2017-01-07.json` file:\r\n\r\n    {  \r\n       &quot;report&quot;: &quot;1.0&quot;,\r\n       &quot;data&quot;: {  \r\n          &quot;date&quot;: &quot;2010-01-07&quot;,\r\n          &quot;messages&quot;: [  \r\n             {  \r\n                &quot;date&quot;: &quot;2010-01-07T19:58:42.949Z&quot;,\r\n                &quot;xml&quot;: &quot;xml_samplesheet_2017_01_07_run_09.xml&quot;,\r\n                &quot;status&quot;: &quot;OK&quot;,\r\n                &quot;message&quot;: &quot;metadata loaded into iRODS successfully&quot;\r\n             },\r\n             {  \r\n                &quot;date&quot;: &quot;2010-01-07T20:22:46.949Z&quot;,\r\n                &quot;xml&quot;: &quot;xml_samplesheet_2017_01_07_run_09.xml&quot;,\r\n                &quot;status&quot;: &quot;NOK&quot;,\r\n                &quot;message&quot;: &quot;metadata duplicated into iRODS&quot;\r\n             },\r\n             {  \r\n                &quot;date&quot;: &quot;2010-01-07T22:11:55.949Z&quot;,\r\n                &quot;xml&quot;: &quot;xml_samplesheet_2017_01_07_run_09.xml&quot;,\r\n                &quot;status&quot;: &quot;NOK&quot;,\r\n                &quot;message&quot;: &quot;metadata was not validated by XSD schema&quot;\r\n             }\r\n          ]\r\n       }\r\n    }\r\n\r\n\r\n\r\nI am using this command:\r\n\r\n    $ cat report-2017-01-07.json \r\n    | jq -s &#39;.data.messages {&quot;date&quot;: &quot;2010-01-07T19:55:99.999Z&quot;, &quot;xml&quot;: &quot;xml_samplesheet_2017_01_07_run_09.xml&quot;, &quot;status&quot;: &quot;OKKK&quot;, &quot;message&quot;: &quot;metadata loaded into iRODS successfullyyyyy&quot;}&#39;\r\n    jq: error: syntax error, unexpected &#39;{&#39;, expecting $end (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n    .data.messages {&quot;date&quot;: &quot;2010-01-07T19:55:99.999Z&quot;, &quot;xml&quot;: &quot;xml_samplesheet_2017_01_07_run_09.xml&quot;, &quot;status&quot;: &quot;OKKK&quot;, &quot;message&quot;: &quot;metadata loaded into iRODS successfullyyyyy&quot;}               \r\n    jq: 1 compile error\r\n\r\n\r\nHere&#39;s how I want the output to look:\r\n\r\n    {\r\n        &quot;report&quot;: &quot;1.0&quot;,\r\n        &quot;data&quot;: {\r\n            &quot;date&quot;: &quot;2010-01-07&quot;,\r\n            &quot;messages&quot;: [{\r\n                &quot;date&quot;: &quot;2010-01-07T19:58:42.949Z&quot;,\r\n                &quot;xml&quot;: &quot;xml_samplesheet_2017_01_07_run_09.xml&quot;,\r\n                &quot;status&quot;: &quot;OK&quot;,\r\n                &quot;message&quot;: &quot;metadata loaded into iRODS successfully&quot;\r\n            }, {\r\n                &quot;date&quot;: &quot;2010-01-07T20:22:46.949Z&quot;,\r\n                &quot;xml&quot;: &quot;xml_samplesheet_2017_01_07_run_09.xml&quot;,\r\n                &quot;status&quot;: &quot;NOK&quot;,\r\n                &quot;message&quot;: &quot;metadata duplicated into iRODS&quot;\r\n            }, {\r\n                &quot;date&quot;: &quot;2010-01-07T22:11:55.949Z&quot;,\r\n                &quot;xml&quot;: &quot;xml_samplesheet_2017_01_07_run_09.xml&quot;,\r\n                &quot;status&quot;: &quot;NOK&quot;,\r\n                &quot;message&quot;: &quot;metadata was not validated by XSD schema&quot;\r\n            }, {\r\n                &quot;date&quot;: &quot;2010-01-07T19:55:99.999Z&quot;,\r\n                &quot;xml&quot;: &quot;xml_samplesheet_2017_01_07_run_09.xml&quot;,\r\n                &quot;status&quot;: &quot;OKKKKKKK&quot;,\r\n                &quot;message&quot;: &quot;metadata loaded into iRODS successfullyyyyy&quot;\r\n            }]\r\n        }\r\n    }",
        "link": "https://stackoverflow.com/questions/42245288/add-new-element-to-existing-json-array-with-jq",
        "title": "Add new element to existing JSON array with jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1487202434,
                "creation_date": 1487202434,
                "answer_id": 42262263,
                "question_id": 42261911,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "jq 1.3 is ancient so the solution using that version is rather inelegant.  Perhaps the best approach would be to &quot;slurp&quot; the two files:\r\n\r\n    jq1.3 -s &#39;.[1] as $o | .[0] | .modules.a = $o&#39; exhibit-a.json exhibit-b.json\r\n\r\nThis will work with later versions as well, but for comparison, using jq 1.4 or later, one could write:\r\n\r\n    jq --argfile modules exhibit-a.json &#39;\r\n      . as $in | $modules | .modules.a = $in&#39; exhibit-b.json",
                "title": "Merge Object at a given Location?"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1487202434,
        "creation_date": 1487200487,
        "question_id": 42261911,
        "body_markdown": "I have the following objects:\r\n\r\n    // exhibit a\r\n    {\r\n      &quot;exported_modules&quot;: [&quot;a&quot;, &quot;b&quot;]\r\n    }\r\n    // exhibit b\r\n    {\r\n      &quot;name&quot;: &quot;thing b&quot;\r\n    }\r\n\r\nThey exist in separate files. I need to basically transform them such that they are output unified in the following state:\r\n\r\n    {\r\n      &quot;exported_modules&quot;: [&quot;a&quot;, &quot;b&quot;],\r\n      &quot;modules&quot;: {\r\n        &quot;a&quot;: {\r\n          &quot;name&quot;: &quot;thing b&quot;\r\n        }\r\n     }\r\n    }\r\n\r\nEssentially I need to insert the contents of exhibit b into `.modules.a`. Is there a way to do this in jq? I&#39;m on `jq` 1.3 unfortunately, which is provided by my distribution.\r\n\r\nI have been trying [what has been recommended here](https://stackoverflow.com/questions/19529688/how-to-merge-2-json-file-using-jq#24904276) but I have not been able to merge into a specific location rather than just merge all keys.",
        "link": "https://stackoverflow.com/questions/42261911/merge-object-at-a-given-location",
        "title": "Merge Object at a given Location?"
    },
    {
        "tags": [
            "python",
            "windows",
            "python-2.7",
            "pip",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 5626253,
                    "reputation": 3736,
                    "user_id": 4454597,
                    "user_type": "registered",
                    "accept_rate": 57,
                    "profile_image": "https://graph.facebook.com/100000586402967/picture?type=large",
                    "display_name": "Anton Khodak",
                    "link": "https://stackoverflow.com/users/4454597/anton-khodak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1510784749,
                "post_id": 42262960,
                "comment_id": 81587885,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 13,
                "is_accepted": false,
                "score": 10,
                "last_activity_date": 1556128974,
                "last_edit_date": 1592644375,
                "creation_date": 1523979399,
                "answer_id": 49882213,
                "question_id": 42262960,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "### Installing via `pip`\n\nAs per [`jq` installation steps][1] for `pip`&#39;s project:\n\n&gt; Installation requires any programs required to build `jq`. This includes:\n&gt;\n&gt; - Autoreconf\n&gt;\n&gt; - The normal C compiler toolchain, such as gcc and make.\n&gt;\n&gt; - `libtool`\n&gt;\n&gt; - Python headers.\n\n### macOS\n\nOn macOS, you need XCode to be installed, and the following packages:\n\n    brew install autoconf automake libtool\n    brew install jq\n\n### Linux\n\nYou need the following packages to be installed:\n\n    yum install autoconf automake libtool python\n\n  [1]: https://pypi.org/project/jq/",
                "title": "&quot;pip install jq&quot; generates errors on Mac and Windows"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1683912939,
                "creation_date": 1683912939,
                "answer_id": 76238739,
                "question_id": 42262960,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To install the `jq` Python module on Windows, you can follow these steps:\r\n\r\n1. Install `jq` executable:\r\n   - Download the Windows executable for `jq` from the official repository: https://github.com/stedolan/jq/releases.\r\n   - Choose the appropriate version (e.g., `jq-win64.exe` for 64-bit Windows).\r\n   - Save the executable file to a location on your computer (e.g., `C:\\jq\\jq-win64.exe`).\r\n\r\n2. Add `jq` executable to the system&#39;s PATH:\r\n   - Press `Win + X` and select &quot;System&quot; or &quot;System Properties.&quot;\r\n   - Click on &quot;Advanced system settings&quot; on the left.\r\n   - In the &quot;System Properties&quot; window, click on the &quot;Environment Variables&quot; button.\r\n   - In the &quot;Environment Variables&quot; dialog, locate the &quot;Path&quot; variable in the &quot;System variables&quot; section and select it.\r\n   - Click on the &quot;Edit&quot; button.\r\n   - Click on the &quot;New&quot; button and enter the directory path where the `jq` executable is located (e.g., `C:\\jq`).\r\n   - Click &quot;OK&quot; on all open dialogs to save the changes.\r\n",
                "title": "&quot;pip install jq&quot; generates errors on Mac and Windows"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1718168581,
                "creation_date": 1718168581,
                "answer_id": 78610702,
                "question_id": 42262960,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "There&#39;s a wheel available for `jq` at https://jeffreyknockel.com/jq/. The author mentions that there are not many tests done on this yet . So, if you do choose to work with it, it&#39;s at your own risks. Been using it, so far, no issue. How to go about it?\r\n- Download the `.whl`file matching your Python version\r\n- Install it: \r\n  ```bash\r\n     pip install [PATH TO .WHL FILE]\r\n  ```\r\nRef: https://github.com/mwilliamson/jq.py/issues/20#issuecomment-1411157736",
                "title": "&quot;pip install jq&quot; generates errors on Mac and Windows"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 16,
        "last_activity_date": 1718168581,
        "creation_date": 1487206766,
        "last_edit_date": 1523973662,
        "question_id": 42262960,
        "body_markdown": "Duplicate of this [issue][1], but the first answer there is wrong (`jq` is supported on Windows) and the second refers to `brew` so I&#39;m guessing is for Mac.\r\n\r\n### Windows\r\n\r\nI am trying to install `jq` for python from the Windows command line, but get the following errors, possibly due to a missing `temp\\pip-build-rtnhmg\\jq\\onig-install-5.9.6` file:\r\n`error: [Error 2] The system cannot find the file specified`\r\n... and ...\r\n\r\n&gt; `Command &quot;c:\\python27\\python.exe -u -c &quot;import setuptools, tokenize;__file__=&#39;c:\\\\users\\\\&lt;USERNAME&gt;\\\\appdata\\\\local\\\\temp\\\\pip-build-rtnhmg\\\\jq\\\\setup.py&#39;;f=getattr(tokenize, &#39;open&#39;, open)(__file__);code=f.read().replace(&#39;\\r\\n&#39;, &#39;\\n&#39;);f.close();exec(compile(code, __file__, &#39;exec&#39;))&quot; install --record c:\\users\\&lt;USERNAME&gt;\\appdata\\local\\temp\\pip-khvjht-record\\install-record.txt --single-version-externally-managed --compile&quot; failed with error code 1 in c:\\users\\&lt;USERNAME&gt;\\appdata\\local\\temp\\pip-build-rtnhmg\\jq\\`\r\n\r\nDoes anyone know what&#39;s gone wrong here?  Searches on StackOverflow and Google aren&#39;t giving me much to go on, and I&#39;m not great with Windows and still new to python/pip.\r\n\r\nHere is the full text, minus username:\r\n\r\n    Microsoft Windows [Version 10.0.14393]\r\n    (c) 2016 Microsoft Corporation. All rights reserved.\r\n    \r\n    C:\\WINDOWS\\system32&gt;pip install jq\r\n    Collecting jq\r\n      Using cached jq-0.1.6.tar.gz\r\n    Building wheels for collected packages: jq\r\n      Running setup.py bdist_wheel for jq ... error\r\n      Complete output from command c:\\python27\\python.exe -u -c &quot;import setuptools, tokenize;__file__=&#39;c:\\\\users\\\\&lt;USERNAME&gt;\\\\appdata\\\\local\\\\temp\\\\pip-build-rtnhmg\\\\jq\\\\setup.py&#39;;f=getattr(tokenize, &#39;open&#39;, open)(__file__);code=f.read().replace(&#39;\\r\\n&#39;, &#39;\\n&#39;);f.close();exec(compile(code, __file__, &#39;exec&#39;))&quot; bdist_wheel -d c:\\users\\&lt;USERNAME&gt;\\appdata\\local\\temp\\tmpuvrf_upip-wheel- --python-tag cp27:\r\n      running bdist_wheel\r\n      running build\r\n      running build_ext\r\n      Executing: ./configure CFLAGS=-fPIC --prefix=c:\\users\\&lt;USERNAME&gt;\\appdata\\local\\temp\\pip-build-rtnhmg\\jq\\onig-install-5.9.6\r\n      error: [Error 2] The system cannot find the file specified\r\n    \r\n      ----------------------------------------\r\n      Failed building wheel for jq\r\n      Running setup.py clean for jq\r\n    Failed to build jq\r\n    Installing collected packages: jq\r\n      Running setup.py install for jq ... error\r\n        Complete output from command c:\\python27\\python.exe -u -c &quot;import setuptools, tokenize;__file__=&#39;c:\\\\users\\\\&lt;USERNAME&gt;\\\\appdata\\\\local\\\\temp\\\\pip-build-rtnhmg\\\\jq\\\\setup.py&#39;;f=getattr(tokenize, &#39;open&#39;, open)(__file__);code=f.read().replace(&#39;\\r\\n&#39;, &#39;\\n&#39;);f.close();exec(compile(code, __file__, &#39;exec&#39;))&quot; install --record c:\\users\\&lt;USERNAME&gt;\\appdata\\local\\temp\\pip-khvjht-record\\install-record.txt --single-version-externally-managed --compile:\r\n        running install\r\n        running build\r\n        running build_ext\r\n        Executing: ./configure CFLAGS=-fPIC --prefix=c:\\users\\&lt;USERNAME&gt;\\appdata\\local\\temp\\pip-build-rtnhmg\\jq\\onig-install-5.9.6\r\n        error: [Error 2] The system cannot find the file specified\r\n    \r\n        ----------------------------------------\r\n    Command &quot;c:\\python27\\python.exe -u -c &quot;import setuptools, tokenize;__file__=&#39;c:\\\\users\\\\&lt;USERNAME&gt;\\\\appdata\\\\local\\\\temp\\\\pip-build-rtnhmg\\\\jq\\\\setup.py&#39;;f=getattr(tokenize, &#39;open&#39;, open)(__file__);code=f.read().replace(&#39;\\r\\n&#39;, &#39;\\n&#39;);f.close();exec(compile(code, __file__, &#39;exec&#39;))&quot; install --record c:\\users\\&lt;USERNAME&gt;\\appdata\\local\\temp\\pip-khvjht-record\\install-record.txt --single-version-externally-managed --compile&quot; failed with error code 1 in c:\\users\\&lt;USERNAME&gt;\\appdata\\local\\temp\\pip-build-rtnhmg\\jq\\\r\n\r\nTrying to install pyjq instead generates the same errors.\r\n\r\nI&#39;m not married to jq: I just need to format json data in python, and jq does a great job on the command line.  If there are other python packages I should try instead, please feel free to recommend them.  As mentioned above though, pyjq is failing install with the same errors.\r\n\r\n \r\n\r\n**Further details / steps taken:**\r\n\r\n - I am on Windows 10 and have installed python 2.7.13, `setuptools` and `pip` using [the steps from here](http://docs.python-guide.org/en/latest/starting/install/win/) ... no issues noted.\r\n - Using pip, I have successfully installed other python packages such as request and jira ... no issues noted.\r\n - Using chocolatey I have successfully installed jq for the command line, following [these steps](https://github.com/stedolan/jq/wiki/Installation) ... no issues noted.\r\n - I have tried using regular permissions, running cmd as administrator, starting a new cmd session, restarting the PC - but get the same errors.\r\n - Trying to install pyjq (`pip install pyjq`) generates the same errors.\r\n - Tried `pip install jq` on a Mac and got similar errors:\r\n\r\n    &gt; `Command &quot;/usr/local/opt/python/bin/python2.7 -u -c &quot;import setuptools, tokenize;__file__=&#39;/private/var/folders/v5/4x0py0ns2td1h69vgllx7dpr0000gn/T/pip-build-DyMoT4/jq/setup.py&#39;;f=getattr(tokenize, &#39;open&#39;, open)(__file__);code=f.read().replace(&#39;\\r\\n&#39;, &#39;\\n&#39;);f.close();exec(compile(code, __file__, &#39;exec&#39;))&quot; install --record /var/folders/v5/4x0py0ns2td1h69vgllx7dpr0000gn/T/pip-i6UKvt-record/install-record.txt --single-version-externally-managed --compile&quot; failed with error code 1 in /private/var/folders/v5/4x0py0ns2td1h69vgllx7dpr0000gn/T/pip-build-DyMoT4/jq/`\r\n\r\n - for the Mac, followed the steps suggested from [here][2] and successfully installed `setuptools` as suggested, but `pip install jq` still fails with the same error.\r\n\r\n  [1]: https://stackoverflow.com/questions/39785890/unable-to-install-jq-via-pip\r\n  [2]: https://stackoverflow.com/questions/31498495/error-when-installing-using-pip",
        "link": "https://stackoverflow.com/questions/42262960/pip-install-jq-generates-errors-on-mac-and-windows",
        "title": "&quot;pip install jq&quot; generates errors on Mac and Windows"
    },
    {
        "tags": [
            "csv",
            "export-to-csv",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1487227557,
                "creation_date": 1487227557,
                "answer_id": 42266774,
                "question_id": 42266468,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Easy!\r\n\r\n    $ jq -r @csv input.json \r\n    2.294891,48.875284\r\n    -2.14908,53.281214\r\n    1.963667,48.768891\r\n    -3.739434,40.390413\r\n\r\nBeware, though, that the precision may differ (or in general, be lost). ",
                "title": "convert output of jq from list of lists to delimited string"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1572692957,
        "creation_date": 1487226386,
        "last_edit_date": 1572692957,
        "question_id": 42266468,
        "body_markdown": "I have a json file which I&#39;m outputing two numbers (lat/lon) and the output now is \r\n\r\n    [\r\n      2.294891,\r\n      48.875284\r\n    ]\r\n    [\r\n      -2.14908,\r\n      53.281214\r\n    ]\r\n    [\r\n      1.963667,\r\n      48.768891\r\n    ]\r\n    [\r\n      -3.739434,\r\n      40.390413\r\n    ]\r\n\r\nwhat I want is the numbers to become strings and be concatenated like \r\n\r\n    2.294891,48.875284\r\n    -2.14908,53.281214\r\n    ...\r\n\r\nbut I don&#39;t know how to do it with jq.\r\n\r\n**Update:**\r\n\r\nI could convert the output to \r\n\r\n    [2.294891,48.875284]\r\n    [-2.14908,53.281214]\r\n    [1.963667,48.768891]\r\n\r\nwith -c argument and use tr -d [ | tr -d ] in the pipe to remove the brackets but I&#39;m sure there is a more elegant way of doing it.\r\n\r\n",
        "link": "https://stackoverflow.com/questions/42266468/convert-output-of-jq-from-list-of-lists-to-delimited-string",
        "title": "convert output of jq from list of lists to delimited string"
    },
    {
        "tags": [
            "json",
            "bash",
            "shell",
            "sh",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1487330949,
                "post_id": 42296559,
                "comment_id": 71748295,
                "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": 1487331918,
                "post_id": 42296559,
                "comment_id": 71748878,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1487331632,
                "creation_date": 1487331632,
                "answer_id": 42297015,
                "question_id": 42296559,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Pass the argument `$REPORT` as a `json` argument using the [`--argjson`](https://stedolan.github.io/jq/manual/) flag supported from `jq-1.5` onwards,\r\n\r\n&gt;     --argjson name JSON-text:    \r\n&gt;     This option passes a JSON-encoded value to the jq program as a predefined variable. \r\n\r\nChange your line to,\r\n\r\n    jq --argjson args &quot;$REPORT&quot; &#39;.data.messages += [$args]&#39; file",
                "title": "update json with jq through shell script"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1487332759,
                "creation_date": 1487332759,
                "answer_id": 42297427,
                "question_id": 42296559,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Thanks @Inian. I changed a little bit but worked.... here is the solution.\r\n    \r\n    if [ &quot;$#&quot; -eq 7 ]; then\r\n    \tif [ &quot;$OPER&quot; == &quot;update&quot; ]; then\r\n    \t\techo &quot;update Json&quot;\r\n                    echo &quot;FILE_PATH: $FILE_PATH - CSV: $CSV - STEP: $STEP - STATUS: $STATUS - CODE: $CODE - MESSAGE: $MESSAGE&quot;\r\n    \t\tREPORT=&quot;{\\&quot;timestamp\\&quot;: \\&quot;$DATE_TIME\\&quot;, \\&quot;step\\&quot;: \\&quot;$STEP\\&quot;, \\&quot;status\\&quot;: \\&quot;$STATUS\\&quot;, \\&quot;code\\&quot;: \\&quot;$CODE\\&quot;, \\&quot;message\\&quot;: \\&quot;$MESSAGE\\&quot;}&quot;\r\n    \t\techo &quot;REPORTTTTT: &quot;$REPORT\r\n    \t\techo `jq --argjson args &quot;$REPORT&quot; &#39;.data.messages += [$args]&#39; $FILE_PATH` &gt; $FILE_PATH\r\n    \telse\r\n    \t\techo &quot;operation not recognized: $OPER&quot;\r\n    \tfi\r\n    else\r\n            echo &quot;wrong parameters.&quot;\r\n    fi",
                "title": "update json with jq through shell script"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1487369322,
                "last_edit_date": 1487369322,
                "creation_date": 1487368818,
                "answer_id": 42308136,
                "question_id": 42296559,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Don&#39;t generate JSON by hand; let `jq` do it. This is important if the values you want to add to the JSON need to be quoted properly, which will not happen if you are just performing string interpolation in the shell:\r\n\r\n    $ foo=&#39;&quot;hi&quot; he said&#39;\r\n    $ json=&quot;{ \\&quot;text\\&quot;: \\&quot;$foo\\&quot; }&quot;  \r\n    $ echo &quot;$json&quot;\r\n    { &quot;text&quot;: &quot;&quot;hi&quot; he said&quot; }  # Wrong: should be { &quot;text&quot;: &quot;\\&quot;hi\\&quot; he said&quot; }\r\n\r\n Further, `jq` can generate the date and time strings; there is no need to run `date` (twice) as well.\r\n\r\n    #!/bin/sh\r\n    \r\n    if [ $# -eq 7 ]; then\r\n      printf &quot;Wrong number of parameters: %d\\n&quot; &quot;$#&quot; &gt;&amp;2\r\n      exit 1\r\n    fi\r\n    \r\n    oper=$1 file_path=$2\r\n    \r\n    # Generate the new message using arguments 3-7\r\n    new_message=$(\r\n      jq -n --arg csv &quot;$3&quot; --arg step &quot;$4&quot; \\\r\n            --arg status &quot;$5&quot; --arg code &quot;$6&quot; \\\r\n            --arg message &quot;$7&quot; &#39;{\r\n      timestamp: now|strftime(&quot;%F:%T&quot;),\r\n      csv: $csv, step: $step, status: $status, code: $code, message: $message}&#39;\r\n    )\r\n    \r\n    case $oper in\r\n      create)\r\n        jq -n --argjson new_msg &quot;$new_message&quot; --arg csv &quot;$3&quot; &#39;{\r\n          date: now|strftime(&quot;%F&quot;),\r\n          csv: $csv,\r\n          messages: [ $new_msg ]\r\n        }&#39; &gt; &quot;$file_path&quot;\r\n        ;;\r\n    \r\n      update)\r\n        jq --argjson new_msg &quot;$new_message&quot; \\\r\n           &#39;.messages += [ $new_msg ]&#39; \\\r\n           &quot;$file_path&quot; &gt; &quot;$file_path.tmp&quot; &amp;&amp; mv &quot;$file_path.tmp&quot; &quot;$file_path&quot; ;;\r\n    \r\n      *) printf &#39;operation not recognized: %s\\n&#39; &quot;$oper&quot; &gt;&amp;2\r\n         exit 1 ;;\r\n    esac\r\n    jq &#39;.&#39; &quot;$file_path&quot;",
                "title": "update json with jq through shell script"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1556721251,
        "creation_date": 1487330198,
        "last_edit_date": 1556721251,
        "question_id": 42296559,
        "body_markdown": "I created a shell script to create and update json files using jq. To create json files is working well. I have a variable that is passed as argument to jq command\r\n\r\n    #!/bin/sh\r\n    OPER=$1\r\n    FILE_PATH=$2\r\n    DATE_TIME=`date +%Y-%m-%d:%H:%M:%S`\r\n    DATE=`date +%Y-%m-%d`\r\n    CSV=$3\r\n    STEP=$4\r\n    STATUS=$5\r\n    CODE=$6\r\n    MESSAGE=$7\r\n    \r\n    if [ &quot;$#&quot; -eq 7 ]; then\r\n    \tif [ &quot;$OPER&quot; == &quot;create&quot; ]; then\r\n    \t\t# echo &quot;FILE_PATH: $FILE_PATH - CSV: $CSV - STEP: $STEP - STATUS: $STATUS - CODE: $CODE - MESSAGE: $MESSAGE&quot;\r\n    \t\tREPORT=&quot;{\\&quot;date\\&quot;: \\&quot;$DATE\\&quot;, \\&quot;csv\\&quot;: \\&quot;$CSV\\&quot;, \\&quot;messages\\&quot;: [{ \\&quot;timestamp\\&quot;: \\&quot;$DATE_TIME\\&quot;, \\&quot;step\\&quot;: \\&quot;$STEP\\&quot;, \\&quot;status\\&quot;: \\&quot;$STATUS\\&quot;, \\&quot;code\\&quot;: \\&quot;$CODE\\&quot;, \\&quot;message\\&quot;: \\&quot;$MESSAGE\\&quot; }] }&quot;\r\n    \t\techo ${REPORT} | jq . &gt; $FILE_PATH\r\n    \telif [ &quot;$OPER&quot; == &quot;update&quot; ]; then\r\n                    echo &quot;FILE_PATH: $FILE_PATH - CSV: $CSV - STEP: $STEP - STATUS: $STATUS - CODE: $CODE - MESSAGE: $MESSAGE&quot;\r\n    \t\tREPORT=&quot;{\\&quot;timestamp\\&quot;: \\&quot;$DATE_TIME\\&quot;, \\&quot;step\\&quot;: \\&quot;$STEP\\&quot;, \\&quot;status\\&quot;: \\&quot;$STATUS\\&quot;, \\&quot;code\\&quot;: \\&quot;$CODE\\&quot;, \\&quot;message\\&quot;: \\&quot;$MESSAGE\\&quot;}&quot;\r\n    \t\techo &quot;REPORTTTTT: &quot;$REPORT\r\n    \t\tREPORT=&quot;jq &#39;.messages[.messages| length] |= . + $REPORT&#39; $FILE_PATH&quot;\r\n    \t\t#echo $REPORT\r\n    \t\techo `jq &#39;.messages[.messages| length] |= . + $REPORT&#39; $FILE_PATH` &gt; $FILE_PATH\r\n    \telse\r\n    \t\techo &quot;operation not recognized: $OPER&quot;\r\n    \tfi\r\n    else\r\n            echo &quot;wrong parameters.&quot;\r\n    fi\r\n    jq . $FILE_PATH\r\n\r\nBut to update the json file I am getting an error. My $REPORT variable is correct. The cotes are correct. I think I must use another jq argument instead of `|= . +`. I used that command with plain text and it worked. But when I create the REPORT variable dynamically it throws an error.\r\n\r\nAny clue? Thanks\r\n\r\n    REPORTTTTT: {&quot;timestamp&quot;: &quot;2017-02-17:12:11:11&quot;, &quot;step&quot;: &quot;2&quot;, &quot;status&quot;: &quot;OK&quot;, &quot;code&quot;: &quot;34&quot;, &quot;message&quot;: &quot;message 34 file.xml&quot;}\r\n    jq: error: syntax error, unexpected INVALID_CHARACTER, expecting $end (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n    &#39;.messages[.messages|\r\n    jq: 1 compile error\r\n    \r\n    jq: error: REPORT/0 is not defined at &lt;top-level&gt;, line 1:\r\n    .messages[.messages| length] |= . + $REPORT                                    \r\n    jq: 1 compile error\r\n\r\nHere is the example at the command line&gt;&gt;\r\n\r\n    $ jq . file.json \r\n    {\r\n      &quot;date&quot;: &quot;2017-02-17&quot;,\r\n      &quot;csv&quot;: &quot;file.csv&quot;,\r\n      &quot;messages&quot;: [\r\n        {\r\n          &quot;timestamp&quot;: &quot;2017-02-17:12:31:21&quot;,\r\n          &quot;step&quot;: &quot;1&quot;,\r\n          &quot;status&quot;: &quot;OK&quot;,\r\n          &quot;code&quot;: &quot;33&quot;,\r\n          &quot;message&quot;: &quot;message 33&quot;\r\n        }\r\n      ]\r\n    }\r\n    $ export REPORT=&quot;{\\&quot;timestamp\\&quot;: \\&quot;2017-02-17:11:51:14\\&quot;, \\&quot;step\\&quot;: \\&quot;2\\&quot;, \\&quot;status\\&quot;: \\&quot;OK\\&quot;, \\&quot;code\\&quot;: \\&quot;34\\&quot;, \\&quot;message\\&quot;: \\&quot;message 34 file.xml\\&quot;}&quot;\r\n    $ echo $REPORT\r\n    {&quot;timestamp&quot;: &quot;2017-02-17:11:51:14&quot;, &quot;step&quot;: &quot;2&quot;, &quot;status&quot;: &quot;OK&quot;, &quot;code&quot;: &quot;34&quot;, &quot;message&quot;: &quot;message 34 file.xml&quot;}\r\n    $ jq &#39;.messages[.messages| length] |= . + $REPORT&#39; file.json \r\n    jq: error: REPORT/0 is not defined at &lt;top-level&gt;, line 1:\r\n    .messages[.messages| length] |= . + $REPORT                                    \r\n    jq: 1 compile error\r\n\r\n",
        "link": "https://stackoverflow.com/questions/42296559/update-json-with-jq-through-shell-script",
        "title": "update json with jq through shell script"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 19,
                "is_accepted": true,
                "score": 19,
                "last_activity_date": 1539890649,
                "last_edit_date": 1539890649,
                "creation_date": 1487351977,
                "answer_id": 42303836,
                "question_id": 42299905,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you stream the data in, you&#39;ll get pairings of paths and values of all leaf values.  If not a pair, then a path marking the end of a definition of an object/array at that path.  Using `leaf_paths` as you found would only give you paths to truthy leaf values so you&#39;ll miss out on `null` or even `false` values. As a stream, you won&#39;t get this problem.\r\n\r\nThere are many ways this could be combined to an object, I&#39;m partial to using `reduce` and assignment in these situations.\r\n\r\n    $ cat input.json\r\n    {&quot;a&quot;:{&quot;b&quot;:[&quot;p q r&quot;]},&quot;w&quot;:[{&quot;x&quot;:null},{&quot;y&quot;:false},{&quot;z&quot;:3}]}\r\n\r\n    $ jq --arg delim &#39;.&#39; &#39;reduce (tostream|select(length==2)) as $i ({};\r\n        .[[$i[0][]|tostring]|join($delim)] = $i[1]\r\n    )&#39; input.json\r\n    {\r\n      &quot;a.b.0&quot;: &quot;p q r&quot;,\r\n      &quot;w.0.x&quot;: null,\r\n      &quot;w.1.y&quot;: false,\r\n      &quot;w.2.z&quot;: 3\r\n    }\r\n\r\n&lt;hr&gt;\r\n\r\nHere&#39;s the same solution broken up a bit to allow room for explanation of what&#39;s going on.\r\n\r\n    $ jq --arg delim &#39;.&#39; &#39;reduce (tostream|select(length==2)) as $i ({};\r\n        [$i[0][]|tostring] as $path_as_strings\r\n            | ($path_as_strings|join($delim)) as $key\r\n            | $i[1] as $value\r\n            | .[$key] = $value\r\n    )&#39; input.json\r\n\r\nConverting the input to a stream with `tostream`, we&#39;ll receive multiple values of pairs/paths as input to our filter.  With this, we can pass those multiple values into `reduce` which is designed to accept multiple values and do something with them.  But before we do, we want to filter those pairs/paths by only the pairs (`select(length==2)`).\r\n\r\nThen in the reduce call, we&#39;re starting with a clean object and assigning new values using a key derived from the path and the corresponding value. Remember that every value produced in the `reduce` call is used for the next value in the iteration.  Binding values to variables doesn&#39;t change the current context and assignments effectively &quot;modify&quot; the current value (the initial object) and passes it along.\r\n\r\n`$path_as_strings` is just the path which is an array of strings and numbers to just strings.  `[$i[0][]|tostring]` is a shorthand I use as an alternative to using `map` when the array I want to map is not the current array.  This is more compact since the mapping is done as a single expression.  That instead of having to do this to get the same result: `($i[0]|map(tostring))`.  The outer parentheses might not be necessary in general but, it&#39;s still two separate filter expressions vs one (and more text).\r\n\r\nThen from there we convert that array of strings to the desired key using the provided delimiter.  Then assign the appropriate values to the current object.\r\n",
                "title": "Using jq, Flatten Arbitrary JSON to Delimiter-Separated Flat Dictionary"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1552940985,
                "last_edit_date": 1552940985,
                "creation_date": 1487395208,
                "answer_id": 42311360,
                "question_id": 42299905,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The following has been tested with jq 1.4, jq 1.5 and the current &quot;master&quot; version. The requirement about including paths to null and false is the reason for &quot;allpaths&quot; and &quot;all_leaf_paths&quot;. \r\n\r\n    # all paths, including paths to null\r\n    def allpaths:\r\n      def conditional_recurse(f):  def r: ., (select(.!=null) | f | r); r;\r\n      path(conditional_recurse(.[]?)) | select(length &gt; 0);\r\n    \r\n    def all_leaf_paths:\r\n      def isscalar: type | (. != &quot;object&quot; and . != &quot;array&quot;);\r\n      allpaths as $p\r\n      | select(getpath($p)|isscalar)\r\n      | $p ;\r\n    \r\n    \r\n    . as $in \r\n    | reduce all_leaf_paths as $path ({};\r\n         . + { ($path | map(tostring) | join($delim)): $in | getpath($path) })\r\n\r\nWith this jq program in flatten.jq:\r\n\r\n\r\n    $ cat input.json\r\n    {&quot;a&quot;:{&quot;b&quot;:[&quot;p q r&quot;]},&quot;w&quot;:[{&quot;x&quot;:null},{&quot;y&quot;:false},{&quot;z&quot;:3}]}\r\n     \r\n    $ jq --arg delim . -f flatten.jq input.json\r\n    \r\n    {\r\n      &quot;a.b.0&quot;: &quot;p q r&quot;,\r\n      &quot;w.0.x&quot;: null,\r\n      &quot;w.1.y&quot;: false,\r\n      &quot;w.2.z&quot;: 3\r\n    }\r\n\r\n\r\n###Collisions\r\n\r\nHere is a helper function that illustrates an alternative path-flattening algorithm. It converts keys that contain the delimiter to quoted strings, and array elements are presented in square brackets (see the example below):\r\n\r\n    def flattenPath(delim):\r\n      reduce .[] as $s (&quot;&quot;;\r\n        if $s|type == &quot;number&quot; \r\n        then ((if . == &quot;&quot; then &quot;.&quot; else . end) + &quot;[\\($s)]&quot;)\r\n        else . + ($s | tostring | if index(delim) then &quot;\\&quot;\\(.)\\&quot;&quot; else . end)\r\n        end );\r\n\r\nExample: Using `flattenPath` instead of `map(tostring) | join($delim)`, the object:\r\n\r\n     {&quot;a.b&quot;: [1]}\r\n\r\nwould become:\r\n\r\n    {\r\n      &quot;\\&quot;a.b\\&quot;[0]&quot;: 1\r\n    }\r\n\r\n",
                "title": "Using jq, Flatten Arbitrary JSON to Delimiter-Separated Flat Dictionary"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1620922206,
                "creation_date": 1620922206,
                "answer_id": 67522548,
                "question_id": 42299905,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To add a new option to the solutions already given, [jqg](https://github.com/NorthboundTrain/jqg) is a script I wrote to flatten any JSON file and then search it using a regex. For your purposes your regex would simply be &#39;`.`&#39; which would match everything.\r\n\r\n    $ echo &#39;{&quot;a&quot;:{&quot;b&quot;:[1]},&quot;x&quot;:[{&quot;y&quot;:2},{&quot;z&quot;:3}]}&#39; | jqg .\r\n    {\r\n      &quot;a.b.0&quot;: 1,\r\n      &quot;x.0.y&quot;: 2,\r\n      &quot;x.1.z&quot;: 3\r\n    }\r\n\r\nand can produce compact output:\r\n\r\n    $ echo &#39;{&quot;a&quot;:{&quot;b&quot;:[1]},&quot;x&quot;:[{&quot;y&quot;:2},{&quot;z&quot;:3}]}&#39; | jqg -q -c .\r\n    {&quot;a.b.0&quot;:1,&quot;x.0.y&quot;:2,&quot;x.1.z&quot;:3}\r\n\r\nIt also handles the more complicated example that @peak used:\r\n\r\n    $ echo &#39;{&quot;a&quot;:{&quot;b&quot;:[&quot;p q r&quot;]},&quot;w&quot;:[{&quot;x&quot;:null},{&quot;y&quot;:false},{&quot;z&quot;:3}]}&#39; | jqg .\r\n    {\r\n      &quot;a.b.0&quot;: &quot;p q r&quot;,\r\n      &quot;w.0.x&quot;: null,\r\n      &quot;w.1.y&quot;: false,\r\n      &quot;w.2.z&quot;: 3\r\n    }\r\n\r\nas well as empty arrays and objects (and a few other edge-case values):\r\n\r\n    $ jqg . test/odd-values.json\r\n    {\r\n      &quot;one.start-string&quot;: &quot;foo&quot;,\r\n      &quot;one.null-value&quot;: null,\r\n      &quot;one.integer-number&quot;: 101,\r\n      &quot;two.two-a.non-integer-number&quot;: 101.75,\r\n      &quot;two.two-a.number-zero&quot;: 0,\r\n      &quot;two.true-boolean&quot;: true,\r\n      &quot;two.two-b.false-boolean&quot;: false,\r\n      &quot;three.empty-string&quot;: &quot;&quot;,\r\n      &quot;three.empty-object&quot;: {},\r\n      &quot;three.empty-array&quot;: [],\r\n      &quot;end-string&quot;: &quot;bar&quot;\r\n    }\r\n\r\n(reporting empty arrays &amp; objects can be turned off with the `-E` option).\r\n\r\n`jqg` was tested with `jq` 1.6\r\n\r\n**Note :** I am the author of the `jqg` script.\r\n\r\n\r\n\r\n",
                "title": "Using jq, Flatten Arbitrary JSON to Delimiter-Separated Flat Dictionary"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 11,
        "last_activity_date": 1620922206,
        "creation_date": 1487340404,
        "last_edit_date": 1495540812,
        "question_id": 42299905,
        "body_markdown": "I&#39;m looking to transform JSON using `jq` to a delimiter-separated and flattened structure.\r\n\r\nThere have been attempts at this. For example, [Flatten nested JSON using jq][1].\r\n\r\nHowever the solutions on that page fail if the JSON contains arrays. For example, if the JSON is:\r\n\r\n    {&quot;a&quot;:{&quot;b&quot;:[1]},&quot;x&quot;:[{&quot;y&quot;:2},{&quot;z&quot;:3}]}\r\n\r\nThe solution above will fail to transform the above to:\r\n\r\n    {&quot;a.b.0&quot;:1,&quot;x.0.y&quot;:2,&quot;x.1.z&quot;:3}\r\n\r\nIn addition, I&#39;m looking for a solution that will also allow for an arbitrary delimiter. For example, suppose the space character is the delimiter.  In this case, the result would be:\r\n\r\n    {&quot;a b 0&quot;:1,&quot;x 0 y&quot;:2,&quot;x 1 z&quot;:3}\r\n\r\nI&#39;m looking to have this functionality accessed via a Bash (4.2+) function as is found in CentOS 7, something like this:\r\n\r\n    flatten_json()\r\n    {\r\n        local JSONData=&quot;$1&quot;\r\n        # jq command to flatten $JSONData, putting the result to stdout\r\n        jq ... &lt;&lt;&lt;&quot;$JSONData&quot;\r\n    }\r\n\r\nThe solution should work with all JSON data types, including *null* and *boolean*. For example, consider the following input:\r\n\r\n    {&quot;a&quot;:{&quot;b&quot;:[&quot;p q r&quot;]},&quot;w&quot;:[{&quot;x&quot;:null},{&quot;y&quot;:false},{&quot;z&quot;:3}]}\r\n\r\nIt should produce:\r\n\r\n    {&quot;a b 0&quot;:&quot;p q r&quot;,&quot;w 0 x&quot;:null,&quot;w 1 y&quot;:false,&quot;w 2 z&quot;:3}\r\n\r\n  [1]: https://stackoverflow.com/questions/37540717/flatten-nested-json-using-jq",
        "link": "https://stackoverflow.com/questions/42299905/using-jq-flatten-arbitrary-json-to-delimiter-separated-flat-dictionary",
        "title": "Using jq, Flatten Arbitrary JSON to Delimiter-Separated Flat Dictionary"
    },
    {
        "tags": [
            "filter",
            "geojson",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1487434240,
                "post_id": 42313772,
                "comment_id": 71788216,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 1155167,
                    "reputation": 397,
                    "user_id": 2949510,
                    "user_type": "registered",
                    "accept_rate": 57,
                    "profile_image": "https://www.gravatar.com/avatar/4d96b16689d52169930ff9fe08637173?s=256&d=identicon&r=PG",
                    "display_name": "Plouf",
                    "link": "https://stackoverflow.com/users/2949510/plouf"
                },
                "reply_to_user": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1487434587,
                "post_id": 42313772,
                "comment_id": 71788371,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 1155167,
                    "reputation": 397,
                    "user_id": 2949510,
                    "user_type": "registered",
                    "accept_rate": 57,
                    "profile_image": "https://www.gravatar.com/avatar/4d96b16689d52169930ff9fe08637173?s=256&d=identicon&r=PG",
                    "display_name": "Plouf",
                    "link": "https://stackoverflow.com/users/2949510/plouf"
                },
                "reply_to_user": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1487434605,
                "post_id": 42313772,
                "comment_id": 71788381,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1487434957,
                "post_id": 42313772,
                "comment_id": 71788516,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 1155167,
                    "reputation": 397,
                    "user_id": 2949510,
                    "user_type": "registered",
                    "accept_rate": 57,
                    "profile_image": "https://www.gravatar.com/avatar/4d96b16689d52169930ff9fe08637173?s=256&d=identicon&r=PG",
                    "display_name": "Plouf",
                    "link": "https://stackoverflow.com/users/2949510/plouf"
                },
                "reply_to_user": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1487435053,
                "post_id": 42313772,
                "comment_id": 71788548,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1487435149,
                "post_id": 42313772,
                "comment_id": 71788585,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 1155167,
                    "reputation": 397,
                    "user_id": 2949510,
                    "user_type": "registered",
                    "accept_rate": 57,
                    "profile_image": "https://www.gravatar.com/avatar/4d96b16689d52169930ff9fe08637173?s=256&d=identicon&r=PG",
                    "display_name": "Plouf",
                    "link": "https://stackoverflow.com/users/2949510/plouf"
                },
                "reply_to_user": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1487435523,
                "post_id": 42313772,
                "comment_id": 71788740,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1487435636,
                "post_id": 42313772,
                "comment_id": 71788777,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 1155167,
                    "reputation": 397,
                    "user_id": 2949510,
                    "user_type": "registered",
                    "accept_rate": 57,
                    "profile_image": "https://www.gravatar.com/avatar/4d96b16689d52169930ff9fe08637173?s=256&d=identicon&r=PG",
                    "display_name": "Plouf",
                    "link": "https://stackoverflow.com/users/2949510/plouf"
                },
                "reply_to_user": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1487436791,
                "post_id": 42313772,
                "comment_id": 71789179,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1487435836,
                "creation_date": 1487435836,
                "answer_id": 42317791,
                "question_id": 42313772,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You can [assign][1] the filtered list back to `.features`:\r\n\r\n    jq &#39;.features |= map(select(.properties|has(&quot;name&quot;)))&#39;\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/#Assignment",
                "title": "Filter objects in geojson based on a specific key"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1487436494,
        "creation_date": 1487412523,
        "last_edit_date": 1487436494,
        "question_id": 42313772,
        "body_markdown": "I try to edit a geojson file to keep only objects that have the key &quot;name&quot;. \r\nThe filter works but I can&#39;t find a way to keep the other objects and, specifically, the geometry and redirect the whole stuff to a new geojson file. Is there a way to display the whole object after filtering one of its children objects? \r\n\r\nHere is an example of my data. The first object has the &quot;name&quot; property and the second hasn&#39;t:\r\n\r\n    {\r\n      &quot;features&quot;: [\r\n        {\r\n          &quot;type&quot;: &quot;Feature&quot;,\r\n          &quot;id&quot;: &quot;way/24824633&quot;,\r\n          &quot;properties&quot;: {\r\n            &quot;@id&quot;: &quot;way/24824633&quot;,\r\n            &quot;highway&quot;: &quot;tertiary&quot;,\r\n            &quot;lit&quot;: &quot;yes&quot;,\r\n            &quot;maxspeed&quot;: &quot;50&quot;,\r\n            &quot;name&quot;: &quot;Rue de Kleinbettingen&quot;,\r\n            &quot;surface&quot;: &quot;asphalt&quot;\r\n          },\r\n          &quot;geometry&quot;: {\r\n            &quot;type&quot;: &quot;LineString&quot;,\r\n            &quot;coordinates&quot;: [\r\n              [\r\n                5.8997935,\r\n                49.6467825\r\n              ],\r\n              [\r\n                5.8972561,\r\n                49.6467445\r\n              ]\r\n            ]\r\n          }\r\n        },\r\n        {\r\n          &quot;type&quot;: &quot;Feature&quot;,\r\n          &quot;id&quot;: &quot;way/474396855&quot;,\r\n          &quot;properties&quot;: {\r\n            &quot;@id&quot;: &quot;way/474396855&quot;,\r\n            &quot;highway&quot;: &quot;path&quot;\r\n          },\r\n          &quot;geometry&quot;: {\r\n            &quot;type&quot;: &quot;LineString&quot;,\r\n            &quot;coordinates&quot;: [\r\n              [\r\n                5.8020608,\r\n                49.6907648\r\n              ],\r\n              [\r\n                5.8020695,\r\n                49.6906054\r\n              ]\r\n            ]\r\n          }\r\n        }\r\n      ]\r\n    }\r\n\r\nHere is what I tried, using **jq**\r\n\r\n    cat file.geojson | jq &#39;.features[].properties | select(has(&quot;name&quot;))&#39;\r\n\r\nThe &quot;geometry&quot; is also a child of &quot;features&quot; but I can&#39;t find a way to make the selection directly from the &quot;features&quot; level. Is there some way to do that? Or a better path to the solution?\r\n\r\nSo, the required ouput is:\r\n\r\n    {\r\n      &quot;type&quot;: &quot;Feature&quot;,\r\n      &quot;id&quot;: &quot;way/24824633&quot;,\r\n      &quot;properties&quot;: {\r\n        &quot;@id&quot;: &quot;way/24824633&quot;,\r\n        &quot;highway&quot;: &quot;tertiary&quot;,\r\n        &quot;lit&quot;: &quot;yes&quot;,\r\n        &quot;maxspeed&quot;: &quot;50&quot;,\r\n        &quot;name&quot;: &quot;Rue de Kleinbettingen&quot;,\r\n        &quot;surface&quot;: &quot;asphalt&quot;\r\n      },\r\n      &quot;geometry&quot;: {\r\n        &quot;type&quot;: &quot;LineString&quot;,\r\n        &quot;coordinates&quot;: [\r\n          [\r\n            5.8997935,\r\n            49.6467825\r\n          ],\r\n          [\r\n            5.8972561,\r\n            49.6467445\r\n          ]\r\n     ]}}\r\n\r\n",
        "link": "https://stackoverflow.com/questions/42313772/filter-objects-in-geojson-based-on-a-specific-key",
        "title": "Filter objects in geojson based on a specific key"
    },
    {
        "tags": [
            "regex",
            "bash",
            "shell",
            "grep",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 4955923,
                    "reputation": 6355,
                    "user_id": 3988526,
                    "user_type": "registered",
                    "profile_image": "https://graph.facebook.com/568589813/picture?type=large",
                    "display_name": "George Vasiliou",
                    "link": "https://stackoverflow.com/users/3988526/george-vasiliou"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1487429293,
                "post_id": 42316542,
                "comment_id": 71786612,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 10263427,
                    "reputation": 309,
                    "user_id": 7574087,
                    "user_type": "registered",
                    "accept_rate": 57,
                    "profile_image": "https://www.gravatar.com/avatar/17000772c4fa39ac1000a4eaef937964?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Beatrix Kiddo",
                    "link": "https://stackoverflow.com/users/7574087/beatrix-kiddo"
                },
                "reply_to_user": {
                    "account_id": 4955923,
                    "reputation": 6355,
                    "user_id": 3988526,
                    "user_type": "registered",
                    "profile_image": "https://graph.facebook.com/568589813/picture?type=large",
                    "display_name": "George Vasiliou",
                    "link": "https://stackoverflow.com/users/3988526/george-vasiliou"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1487431687,
                "post_id": 42316542,
                "comment_id": 71787368,
                "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": 1,
                "creation_date": 1487433255,
                "post_id": 42316542,
                "comment_id": 71787839,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 10263427,
                    "reputation": 309,
                    "user_id": 7574087,
                    "user_type": "registered",
                    "accept_rate": 57,
                    "profile_image": "https://www.gravatar.com/avatar/17000772c4fa39ac1000a4eaef937964?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Beatrix Kiddo",
                    "link": "https://stackoverflow.com/users/7574087/beatrix-kiddo"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1487434285,
                "post_id": 42316542,
                "comment_id": 71788238,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1487436405,
                "creation_date": 1487436405,
                "answer_id": 42317877,
                "question_id": 42316542,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Consider:\r\n\r\n    $ jq -c &#39;keys[] as $k | ($k, .[$k])&#39; &lt;&lt;&lt; &quot;$var&quot;\r\n    &quot;build&quot;\r\n    &quot;123&quot;\r\n    &quot;deploy&quot;\r\n    &quot;False&quot;\r\n    &quot;install&quot;\r\n    &quot;False&quot;\r\n    &quot;ip&quot;\r\n    &quot;0.0.0.0&quot;\r\n    &quot;password&quot;\r\n    &quot;kilby&quot;\r\n    &quot;user&quot;\r\n    &quot;jack&quot;\r\n\r\nYou can then use the bash command, `readarray`, or the idiom: \r\n\r\n    while read -r line\r\n    do ...\r\n    done\r\n\r\nSee the [jq FAQ][1] for further details.\r\n\r\n### Caveat\r\nYou don&#39;t say what your ultimate goal is, but I suspect that you would be better off using jq more comprehensively to achieve it. \r\n\r\n\r\n  [1]: https://github.com/stedolan/jq/wiki/FAQ",
                "title": "how to transfer all the key value pairs present in a .txt file to an array using bash script"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": -1,
                "last_activity_date": 1487660907,
                "last_edit_date": 1487660907,
                "creation_date": 1487444013,
                "answer_id": 42319331,
                "question_id": 42316542,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "First I will make a function that returns the contents of the array.\r\n\r\n    function myvar {\r\n       cat &lt;&lt; &quot;END&quot;\r\n    { &quot;user&quot;: &quot;jack&quot;,&quot;password&quot;: &quot;kilby&quot;,&quot;install&quot;:&quot;False&quot;, &quot;deploy&quot;:&quot;False&quot;, &quot;build&quot;:&quot;123&quot;,&quot;ip&quot;:&quot;0.0.0.0&quot; }\r\n    END\r\n    }\r\n\r\nNow we can parse the var by cutting the string in lines at &#39;,&#39;, and find the fields.\r\n\r\n    myvar | tr &#39;,&#39; &#39;\\n&#39; | sed &#39;s/.*&quot;\\(.*\\)&quot;.*\\(&quot;.*&quot;\\).*/\\1=\\2/&#39;\r\n\r\nNow we have these, we can evaluating the result by sourcing it. Before sourcing it, we will use a tick to make it act as a file: `&lt;( echo &quot;My output looks like a file&quot;)`  \r\nOP asked for an array, but first I will show how to make environment vars.\r\n\r\n    source &lt;(myvar | tr &#39;,&#39; &#39;\\n&#39; | sed &#39;s/.*&quot;\\(.*\\)&quot;.*\\(&quot;.*&quot;\\).*/\\1=\\2/&#39;)\r\n    echo &quot;Environment variable build=${build}&quot;\r\n\r\nNow we like to fill it in an associative array (Note: bash version 4 only).\r\n\r\n    declare -A arr\r\n    source &lt;(myvar | tr &#39;,&#39; &#39;\\n&#39; | sed &#39;s/.*&quot;\\(.*\\)&quot;.*\\(&quot;.*&quot;\\).*/arr[\\1]=\\2/&#39;)\r\n    # Show that it worked\r\n    for key in ${!arr[@]}; do\r\n         echo &quot;Array[${key}]=${arr[${key}]}&quot;\r\n    done\r\n\r\n",
                "title": "how to transfer all the key value pairs present in a .txt file to an array using bash script"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": -1,
                "last_activity_date": 1487461996,
                "creation_date": 1487461996,
                "answer_id": 42322034,
                "question_id": 42316542,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Without wanting to judge if the method you selected to parse that kind of data is right or wrong, i will try to answer your question even if i disagree with your selected method for parsing json data.\r\n\r\nIn this point of your code you create an array named arr:\r\n\r\n    arr=( $(grep -o \\&quot;[^\\&quot;]*. properties.txt) )\r\n\r\nIf you ask bash to tell you what is stored inside this array you get the response:\r\n\r\n    $ declare -p arr\r\n    declare -a arr=([0]=&quot;\\&quot;user\\&quot;&quot; [1]=&quot;\\&quot;jack\\&quot;&quot; [2]=&quot;\\&quot;password\\&quot;&quot; [3]=&quot;\\&quot;kilby\\&quot;&quot; \\\r\n    [4]=&quot;\\&quot;install\\&quot;&quot; [5]=&quot;\\&quot;False\\&quot;&quot; [6]=&quot;\\&quot;deploy\\&quot;&quot; [7]=&quot;\\&quot;\\&quot;&quot; \\\r\n    [8]=&quot;\\&quot;build\\&quot;&quot; [9]=&quot;\\&quot;123\\&quot;&quot; [10]=&quot;\\&quot;ip\\&quot;&quot; [11]=&quot;\\&quot;0.0.0.0\\&quot;&quot;)\r\n\r\nMind that i have modified the var field `&quot;deploy&quot;:&quot;false&quot;` to `&quot;deploy&quot;:&quot;&quot;` to test my answer - this is arr[7] above.\r\n\r\nThe most easy way i found to handle the missing fields from your array is to redifine the same arr array using bash substitution techniques like this:\r\n\r\n    $ arr=( ${arr[@]//\\&quot;\\&quot;/\\&quot;empty\\&quot;/} )\r\n    $ declare -p arr\r\n    declare -a arr=([0]=&quot;\\&quot;user\\&quot;&quot; [1]=&quot;\\&quot;jack\\&quot;&quot; [2]=&quot;\\&quot;password\\&quot;&quot; [3]=&quot;\\&quot;kilby\\&quot;&quot; \\ \r\n    [4]=&quot;\\&quot;install\\&quot;&quot; [5]=&quot;\\&quot;False\\&quot;&quot; [6]=&quot;\\&quot;deploy\\&quot;&quot; [7]=&quot;\\&quot;empty\\&quot;/&quot; \\\r\n    [8]=&quot;\\&quot;build\\&quot;&quot; [9]=&quot;\\&quot;123\\&quot;&quot; [10]=&quot;\\&quot;ip\\&quot;&quot; [11]=&quot;\\&quot;0.0.0.0\\&quot;&quot;)\r\n\r\nMind that arr[7] has changed to `&quot;empty&quot;` from previously `&quot;&quot;`\r\n\r\nIn reality, your code will store to the array the string `\\&quot;\\&quot;` for empty fields, which will be printed by echo like simple `&quot;&quot;`  \r\n\r\nAfter my substitution , declare -p advises `arr[7]=\\&quot;empty\\&quot;` , which will be printed by echo as simple `&quot;empty&quot;`.Of course you can change this text to whatever you like, by maintaining the escaping of double quotes.\r\n \r\nResults with your second `var2={&quot;k1&quot;:&quot;&quot;,&quot;k2&quot;:&quot;&quot;,&quot;k3&quot;:&quot;&quot;}`\r\n\r\n    $ var2=&#39;{&quot;k1&quot;:&quot;&quot;,&quot;k2&quot;:&quot;&quot;,&quot;k3&quot;:&quot;&quot;}&#39;\r\n    $ echo &quot;$var2&quot; &gt;properties.txt\r\n    $ cat properties.txt\r\n    {&quot;k1&quot;:&quot;&quot;,&quot;k2&quot;:&quot;&quot;,&quot;k3&quot;:&quot;&quot;}\r\n    $ arr=( $(grep -o \\&quot;[^\\&quot;]*. properties.txt) )\r\n    $ declare -p arr\r\n    declare -a arr=([0]=&quot;\\&quot;k1\\&quot;&quot; [1]=&quot;\\&quot;\\&quot;&quot; [2]=&quot;\\&quot;k2\\&quot;&quot; [3]=&quot;\\&quot;\\&quot;&quot; [4]=&quot;\\&quot;k3\\&quot;&quot; [5]=&quot;\\&quot;\\&quot;&quot;)\r\n    $ arr=( ${arr[@]//\\&quot;\\&quot;/\\&quot;empty\\&quot;/} )\r\n    $ declare -p arr\r\n    declare -a arr=([0]=&quot;\\&quot;k1\\&quot;&quot; [1]=&quot;\\&quot;empty\\&quot;/&quot; [2]=&quot;\\&quot;k2\\&quot;&quot; [3]=&quot;\\&quot;empty\\&quot;/&quot; [4]=&quot;\\&quot;k3\\&quot;&quot; [5]=&quot;\\&quot;empty\\&quot;/&quot;)\r\n    $ echo &quot;${arr[@]}&quot;\r\n    &quot;k1&quot; &quot;empty&quot;/ &quot;k2&quot; &quot;empty&quot;/ &quot;k3&quot; &quot;empty&quot;/\r\n\r\nNotice:   \r\nThis solution is only advising the next step to your code. I have not tested your data manipulation techniques (i.e your grep, etc). \r\n",
                "title": "how to transfer all the key value pairs present in a .txt file to an array using bash script"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1487467883,
                "last_edit_date": 1487467883,
                "creation_date": 1487464387,
                "answer_id": 42322295,
                "question_id": 42316542,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "`jq` is the tool to parse JSON from shell. You can parse JSON in other languages (python, php, ruby, GO, etc), but if you go that route, you might as well just write your whole program in that language.\r\n\r\nSo .. from bash, you&#39;d use `jq`:\r\n\r\n    $ jq &#39;keys[] as $k | &quot;\\($k)=\\(.[$k])&quot;&#39; &lt;&lt;&lt;&quot;$var&quot; \r\n    &quot;build=123&quot;\r\n    &quot;deploy=False&quot;\r\n    &quot;install=False&quot;\r\n    &quot;ip=0.0.0.0&quot;\r\n    &quot;password=kilby&quot;\r\n    &quot;user=jack&quot;\r\n\r\nIf you want these pairs in an associative array in bash 4+, you might do this:\r\n\r\n    $ declare -A a=&quot;( $(jq -r &#39;keys[] as $k | &quot;[\\($k)]=\\&quot;\\(.[$k])\\&quot;&quot;&#39; &lt;&lt;&lt;&quot;$var&quot; ) )&quot;\r\n    $ declare -p a\r\n    declare -A a=([build]=&quot;123&quot; [install]=&quot;False&quot; [ip]=&quot;0.0.0.0&quot; [user]=&quot;jack&quot; [deploy]=&quot;False&quot; [password]=&quot;kilby&quot; )\r\n\r\nThis works fine as long as there are no newlines in variable indexes or values. To make it handle more complex data, you&#39;ll need .. a more complex handler. If there&#39;s a risk of newlines, please mention it in your question.\r\n",
                "title": "how to transfer all the key value pairs present in a .txt file to an array using bash script"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1487476470,
                "last_edit_date": 1495540930,
                "creation_date": 1487472452,
                "answer_id": 42323082,
                "question_id": 42316542,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "&lt;sup&gt;This answer&#39;s solutions read the key-value pairs into _consecutive_ elements of a _regular_ array (element `0` receives the 1st key, element `1` the associated value, ...), as in the question; for a solution that creates a Bash v4+ _associative_ array, see [ghoti&#39;s helpful answer](https://stackoverflow.com/a/42322295/45375).&lt;/sup&gt;\r\n\r\n**tl;dr**:\r\n\r\n### Using standard utilities only:\r\n\r\n    readarray -t arr &lt; &lt;(grep -o &#39;&quot;[^&quot;]*.&#39; properties.txt | tr -d \\&quot;)\r\n\r\nBash v3.x equivalent:\r\n\r\n    arr=()\r\n    while IFS= read -r val; do\r\n      arr+=( &quot;$val&quot; )\r\n    done &lt; &lt;(grep -o &#39;&quot;[^&quot;]*.&#39; properties.txt | tr -d \\&quot;)\r\n\r\n\r\n### Using `jq`:\r\n\r\n    readarray -t arr &lt; &lt;(jq -r &#39;keys_unsorted[] as $k | $k, .[$k]&#39; properties.txt)\r\n\r\n&lt;sup&gt;The `jq` command is a variation of [peak&#39;s helpful answer](https://stackoverflow.com/a/42317877/45375): `keys_unsorted` ensures that the keys are enumerated in input order, and `-r` ensures that the results are output as raw values rather than JSON-encoded, which in this case means that the double quotes are stripped.&lt;/sup&gt;\r\n\r\n\r\nBash v3.x equivalent:\r\n\r\n    arr=()\r\n    while IFS= read -r val; do\r\n      arr+=( &quot;$val&quot; )\r\n    done &lt; &lt;(jq -r &#39;keys_unsorted[] as $k | &quot;\\($k)\\n\\(.[$k])&quot;&#39; properties.txt)\r\n\r\n\r\n----------\r\n\r\nFirst things first: if feasible, it&#39;s **always worth using a proper JSON parser such as [`jq`](https://stedolan.github.io/jq/)**.\r\n\r\nThe problems with your approach:\r\n\r\n* `grep -o \\&quot;[^\\&quot;]*.` _included_ the enclosing `&quot;` in the output, which the array assignment `arr=( ... )` then parsed as _part of the values_.\r\n\r\n* It&#39;s easy to fix that problem by piping to `tr -d \\&quot;` to remove them, but the `arr=( $(...) )` syntax then _ignores empty strings_, so you&#39;ll lose empty input values in the process.\r\n\r\n* That said, you should _generally avoid_ `arr=( $(...) )`, because it \r\n  (a) invariably splits the output from the command substitution `$(...)` by *whitespace* (word-splitting), irrespective of embedded quote chars., (b) by default subjects the resulting words to filename expansion (globbing).\r\n\r\nThe safe alternative that avoids both problems - at least with _line-oriented_ input - is to use `readarray`, available since Bash v4.0; `-t` strips the trailing `\\n` from the lines read.\r\n\r\nIn Bash v3.x, a `while` loop must be used to read the lines, because the construct that is _almost_ equivalent to `readarray -t arr` - `IFS=$&#39;\\n&#39; read -d &#39;&#39; -ra arr` - also _ignores empty entries_.\r\n\r\n\r\n\r\n\r\n",
                "title": "how to transfer all the key value pairs present in a .txt file to an array using bash script"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": -1,
                "last_activity_date": 1487593051,
                "last_edit_date": 1487593051,
                "creation_date": 1487592744,
                "answer_id": 42344287,
                "question_id": 42316542,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Thnaks a lot for quick response guys. I solved my problem by following method\r\n\r\n    makeKeyValueArray (){\r\n    # remove colon and commas\r\n    IFS=&#39;:&#39; read -ra ADDR &lt;&lt;&lt; &quot;$var&quot;\r\n    IFS=&#39;,&#39; read -ra ADDR2 &lt;&lt;&lt; &quot;${ADDR[@]}&quot;\r\n    \r\n    echo ${ADDR2[@]} &gt; &quot;$destdir&quot;\r\n\r\n    #remove curly braces\r\n    sed &#39;s/[{}]//g&#39; $destdir &gt; temp_ip_prop.txt\r\n    mv temp_ip_prop.txt $destdir\r\n    \r\n   \r\n\r\n    #store each item in a array &quot;arr&quot;\r\n        cn=0;\r\n        \tfor i in `cat $destdir`\r\n        \tdo\r\n           \tarr[$cn]=$i;\r\n           \t((cn=cn+1));\r\n        \tdone\r\n\r\n    }\r\n\r\nAnd then in a loop i compared whether array contains &quot;&quot;. If so i just made that field as empty space.\r\n\r\nThe mistake i was doing was in the\r\n\r\n&gt;  arr=( $(grep -o \\&quot;[^\\&quot;]*. properties.txt) )\r\n\r\nThis was storing each \\&quot; to the array. \r\n",
                "title": "how to transfer all the key value pairs present in a .txt file to an array using bash script"
            }
        ],
        "is_answered": true,
        "answer_count": 6,
        "score": 0,
        "last_activity_date": 1487660907,
        "creation_date": 1487428735,
        "last_edit_date": 1487431984,
        "question_id": 42316542,
        "body_markdown": "I have a variable &quot;var&quot; which has the json text as shown below\r\n\r\n     var=&#39;{ &quot;user&quot;: &quot;jack&quot;,&quot;password&quot;: &quot;kilby&quot;,&quot;install&quot;:&quot;False&quot;, &quot;deploy&quot;:&quot;False&quot;, &quot;build&quot;:&quot;123&quot;,&quot;ip&quot;:&quot;0.0.0.0&quot; }&#39;\r\nIam writig that to a .txt file \r\n\r\n    touch properties.txt\r\n\r\n    destdir=./properties.txt\r\n    \r\n    if [ -f &quot;$destdir&quot; ]\r\n    then \r\n        echo &quot;$var&quot; &gt; &quot;$destdir&quot;\r\n    fi\r\nThen I have to store all key value pairs inside an array for further processing that i am dong as below \r\n\r\n    arr=( $(grep -o \\&quot;[^\\&quot;]*. properties.txt) )\r\nSo all the texts present inside double quotes are moved to &quot;arr&quot;\r\n\r\nbut the problem is if key value pair is as shown below i.e if value is empty then &quot;arr&quot; is getting  \\&quot;  as a one entry, Thats not desiarble. \r\n\r\n    {&quot;k1&quot;:&quot;&quot;,&quot;k2&quot;:&quot;&quot;,&quot;k3&quot;:&quot;&quot;}\r\n\r\nI need an empty string to go inplace as an entry to &quot;arr&quot; in such case.\r\n\r\nI am not much aware of bash commands. So appreciate any help.\r\nIf the result can achieved using &quot;jq&quot; library then those suggestions are also welcome.\r\nthanks ",
        "link": "https://stackoverflow.com/questions/42316542/how-to-transfer-all-the-key-value-pairs-present-in-a-txt-file-to-an-array-using",
        "title": "how to transfer all the key value pairs present in a .txt file to an array using bash script"
    },
    {
        "tags": [
            "json",
            "regex",
            "bash",
            "shell",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1487448748,
                "creation_date": 1487448748,
                "answer_id": 42320172,
                "question_id": 42320072,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "If `v` is an empty string, you need to quote its expansion. You should pass the value of `$k` via a variable as well, rather than attempting to interpolate it.\r\n\r\n    jq --arg flag &quot;$node&quot; \\\r\n       --arg temp  &quot;$v&quot; \\\r\n       --arg k1 &quot;$k&quot; \\\r\n       &#39;(.[$flag]|.[$k1])|=$temp&#39; properties.json &gt; tempprop.json\r\n\r\nAs is, the unquoted expansion of empty `$v` &quot;disappears&quot;, and `jq` sees the filter as the second argument to that `--arg` option, leaving `properties.json` to be interpreted as the filter.",
                "title": "How can i replace a character with blank space in bash using jq library"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1487451079,
        "creation_date": 1487448174,
        "last_edit_date": 1487451079,
        "question_id": 42320072,
        "body_markdown": "I am using `jq` command to replace &quot;value&quot; for corresponding &quot;key&quot; in a JSON file.\r\nHere in the following code snippet I have to replace `v`&#39;s value corresponding to key `k` in the JSON object `node`.\r\n \r\n\r\n      jq --arg flag &quot;$node&quot; \\\r\n                       --arg temp  $v \\\r\n            \t &#39;(.[$flag]|.[&#39;$k&#39;])|=$temp&#39; properties.json &gt; tempprop.json\r\n\r\nThe problem is if there is already a value is present then I need to pass an empty string as value. But `jq` parser is throwing exception saying\r\n\r\n    jq: error: properties/0 is not defined at &lt;top-level&gt;, line 1:\r\n    properties.json\r\nSo I don&#39;t know any other way to deal with this, appreciate any kind of help.\r\n\r\nThanks.\r\n\r\n\r\n ",
        "link": "https://stackoverflow.com/questions/42320072/how-can-i-replace-a-character-with-blank-space-in-bash-using-jq-library",
        "title": "How can i replace a character with blank space in bash using jq library"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 8,
                "is_accepted": false,
                "score": 8,
                "last_activity_date": 1703369382,
                "last_edit_date": 1703369382,
                "creation_date": 1487629829,
                "answer_id": 42355383,
                "question_id": 42355182,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The trick is to use `.Name |= gsub(&quot;\\\\.&quot;;&quot;:&quot;)`.  In your case (a flat list), it&#39;s simple.  If you want to modify the keys of all objects in an arbitrary JSON text, the simplest would be to use `walk/1`:\r\n\r\n    walk( if type == &quot;object&quot; and (.Name|type) == &quot;string&quot; then .Name |= gsub(&quot;\\\\.&quot;;&quot;:&quot;)) else . end )\r\n\r\n\r\n(If your jq does not have walk/1, then its jq definition can readily be found by googling.)\r\n\r\n\r\n\r\n",
                "title": "substitute certain characters in strings found in an object"
            },
            {
                "up_vote_count": 8,
                "is_accepted": true,
                "score": 8,
                "last_activity_date": 1487630120,
                "creation_date": 1487630120,
                "answer_id": 42355445,
                "question_id": 42355182,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You may split by `.` and join by `:`\r\n\r\n    jq &#39;(.Parameters[].Name)|=(split(&quot;.&quot;)|join(&quot;:&quot;))&#39; file.json\r\n\r\nThe assignment is done using the [*update* operator][1].\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/#Assignment",
                "title": "substitute certain characters in strings found in an object"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 5,
        "last_activity_date": 1703369382,
        "creation_date": 1487628871,
        "last_edit_date": 1487630220,
        "question_id": 42355182,
        "body_markdown": "I have a list of objects and want to replace all occurrences of `.` with `:` when the key is `Name` using `jq`\r\n\r\ninput: \r\n\r\n    {\r\n      &quot;Parameters&quot;: [\r\n        {\r\n          &quot;Name&quot;: &quot;TEST.AB.SOMETHING&quot;,\r\n          &quot;Value&quot;: &quot;hvfuycsgvfiwbiwbibibewfiwbcfwifcbwibcibc&quot;\r\n        },\r\n        {\r\n          &quot;Name&quot;: &quot;TEST_GF_USER&quot;,\r\n          &quot;Value&quot;: &quot;ssssecret&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\n    \r\nexpected output:\r\n\r\n    {\r\n      &quot;Parameters&quot;: [\r\n        {\r\n          &quot;Name&quot;: &quot;TEST:AB:SOMETHING&quot;,\r\n          &quot;Value&quot;: &quot;hvfuycsgvfiwbiwbibibewfiwbcfwifcbwibcibc&quot;\r\n        },\r\n        {\r\n          &quot;Name&quot;: &quot;TEST_GF_USER&quot;,\r\n          &quot;Value&quot;: &quot;ssssecret&quot;\r\n        }\r\n      ]\r\n    }\r\n",
        "link": "https://stackoverflow.com/questions/42355182/substitute-certain-characters-in-strings-found-in-an-object",
        "title": "substitute certain characters in strings found in an object"
    },
    {
        "tags": [
            "bash",
            "sh",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 14,
                "is_accepted": true,
                "score": 14,
                "last_activity_date": 1513084998,
                "last_edit_date": 1513084998,
                "creation_date": 1487636854,
                "answer_id": 42356580,
                "question_id": 42356536,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You can use `to_entries` for that:\r\n\r\n    jq -r &#39;to_entries[]|&quot;\\(.key)=\\&quot;\\(.value)\\&quot;&quot;&#39; input.json\r\n\r\nBtw, in Java properties files you don&#39;t need to quote the value:\r\n\r\n    jq -r &#39;to_entries[]|&quot;\\(.key)=\\(.value)&quot;&#39; input.json",
                "title": "Convert a simple JSON object to a properties file"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1513067682,
                "creation_date": 1513067682,
                "answer_id": 47768229,
                "question_id": 42356536,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Actually the usage of \\`to_entries&#39; and \\`@sh&#39; filter will work only for *simple* JSON objects (As stated in the question...). In my case (nested json) seems I&#39;ll use npm&#39;s package &quot;json-to-properties&quot;",
                "title": "Convert a simple JSON object to a properties file"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1694692357,
                "last_edit_date": 1694692357,
                "creation_date": 1694529280,
                "answer_id": 77090158,
                "question_id": 42356536,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you have a nested structure you can define a file, for example `to-properties.jq`:\r\n\r\n    def val_at($path; $json):\r\n      $json | getpath($path)\r\n    ;\r\n\r\n    . as $json\r\n      | [paths(type != &quot;object&quot;)]\r\n      | map(&quot;\\(join(&quot;.&quot;))=\\(val_at(.; $json))&quot;)\r\n      | join(&quot;\\n&quot;)\r\n\r\n\r\nYou can then invoke `jq -r -f to-properties.jq file.json` which would output something like:\r\n\r\n    bar.baz=abc\r\n    foo.bar=123\r\n    foo.bar.baz=xyz",
                "title": "Convert a simple JSON object to a properties file"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1728324173,
                "creation_date": 1728324173,
                "answer_id": 79063103,
                "question_id": 42356536,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The [yq][1] utility can read JSON, YAML, INI, TOML and more and output, among other formats, Java properties. For JSON input, Use it like this:\r\n\r\n```bash\r\nyq -p json -o props &lt; config.json\r\n```\r\n\r\nIf you need shell variables, do\r\n\r\n```bash\r\nyq -p json -o shell &lt; config.json\r\n```\r\n\r\n\r\n  [1]: https://github.com/mikefarah/yq",
                "title": "Convert a simple JSON object to a properties file"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1729020257,
                "creation_date": 1729020257,
                "answer_id": 79091462,
                "question_id": 42356536,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You know, I remembered actually doing [this exact thing][1] a while back, and, although you have an answer, I will put this here for others to refer to:\r\n```json\r\n{\r\n  &quot;Applicant&quot;: [\r\n    {\r\n      &quot;id&quot;: 1,\r\n      &quot;tableReference&quot;: {\r\n        &quot;tableId&quot;: &quot;Applicant&quot;\r\n      }\r\n    },\r\n    {\r\n      &quot;id&quot;: 2,\r\n      &quot;tableReference&quot;: {\r\n        &quot;tableId&quot;: &quot;Applicant&quot;\r\n      }\r\n    }\r\n  ],\r\n  &quot;ApplicantBureau&quot;: [\r\n    {\r\n      &quot;id&quot;: 3,\r\n      &quot;tableReference&quot;: {\r\n        &quot;tableId&quot;: &quot;ApplicantBureau&quot;\r\n      }\r\n    }\r\n  ],\r\n  &quot;Foo&quot;: [\r\n    {\r\n      &quot;id&quot;: 4,\r\n      &quot;tableReference&quot;: {\r\n        &quot;tableId&quot;: &quot;Foo&quot;\r\n      }\r\n    }\r\n  ]\r\n}\r\n```\r\nin example.json\r\n```\r\njq -r &#39;path(.. | scalars) as $p | getpath($p) as $v | &quot;\\($p|join(&quot;.&quot;))=\\($v)&quot;&#39;  example.json\r\nApplicant.0.id=1\r\nApplicant.0.tableReference.tableId=Applicant\r\nApplicant.1.id=2\r\nApplicant.1.tableReference.tableId=Applicant\r\nApplicantBureau.0.id=3\r\nApplicantBureau.0.tableReference.tableId=ApplicantBureau\r\nFoo.0.id=4\r\nFoo.0.tableReference.tableId=Foo\r\n```\r\n\r\n\r\n  [1]: https://gist.github.com/olih/f7437fb6962fb3ee9fe95bda8d2c8fa4",
                "title": "Convert a simple JSON object to a properties file"
            }
        ],
        "is_answered": true,
        "answer_count": 5,
        "score": 5,
        "last_activity_date": 1729020257,
        "creation_date": 1487636525,
        "last_edit_date": 1487637899,
        "question_id": 42356536,
        "body_markdown": "I have a simple JSON object and would like to convert it into a properties file in bash.\r\n\r\nInput: \r\n\r\n    {\r\n        &quot;foo&quot;: &quot;bar&quot;,\r\n        &quot;abc&quot;: &quot;def ghi&quot;\r\n    }\r\n\r\nexpected output:\r\n\r\n    foo=&quot;bar&quot;\r\n    abc=&quot;def ghi&quot;",
        "link": "https://stackoverflow.com/questions/42356536/convert-a-simple-json-object-to-a-properties-file",
        "title": "Convert a simple JSON object to a properties file"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1487700986,
                "last_edit_date": 1487700986,
                "creation_date": 1487700544,
                "answer_id": 42374793,
                "question_id": 42373924,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Try this instead:\r\n\r\n    $ jq --arg p webpack --arg v 1.2.3 &#39;\r\n    def update_package($package; $version):\r\n        if has($package) then .[$package] = $version\r\n        else . end;\r\n    .dependencies |= update_package($p; $v)\r\n        | .devDependencies |= update_package($p; $v)&#39; project.json\r\n\r\n`update_package/2` will only update the dependency object if it actually references the given project, otherwise it is left alone.  Apply to both `dependencies` and `devDependencies`.\r\n\r\nThe problem with your original filter that was removing the `dependencies` object was that since the project didn&#39;t exist, there was no corresponding value to update. By applying `startswith` on the nonexistent value, it caused an error. That error in turn was just ignored and effectively skipped the corresponding item in the map, thus losing that property.\r\n\r\nFor a quick fix to ensure this doesn&#39;t happen, don&#39;t ignore the error, provide an alternate value to use when the property doesn&#39;t exist.\r\n\r\n    .value[$p]?      | startswith(&quot;^&quot;)? # bad\r\n    .value[$p] // &quot;&quot; | startswith(&quot;^&quot;)  # better",
                "title": "Update JSON based on condition using jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1487747311,
                "last_edit_date": 1487747311,
                "creation_date": 1487702338,
                "answer_id": 42375361,
                "question_id": 42373924,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Using your approach, it would be better to use map_values:\r\n\r\n    map_values(if type == &quot;object&quot; \r\n               then with_entries( if .key == $p and (.value | startswith(&quot;^&quot;)?) \r\n                                  then .value = $v else . end )\r\n\t           else . end)\r\n\r\nYou might also like to consider using `walk/1`:\r\n\r\n    walk(if type == &quot;object&quot; and has($p) and (.[$p]|startswith(&quot;^&quot;))\r\n         then .[$p] = $v else . end)\r\n\r\nThe solution using `walk/1` will examine the JSON entity recursively.  If your jq does not have `walk`, its definition in jq can readily be found by googling.\r\n\r\n### Robust solution using when/2\r\n\r\n    def when(p;q): if p//false then q else . end;\r\n\r\n    map_values( when(type == &quot;object&quot;;\r\n                     with_entries( when( .key == $p and (.value | startswith(&quot;^&quot;)?);\r\n\t\t                                 .value = $v) )) )\r\n",
                "title": "Update JSON based on condition using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1487747311,
        "creation_date": 1487697666,
        "last_edit_date": 1487703778,
        "question_id": 42373924,
        "body_markdown": "Supposing that I have a JSON file that looks like this:\r\n\r\n    {\r\n      &quot;name&quot;: &quot;tom&quot;,\r\n      &quot;scripts&quot;: {\r\n        &quot;webpack&quot;: &quot;webpack --progress --colors --watch&quot;\r\n      },\r\n      &quot;dependencies&quot;: {\r\n      },\r\n      &quot;devDependencies&quot;: {\r\n        &quot;webpack&quot;: &quot;^2.2.1&quot;\r\n      }\r\n    }\r\n\r\nI would like to be able to specify a package by name, find the corresponding entry in either `dependencies` or `devDependencies` and update the value.\r\n\r\nThe closest I got was this:\r\n\r\n    $ jq --arg p webpack --arg v 1.2.3 &#39;to_entries | map(\r\n       if (.value[$p]? | startswith(&quot;^&quot;)?) then \r\n          .value[$p] = $v\r\n       else . \r\n       end\r\n    ) | from_entries&#39; file.json\r\nWhich updates the value but also removes the `dependencies` and the `name` property:\r\n\r\n    {\r\n      &quot;scripts&quot;: {\r\n        &quot;webpack&quot;: &quot;webpack --progress --colors --watch&quot;\r\n      },\r\n      &quot;devDependencies&quot;: {\r\n        &quot;webpack&quot;: &quot;1.2.3&quot;\r\n      }\r\n    }\r\nHow can I update the desired value without affecting the other properties in the original JSON?",
        "link": "https://stackoverflow.com/questions/42373924/update-json-based-on-condition-using-jq",
        "title": "Update JSON based on condition using jq"
    },
    {
        "tags": [
            "json",
            "awk",
            "sed",
            "grep",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 5,
                "creation_date": 1487761978,
                "post_id": 42389561,
                "comment_id": 71927096,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1487762049,
                "post_id": 42389561,
                "comment_id": 71927158,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 1020072,
                    "reputation": 243994,
                    "user_id": 1030675,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/957956ce51706d03f19a4dc85a767bb1?s=256&d=identicon&r=PG",
                    "display_name": "choroba",
                    "link": "https://stackoverflow.com/users/1030675/choroba"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1487762504,
                "post_id": 42389561,
                "comment_id": 71927466,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1487777339,
                "creation_date": 1487777339,
                "answer_id": 42395703,
                "question_id": 42389561,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "`awk` to the rescue!\r\n\r\n    $ awk -F, -v RS={ &#39;NR&gt;1 {for(i=1;i&lt;=NF;i++)\r\n                             {if($i~/&quot;1a&quot;:/) printf &quot;%s&quot;, $i OFS\r\n                              if($i~/&quot;h&quot;:&quot;log(A|B)&quot;/) printf &quot;%s\\n&quot;, $i}}&#39; file\r\n\r\n\r\n    &quot;1a&quot;:&quot;2017-01-28 00:00:00&quot; &quot;h&quot;:&quot;logA&quot;\r\n    &quot;1a&quot;:&quot;2017-01-28 00:00:11&quot; &quot;h&quot;:&quot;logB&quot;\r\n\r\nof course better to use json aware tools.\r\n",
                "title": "Extract key-value pairs from a JSON file with custom output formatting"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1487779050,
                "last_edit_date": 1487779050,
                "creation_date": 1487778661,
                "answer_id": 42396221,
                "question_id": 42389561,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "**Input**\r\n\r\n    $ cat log\r\n        {&quot;1a&quot;:&quot;2017-01-28 00:00:00&quot;,&quot;2a&quot;:&quot;sample&quot;,&quot;a&quot;:&quot;12345&quot;,&quot;b&quot;:&quot;2017-02-06&quot;,&quot;c&quot;:&quot;2017-02-06T17:51:02.454-08:00&quot;,&quot;d&quot;:&quot;Mozilla/5.0\r\n        ; en-US; rv:1.9.0.1) Gecko/2008070208 Firefox/3.0.1&quot;,&quot;e&quot;:&quot;2017-02-06 \r\n        &quot;,&quot;f&quot;:&quot;03&quot;,&quot;g&quot;:&quot;example&quot;,&quot;h&quot;:&quot;logA&quot;,&quot;i&quot;:&quot;IFX&quot;,&quot;j&quot;:&quot;a85&quot;,&quot;k&quot;:&quot;12345678&quot;},\r\n    {&quot;1a&quot;:&quot;2017-01-28 00:00:11&quot;,&quot;2a&quot;:&quot;sample&quot;,&quot;a&quot;:&quot;12345&quot;,&quot;b&quot;:&quot;2017-02-06&quot;,&quot;c&quot;:&quot;2017-02-06T17:51:02.454-08:00&quot;,&quot;d&quot;:&quot;Mozilla/5.0\r\n        ; en-US; rv:1.9.0.1) Gecko/2008070208 Firefox/3.0.1&quot;,&quot;e&quot;:&quot;2017-02-06 \r\n        &quot;,&quot;f&quot;:&quot;03&quot;,&quot;g&quot;:&quot;example&quot;,&quot;h&quot;:&quot;logB&quot;,&quot;i&quot;:&quot;IFX&quot;,&quot;j&quot;:&quot;a85&quot;,&quot;k&quot;:&quot;12345678&quot;}\r\n\r\n**Output**\r\n\r\n    $ awk -F, -v RS=&#39;[{}]&#39; &#39;{s=&quot;&quot;; for(i=1;i&lt;=NF;i++)if($i~/^&quot;(1a|h)&quot;:/)s=(s?s OFS:&quot;&quot;) $i; if(s)print s}&#39;  log \r\n    &quot;1a&quot;:&quot;2017-01-28 00:00:00&quot; &quot;h&quot;:&quot;logA&quot;\r\n    &quot;1a&quot;:&quot;2017-01-28 00:00:11&quot; &quot;h&quot;:&quot;logB&quot;\r\n\r\n",
                "title": "Extract key-value pairs from a JSON file with custom output formatting"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1488201852,
                "last_edit_date": 1495542308,
                "creation_date": 1487791969,
                "answer_id": 42400641,
                "question_id": 42389561,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Instead of standard utilities, consider use of the very flexible **[`jq`](https://stedolan.github.io/jq/) JSON CLI**, which:\r\n\r\n* simplifies the solution\r\n* makes it robust\r\n* allows it to be generalized.\r\n\r\n&lt;!--  --&gt;\r\n\r\n    echo &#39;\r\n    [\r\n      { &quot;1a&quot;:&quot;2017-01-28 00:00:00&quot;, &quot;2a&quot;:&quot;sample&quot;, &quot;h&quot;:&quot;logA&quot;, &quot;i&quot;:&quot;IFX&quot; }, \r\n      { &quot;1a&quot;:&quot;2017-01-28 00:00:11&quot;, &quot;2a&quot;:&quot;sample&quot;, &quot;h&quot;:&quot;logB&quot;, &quot;i&quot;:&quot;IFX&quot; }\r\n    ]&#39; |\r\n      jq -r --argjson keys &#39;[ &quot;1a&quot;, &quot;h&quot; ]&#39; &#39;\r\n        .[] | &quot;\\&quot;\\($keys[0])\\&quot;: \\&quot;\\(.[$keys[0]])\\&quot; \\&quot;\\($keys[1])\\&quot;: \\&quot;\\(.[$keys[1]])\\&quot;&quot;\r\n      &#39; \r\n\r\n&lt;sup&gt;To be self-contained, the command provides literal input via the pipeline and is formatted for readability.  \r\nTo instead pass a _file_ to the `jq` command, simply specify its path after the script&#39;s closing `&#39;`  \r\n(`jq -r ... &#39;...&#39; file.json`)&lt;/sup&gt;\r\n\r\nyields:\r\n\r\n    &quot;1a&quot;: &quot;2017-01-28 00:00:00&quot; &quot;h&quot;: &quot;logA&quot;\r\n    &quot;1a&quot;: &quot;2017-01-28 00:00:11&quot; &quot;h&quot;: &quot;logB&quot;\r\n\r\n* `--argjson keys &#39;[ &quot;1a&quot;, &quot;h&quot; ]&#39;` defines variable `$keys` as a JSON-formatted array of the names of the keys (properties) to extract.\r\n\r\n* `.[]` enumerates all elements of the input array - the individual objects - and `$keys[&lt;n&gt;]` and `.[$keys[&lt;n&gt;]]` expand to the property name with index `&lt;n&gt;` and the _value_ for that property name, respectively (note the `.[...]` accessor).\r\n\r\n* Most of the effort is spent on output formatting: Embedded `&quot;` chars. must be escaped as `\\&quot;`, and embedded variable references must be enclosed in `\\(...)` - although using `+` with separate tokens to build a string is also an option.\r\n\r\n\r\n### Generalizing the solution\r\n\r\nThe above command isn&#39;t easily generalized to an arbitrary number of key-value pairs to output per line, because the because the array indices (`0` and `1`) are *explicitly* specified.\r\n\r\nInspired by [peak&#39;s helpful answer](https://stackoverflow.com/a/42419332/45375), which shows a simple example of defining a helper _function_ in `jq`, the following variant uses a combination of built-in functions and a custom function to **accept an *arbitrary* number of keys to extract**:\r\n\r\n    echo &#39;\r\n    [\r\n      { &quot;1a&quot;:&quot;2017-01-28 00:00:00&quot;, &quot;2a&quot;:&quot;sample&quot;, &quot;h&quot;:&quot;logA&quot;, &quot;i&quot;:&quot;IFX&quot; },\r\n      { &quot;1a&quot;:&quot;2017-01-28 00:00:11&quot;, &quot;2a&quot;:&quot;sample&quot;, &quot;h&quot;:&quot;logB&quot;, &quot;i&quot;:&quot;IFX&quot; }\r\n    ]\r\n    &#39; |\r\n      jq -r --argjson keys &#39;[ &quot;1a&quot;, &quot;h&quot;, &quot;i&quot;  ]&#39; &#39;\r\n        def printKv($k; $v): &quot;\\&quot;\\($k)\\&quot;: \\&quot;\\($v)\\&quot;&quot;;\r\n        .[] | . as $o | \r\n          reduce $keys[] as $k (&quot;&quot;; . + if .==&quot;&quot; then &quot;&quot; else &quot; &quot; end + printKv($k; $o[$k]))\r\n      &#39;\r\n\r\nyields (3 key-value pairs per line, because 3 keys were passed):\r\n\r\n    &quot;1a&quot;: &quot;2017-01-28 00:00:00&quot; &quot;h&quot;: &quot;logA&quot; &quot;i&quot;: &quot;IFX&quot;\r\n    &quot;1a&quot;: &quot;2017-01-28 00:00:11&quot; &quot;h&quot;: &quot;logB&quot; &quot;i&quot;: &quot;IFX&quot;\r\n\r\nThe built-in `reduce` function is used to build up the target string by iterating over the key-value pairs and creating the string representation for each with the help of custom function `printKv`.\r\n\r\n----------\r\n\r\nFollowing another suggestion by [peak](https://stackoverflow.com/users/997358/peak) , here&#39;s **a simpler, more `jq`-like alternative that yields the same output**:\r\n\r\n    echo &#39;\r\n    [\r\n      { &quot;1a&quot;:&quot;2017-01-28 00:00:00&quot;, &quot;2a&quot;:&quot;sample&quot;, &quot;h&quot;:&quot;logA&quot;, &quot;i&quot;:&quot;IFX&quot; },\r\n      { &quot;1a&quot;:&quot;2017-01-28 00:00:11&quot;, &quot;2a&quot;:&quot;sample&quot;, &quot;h&quot;:&quot;logB&quot;, &quot;i&quot;:&quot;IFX&quot; }\r\n    ]\r\n    &#39; |\r\n      jq -r --argjson keys &#39;[ &quot;1a&quot;, &quot;h&quot;, &quot;i&quot;  ]&#39; &#39;\r\n        def printKv($k): &quot;\\&quot;\\($k)\\&quot;: \\&quot;\\(.[$k])\\&quot;&quot;;\r\n        .[] | [ $keys[] as $k | printKv($k) ] | join(&quot; &quot;)\r\n      &#39;\r\n\r\n* `printKv()` now takes only a single parameter - the *key* `$k` - and relies on the pipeline input - still containing the input object - to extract the associated *value* - `.[$k]`\r\n\r\n* Enclosing `$keys[] as $k | printKv($k)` in `[ ... ]` passes the output from the _multiple_ `printKv` calls as a _single array_ through the pipeline.\r\n\r\n* This then allows the built-in `join` function to join the array elements with spaces to form a single output line.\r\n\r\n\r\n",
                "title": "Extract key-value pairs from a JSON file with custom output formatting"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1487997135,
                "last_edit_date": 1487997135,
                "creation_date": 1487862146,
                "answer_id": 42419332,
                "question_id": 42389561,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "This is a tweak of @mklement0&#39;s excellent answer. By defining a &quot;print-me&quot; function, the tweak minimizes the annoyance of having to escape double-quotation marks:\r\n\r\n    def q: &quot;\\&quot;\\(tostring)\\&quot;&quot;;\r\n\r\n    .[] | &quot;\\($keys[0]|q): \\(.[$keys[0]]|q) \\($keys[1]|q): \\(.[$keys[1]]|q)&quot;\r\n\r\n\r\nOr if you prefer:\r\n\r\n    def printKV($k): &quot;\\&quot;\\($k)\\&quot;: \\&quot;\\(.[$k])\\&quot;&quot;; \r\n\r\n    .[] | printKV($keys[0]) + &quot; &quot; + printKV($keys[1])\r\n\r\n### Generalized solution\r\n\r\nWith `printKV/1` as defined immediately above, and assuming $keys is defined on the command line (or by other means) as an array of strings:\r\n\r\n    def printKeyValues(keys):\r\n      [keys[] as $key | printKV($key)] | join(&quot; &quot;);\r\n\r\n    .[] | printKeyValues($keys)\r\n\r\n",
                "title": "Extract key-value pairs from a JSON file with custom output formatting"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": 1,
        "last_activity_date": 1488201852,
        "creation_date": 1487761732,
        "last_edit_date": 1487859842,
        "question_id": 42389561,
        "body_markdown": "I want to grep a combination of two words from a huge log file, the words are scattered and not in any particular order.\r\n\r\nSample log:\r\n\r\n        {&quot;1a&quot;:&quot;2017-01-28 00:00:00&quot;,&quot;2a&quot;:&quot;sample&quot;,&quot;a&quot;:&quot;12345&quot;,&quot;b&quot;:&quot;2017-02-06&quot;,&quot;c&quot;:&quot;2017-02-06T17:51:02.454-08:00&quot;,&quot;d&quot;:&quot;Mozilla/5.0\r\n        ; en-US; rv:1.9.0.1) Gecko/2008070208 Firefox/3.0.1&quot;,&quot;e&quot;:&quot;2017-02-06 \r\n        &quot;,&quot;f&quot;:&quot;03&quot;,&quot;g&quot;:&quot;example&quot;,&quot;h&quot;:&quot;logA&quot;,&quot;i&quot;:&quot;IFX&quot;,&quot;j&quot;:&quot;a85&quot;,&quot;k&quot;:&quot;12345678&quot;},\r\n    {&quot;1a&quot;:&quot;2017-01-28 00:00:11&quot;,&quot;2a&quot;:&quot;sample&quot;,&quot;a&quot;:&quot;12345&quot;,&quot;b&quot;:&quot;2017-02-06&quot;,&quot;c&quot;:&quot;2017-02-06T17:51:02.454-08:00&quot;,&quot;d&quot;:&quot;Mozilla/5.0\r\n        ; en-US; rv:1.9.0.1) Gecko/2008070208 Firefox/3.0.1&quot;,&quot;e&quot;:&quot;2017-02-06 \r\n        &quot;,&quot;f&quot;:&quot;03&quot;,&quot;g&quot;:&quot;example&quot;,&quot;h&quot;:&quot;logB&quot;,&quot;i&quot;:&quot;IFX&quot;,&quot;j&quot;:&quot;a85&quot;,&quot;k&quot;:&quot;12345678&quot;}\r\n\r\nIn this file, I want to grep `&quot;1a&quot;:&quot;&lt;value&gt;&quot;` and `&quot;h&quot;:&quot;&lt;value of logA or logB&gt;&quot;` which there should not be any duplicates.\r\n\r\nExpected Output:\r\n\r\n    &quot;1a&quot;:&quot;2017-01-28 00:00:00&quot; &quot;h&quot;:&quot;logA&quot;\r\n    &quot;1a&quot;:&quot;2017-01-28 00:00:11&quot; &quot;h&quot;:&quot;logB&quot;\r\n\r\nI tried using egrep this way but it gives the entire line :\r\n \r\n    egrep -oE &#39;1a\\|&quot;h&quot;&#39; but this does not give the required output.\r\n\r\n    awk /pattern1/ &amp;&amp; /pattern2/ filename #no use\r\n\r\nThanks for the help",
        "link": "https://stackoverflow.com/questions/42389561/extract-key-value-pairs-from-a-json-file-with-custom-output-formatting",
        "title": "Extract key-value pairs from a JSON file with custom output formatting"
    },
    {
        "tags": [
            "json",
            "key",
            "jq",
            "flatten"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1487797924,
                "creation_date": 1487797924,
                "answer_id": 42402377,
                "question_id": 42401073,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Given the following input :\r\n\r\n    {\r\n     &quot;key1&quot;: [{&quot;name&quot;:&quot;Emma&quot;},{&quot;name&quot;:&quot;Bob&quot;}],\r\n     &quot;key2&quot;: [{&quot;name&quot;:&quot;Jean&quot;}]\r\n    }\r\n\r\nYou can divide your items to entries, store the key in a variable and add the value for each item in `value` object:\r\n\r\n    jq  &#39;[ to_entries[] | .key as $parent | .value[] |\r\n       .[&quot;parent-key-name&quot;] |= (.+ $parent) ] &#39; test.json\r\n\r\nwhich gives the following output :\r\n\r\n    [\r\n      {\r\n        &quot;name&quot;: &quot;Emma&quot;,\r\n        &quot;parent-key-name&quot;: &quot;key1&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;Bob&quot;,\r\n        &quot;parent-key-name&quot;: &quot;key1&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;Jean&quot;,\r\n        &quot;parent-key-name&quot;: &quot;key2&quot;\r\n      }\r\n    ]\r\n\r\n",
                "title": "Flatten JSON with jq retaining key names"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1487836784,
                "last_edit_date": 1487836784,
                "creation_date": 1487799851,
                "answer_id": 42402871,
                "question_id": 42401073,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The solution presented below consists of two steps, each of which might be helpful separately, e.g. if someone wants to &quot;flatten&quot; the JSON in a slightly different way.\r\n\r\n1. First, let&#39;s make the changes to obj[i] &quot;in-place&quot;:\r\n\r\n    with_entries( .key as $k | .value[] |= ( . + {&quot;parent-key-name&quot;: $k} ) )\r\n\r\nExample:\r\n\r\n    $ jq -n -c -f program.jq\r\n\r\nInput:\r\n    {\r\n     &quot;key1&quot;: [{a:1}, {a:2}],\r\n     &quot;key2&quot;: [{b:3}] \r\n    } \r\n\r\nOutput:\r\n\r\n    {\r\n      &quot;key1&quot;: [\r\n        {\r\n          &quot;a&quot;: 1,\r\n          &quot;parent-key-name&quot;: &quot;key1&quot;\r\n        },\r\n        {\r\n          &quot;a&quot;: 2,\r\n          &quot;parent-key-name&quot;: &quot;key1&quot;\r\n        }\r\n      ],\r\n      &quot;key2&quot;: [\r\n        {\r\n          &quot;b&quot;: 3,\r\n          &quot;parent-key-name&quot;: &quot;key2&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\n2. To flatten, simply append `| [.[]]` to the above filter. This produces:\r\n\r\n   [[{&quot;a&quot;:1,&quot;parent-key-name&quot;:&quot;key1&quot;},{&quot;a&quot;:2,&quot;parent-key-name&quot;:&quot;key1&quot;}],[{&quot;b&quot;:3,&quot;parent-key-name&quot;:&quot;key2&quot;}]]\r\n",
                "title": "Flatten JSON with jq retaining key names"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 3,
        "last_activity_date": 1487836784,
        "creation_date": 1487793497,
        "last_edit_date": 1487793974,
        "question_id": 42401073,
        "body_markdown": "I&#39;m trying to flatten a JSON consisting of nested objects. The top layer contains several key/value pairs, where each value is itself an array of a number of objects (the bottom layer).\r\n\r\nWhat I would like to get, using jq, is simply an array of objects containing all the objects of the bottom layer, each of which with an additional key/value pair identifying the top-layer key it originally belonged to.\r\n\r\nIn other words, I would like to turn a JSON\r\n\r\n    {\r\n     &quot;key1&quot;: [obj1, obj2],\r\n     &quot;key2&quot;: [obj3]\r\n    }\r\n\r\ninto a plain array\r\n\r\n    [OBJ1, OBJ2, OBJ3]\r\n\r\nwhere each `OBJi` is simply the original object with an extra key/value pair\r\n\r\n    &quot;parent-key-name&quot;: keyx\r\n\r\nwhere `keyx` would be the top-layer key `obji` belonged to, i.e. `&quot;key1&quot;` for `obj1` and `obj2`, and `&quot;key2&quot;` for `obj3`.\r\n\r\nI&#39;m struggling with the fact that when referencing the objects in the bottom layer, e.g. via .[], jq does not seem to have inbuilt functionality to access associated top-layer information. However, I&#39;m new to jq, and hope there is an easy solution after all.\r\n",
        "link": "https://stackoverflow.com/questions/42401073/flatten-json-with-jq-retaining-key-names",
        "title": "Flatten JSON with jq retaining key names"
    },
    {
        "tags": [
            "json",
            "linux",
            "bash",
            "csv",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1143565,
                    "reputation": 535973,
                    "user_id": 1126841,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa05233b2357f8d11c22ef4cfc7bb85c?s=256&d=identicon&r=PG",
                    "display_name": "chepner",
                    "link": "https://stackoverflow.com/users/1126841/chepner"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1487852323,
                "post_id": 42414365,
                "comment_id": 71976381,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 9339614,
                    "reputation": 1141,
                    "user_id": 6932839,
                    "user_type": "registered",
                    "accept_rate": 74,
                    "profile_image": "https://i.sstatic.net/62p5n.jpg?s=256",
                    "display_name": "arnpry",
                    "link": "https://stackoverflow.com/users/6932839/arnpry"
                },
                "reply_to_user": {
                    "account_id": 1143565,
                    "reputation": 535973,
                    "user_id": 1126841,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa05233b2357f8d11c22ef4cfc7bb85c?s=256&d=identicon&r=PG",
                    "display_name": "chepner",
                    "link": "https://stackoverflow.com/users/1126841/chepner"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1487852598,
                "post_id": 42414365,
                "comment_id": 71976557,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1487852737,
                "post_id": 42414365,
                "comment_id": 71976650,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 3026269,
                    "reputation": 1103,
                    "user_id": 2566213,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/eb644d42facc08e6ef0cdfdb60cc92c3?s=256&d=identicon&r=PG",
                    "display_name": "rindeal",
                    "link": "https://stackoverflow.com/users/2566213/rindeal"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1487852920,
                "post_id": 42414365,
                "comment_id": 71976770,
                "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"
                },
                "reply_to_user": {
                    "account_id": 3026269,
                    "reputation": 1103,
                    "user_id": 2566213,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/eb644d42facc08e6ef0cdfdb60cc92c3?s=256&d=identicon&r=PG",
                    "display_name": "rindeal",
                    "link": "https://stackoverflow.com/users/2566213/rindeal"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1487853738,
                "post_id": 42414365,
                "comment_id": 71977356,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 7,
                "is_accepted": true,
                "score": 6,
                "last_activity_date": 1536138551,
                "last_edit_date": 1536138551,
                "creation_date": 1487854873,
                "answer_id": 42416494,
                "question_id": 42414365,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It&#39;s a bit more complex because you need to flatten `sids`, `ll` and `smry` before you can flatten the whole record. I recommend to create a `jq` file:\r\n\r\n*foo.jq*:\r\n\r\n    .data[]|{\r\n        &quot;sids&quot;:(.meta.sids[0]|split(&quot; &quot;)[0]),\r\n        &quot;ll&quot;:(.meta.ll|map(tostring)|join(&quot;,&quot;)),\r\n        &quot;state&quot;:.meta.state,\r\n        &quot;name&quot;:.meta.name,\r\n        &quot;smry&quot;:(.smry[]|join(&quot;,&quot;))\r\n    }|join(&quot;,&quot;)\r\n    # or, for robust csv output\r\n    # } | @csv \r\n\r\nAnd then call:\r\n\r\n    jq -rf foo.jq file.json\r\n\r\nOutput:\r\n\r\n    CA008102500,-66.9333,47.0667,NB,LONG LAKE,42,1955-02-23\r\n    CA008103425,-67.2333,45.9667,NB,NACKAWIC,40,1969-02-23\r\n    CA008104933,-67.4667,47.4667,NB,ST QUENTIN,M,M\r\n    CA008104936,-67.2667,45.1833,NB,ST STEPHEN,48,1900-02-23\r\n    CA008105000,-67.25,47.2667,NB,SISSON DAM,35,1955-02-23\r\n\r\n",
                "title": "Convert JSON to CSV with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1536138551,
        "creation_date": 1487848968,
        "last_edit_date": 1487851994,
        "question_id": 42414365,
        "body_markdown": "I&#39;m trying to extract the `sids, ll, state, name, smry` values in my `JSON` file using `jq` and export to a csv.\r\n\r\n**JSON File (out.json):**\r\n\r\n    {\r\n    \t&quot;data&quot;: [\r\n    \t\t{\r\n    \t\t\t&quot;meta&quot;: {\r\n    \t\t\t\t&quot;uid&quot;: 74529,\r\n    \t\t\t\t&quot;ll&quot;: [\r\n    \t\t\t\t\t-66.9333,\r\n    \t\t\t\t\t47.0667\r\n    \t\t\t\t],\r\n    \t\t\t\t&quot;sids&quot;: [\r\n    \t\t\t\t\t&quot;CA008102500 6&quot;\r\n    \t\t\t\t],\r\n    \t\t\t\t&quot;state&quot;: &quot;NB&quot;,\r\n    \t\t\t\t&quot;elev&quot;: 1250,\r\n    \t\t\t\t&quot;name&quot;: &quot;LONG LAKE&quot;\r\n    \t\t\t},\r\n    \t\t\t&quot;smry&quot;: [\r\n    \t\t\t\t[\r\n    \t\t\t\t\t&quot;42&quot;,\r\n    \t\t\t\t\t&quot;1955-02-23&quot;\r\n    \t\t\t\t]\r\n    \t\t\t]\r\n    \t\t},\r\n    \t\t{\r\n    \t\t\t&quot;meta&quot;: {\r\n    \t\t\t\t&quot;uid&quot;: 74534,\r\n    \t\t\t\t&quot;ll&quot;: [\r\n    \t\t\t\t\t-67.2333,\r\n    \t\t\t\t\t45.9667\r\n    \t\t\t\t],\r\n    \t\t\t\t&quot;sids&quot;: [\r\n    \t\t\t\t\t&quot;CA008103425 6&quot;\r\n    \t\t\t\t],\r\n    \t\t\t\t&quot;state&quot;: &quot;NB&quot;,\r\n    \t\t\t\t&quot;elev&quot;: 150.9,\r\n    \t\t\t\t&quot;name&quot;: &quot;NACKAWIC&quot;\r\n    \t\t\t},\r\n    \t\t\t&quot;smry&quot;: [\r\n    \t\t\t\t[\r\n    \t\t\t\t\t&quot;40&quot;,\r\n    \t\t\t\t\t&quot;1969-02-23&quot;\r\n    \t\t\t\t]\r\n    \t\t\t]\r\n    \t\t},\r\n    \t\t{\r\n    \t\t\t&quot;meta&quot;: {\r\n    \t\t\t\t&quot;uid&quot;: 74549,\r\n    \t\t\t\t&quot;ll&quot;: [\r\n    \t\t\t\t\t-67.4667,\r\n    \t\t\t\t\t47.4667\r\n    \t\t\t\t],\r\n    \t\t\t\t&quot;sids&quot;: [\r\n    \t\t\t\t\t&quot;CA008104933 6&quot;\r\n    \t\t\t\t],\r\n    \t\t\t\t&quot;state&quot;: &quot;NB&quot;,\r\n    \t\t\t\t&quot;elev&quot;: 794,\r\n    \t\t\t\t&quot;name&quot;: &quot;ST QUENTIN&quot;\r\n    \t\t\t},\r\n    \t\t\t&quot;smry&quot;: [\r\n    \t\t\t\t[\r\n    \t\t\t\t\t&quot;M&quot;,\r\n    \t\t\t\t\t&quot;M&quot;\r\n    \t\t\t\t]\r\n    \t\t\t]\r\n    \t\t},\r\n    \t\t{\r\n    \t\t\t&quot;meta&quot;: {\r\n    \t\t\t\t&quot;uid&quot;: 74550,\r\n    \t\t\t\t&quot;ll&quot;: [\r\n    \t\t\t\t\t-67.2667,\r\n    \t\t\t\t\t45.1833\r\n    \t\t\t\t],\r\n    \t\t\t\t&quot;sids&quot;: [\r\n    \t\t\t\t\t&quot;CA008104936 6&quot;\r\n    \t\t\t\t],\r\n    \t\t\t\t&quot;state&quot;: &quot;NB&quot;,\r\n    \t\t\t\t&quot;elev&quot;: 36.1,\r\n    \t\t\t\t&quot;name&quot;: &quot;ST STEPHEN&quot;\r\n    \t\t\t},\r\n    \t\t\t&quot;smry&quot;: [\r\n    \t\t\t\t[\r\n    \t\t\t\t\t&quot;48&quot;,\r\n    \t\t\t\t\t&quot;1900-02-23&quot;\r\n    \t\t\t\t]\r\n    \t\t\t]\r\n    \t\t},\r\n    \t\t{\r\n    \t\t\t&quot;meta&quot;: {\r\n    \t\t\t\t&quot;uid&quot;: 74554,\r\n    \t\t\t\t&quot;ll&quot;: [\r\n    \t\t\t\t\t-67.25,\r\n    \t\t\t\t\t47.2667\r\n    \t\t\t\t],\r\n    \t\t\t\t&quot;sids&quot;: [\r\n    \t\t\t\t\t&quot;CA008105000 6&quot;\r\n    \t\t\t\t],\r\n    \t\t\t\t&quot;state&quot;: &quot;NB&quot;,\r\n    \t\t\t\t&quot;elev&quot;: 915.4,\r\n    \t\t\t\t&quot;name&quot;: &quot;SISSON DAM&quot;\r\n    \t\t\t},\r\n    \t\t\t&quot;smry&quot;: [\r\n    \t\t\t\t[\r\n    \t\t\t\t\t&quot;35&quot;,\r\n    \t\t\t\t\t&quot;1955-02-23&quot;\r\n    \t\t\t\t]\r\n    \t\t\t]\r\n    \t\t}\r\n    \t]\r\n    }\r\n\r\n**Terminal Code:**\r\n\r\n    jq &#39;.data | [ {sids, ll, state, name, smry} ]&#39; out.json\r\n\r\nI am getting the following errors:\r\n\r\n    assertion &quot;cb == jq_util_input_next_input_cb&quot; failed: file &quot;/usr/src/ports/jq/jq-1.5-3.x86_64/src/jq-1.5/util.c&quot;, line 371, function: jq_util_input_get_position\r\n    Aborted (core dumped)\r\n\r\n**Example Expected Output:**\r\n\r\n    sids, ll, state, name, smry\r\n    CA008102500, -66.9333, 47.0667, NB, LONG LAKE, 42,1955-02-23\r\n    CA008103425, -67.2333, 45.9667, NB, NACKAWIC, 35,1955-02-23\r\n\r\nWhat am I doing wrong?\r\n",
        "link": "https://stackoverflow.com/questions/42414365/convert-json-to-csv-with-jq",
        "title": "Convert JSON to CSV with jq"
    },
    {
        "tags": [
            "json",
            "object",
            "key",
            "command-line-interface",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 9289464,
                    "reputation": 1901,
                    "user_id": 6898301,
                    "user_type": "registered",
                    "accept_rate": 60,
                    "profile_image": "https://www.gravatar.com/avatar/b15352488cd114b3b5f519de42b4e8ed?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Massimo Petrus",
                    "link": "https://stackoverflow.com/users/6898301/massimo-petrus"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1487893964,
                "post_id": 42427725,
                "comment_id": 72002265,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 90,
                "is_accepted": true,
                "score": 90,
                "last_activity_date": 1746180971,
                "last_edit_date": 1746180971,
                "creation_date": 1487893790,
                "answer_id": 42428341,
                "question_id": 42427725,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "    map( { (.name|tostring): . } ) | add\r\n\r\n(The `tostring` is for safety/robustness.)\r\n\r\n### INDEX/1\r\n\r\nIf your jq has `INDEX/1` (introduced in version 1.6), you can simply write:\r\n\r\n    INDEX(.name)\r\n",
                "title": "Using jq, convert array of objects to object with named keys"
            },
            {
                "up_vote_count": 47,
                "is_accepted": false,
                "score": 47,
                "last_activity_date": 1487894738,
                "creation_date": 1487894738,
                "answer_id": 42428521,
                "question_id": 42427725,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Just build up a new object going through the items in the array.  Add the items to the object with the `name` as the key.\r\n\r\n    reduce .[] as $i ({}; .[$i.name] = $i)",
                "title": "Using jq, convert array of objects to object with named keys"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 60,
        "last_activity_date": 1746180971,
        "creation_date": 1487890417,
        "last_edit_date": 1487939235,
        "question_id": 42427725,
        "body_markdown": "Given a json file in the format as :\r\n\r\n\r\n    [\r\n     {\r\n      name : &quot;A&quot;,\r\n      value : &quot;1&quot;\r\n     },\r\n     {\r\n      name : &quot;B&quot;,\r\n      value : &quot;5&quot;\r\n     },\r\n     {\r\n      name : &quot;E&quot;,\r\n      value : &quot;8&quot;\r\n     }\r\n    ]\r\n\r\nHow would I convert it to something like this using jq:\r\n\r\n    {\r\n     &quot;A&quot; : {\r\n       name : &quot;A&quot;,\r\n       value : &quot;1&quot;\r\n     },\r\n     &quot;B&quot; : {\r\n      name : &quot;B&quot;,\r\n      value : &quot;5&quot;\r\n     },\r\n     &quot;E&quot; : {\r\n      name : &quot;E&quot;,\r\n      value : &quot;8&quot;\r\n     }\r\n    }\r\n\r\n\r\n` jq &#39;{(.[].name) : &quot;the name&quot;}&#39; &#39;myfile.json&#39;` gets me an object with [].name keys but how do I assign the object to it?\r\n",
        "link": "https://stackoverflow.com/questions/42427725/using-jq-convert-array-of-objects-to-object-with-named-keys",
        "title": "Using jq, convert array of objects to object with named keys"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 9480743,
                    "reputation": 1922,
                    "user_id": 7048775,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/c0hRY.jpg?s=256",
                    "display_name": "Chris Cousins",
                    "link": "https://stackoverflow.com/users/7048775/chris-cousins"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1487953498,
                "post_id": 42443409,
                "comment_id": 72030781,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1487953501,
                "last_edit_date": 1495542712,
                "creation_date": 1487953501,
                "answer_id": 42443559,
                "question_id": 42443409,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "I just had a similar question answered yesterday.\r\n\r\n`jq &#39;map( { (.properties.osm_id|tostring): . } ) | add&#39;`\r\n\r\nNote that your desired output is an array [] when it should be an object (for the keys).\r\n\r\n(prev question was https://stackoverflow.com/a/42428341/7613900)",
                "title": "Create object id from JSON key value using jq"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": -3,
        "last_activity_date": 1487953501,
        "creation_date": 1487953097,
        "question_id": 42443409,
        "body_markdown": "I am trying to restructure my JSON by assigning an id to each object in a given array. This id would be created by using an existing key value (osm_id). \r\n\r\nThis is my input:\r\n\r\n    [ \r\n    {\r\n      &quot;geometry&quot; : {\r\n        &quot;coordinates&quot; : [ -0.7118478, 51.0930284 ],\r\n        &quot;type&quot; : &quot;Point&quot;\r\n      },\r\n      &quot;properties&quot; : {\r\n        &quot;osm_id&quot; : &quot;262661&quot;,\r\n        &quot;religion&quot; : &quot;christian&quot;\r\n      },\r\n      &quot;type&quot; : &quot;Feature&quot;\r\n    }, \r\n    {\r\n      &quot;geometry&quot; : {\r\n        &quot;coordinates&quot; : [ -0.7207513, 51.0897118 ],\r\n        &quot;type&quot; : &quot;Point&quot;\r\n      },\r\n      &quot;properties&quot; : {\r\n        &quot;denomination&quot; : &quot;catholic&quot;,\r\n        &quot;osm_id&quot; : &quot;262662&quot;,\r\n        &quot;religion&quot; : &quot;christian&quot;\r\n      },\r\n      &quot;type&quot; : &quot;Feature&quot;\r\n    }\r\n    ]\r\n\r\nThis is my desired output:\r\n\r\n    [\r\n    &quot;262661&quot;: {\r\n      &quot;geometry&quot;: {\r\n        &quot;coordinates&quot;: [\r\n          -0.7118478,\r\n          51.0930284\r\n        ],\r\n        &quot;type&quot;: &quot;Point&quot;\r\n      },\r\n      &quot;properties&quot;: {\r\n        &quot;osm_id&quot;: &quot;262661&quot;,\r\n        &quot;religion&quot;: &quot;christian&quot;\r\n      },\r\n      &quot;type&quot;: &quot;Feature&quot;\r\n    },\r\n    &quot;262662&quot;: {\r\n      &quot;geometry&quot;: {\r\n        &quot;coordinates&quot;: [\r\n          -0.7207513,\r\n          51.0897118\r\n        ],\r\n        &quot;type&quot;: &quot;Point&quot;\r\n      },\r\n      &quot;properties&quot;: {\r\n         &quot;denomination&quot;: &quot;catholic&quot;,\r\n         &quot;osm_id&quot;: &quot;262662&quot;,\r\n         &quot;religion&quot;: &quot;christian&quot;\r\n      },\r\n      &quot;type&quot;: &quot;Feature&quot;\r\n    }\r\n    ]\r\n\r\nI&#39;ve been trying to work with jq to update the data, but I can&#39;t figure out how to assign that top level id. So far I have \r\n\r\n    .[] |= {geometry, properties, type}\r\n\r\nbut anything further results in errors. \r\n\r\nI appreciate any help or input. ",
        "link": "https://stackoverflow.com/questions/42443409/create-object-id-from-json-key-value-using-jq",
        "title": "Create object id from JSON key value using jq"
    },
    {
        "tags": [
            "json",
            "object",
            "updates",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 5772257,
                    "reputation": 1600,
                    "user_id": 4555367,
                    "user_type": "registered",
                    "accept_rate": 73,
                    "profile_image": "https://i.sstatic.net/kA6dj.jpg?s=256",
                    "display_name": "Prasad",
                    "link": "https://stackoverflow.com/users/4555367/prasad"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1487982570,
                "post_id": 42450296,
                "comment_id": 72044792,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 5772257,
                    "reputation": 1600,
                    "user_id": 4555367,
                    "user_type": "registered",
                    "accept_rate": 73,
                    "profile_image": "https://i.sstatic.net/kA6dj.jpg?s=256",
                    "display_name": "Prasad",
                    "link": "https://stackoverflow.com/users/4555367/prasad"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1487982696,
                "post_id": 42450296,
                "comment_id": 72044831,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1487993769,
                "creation_date": 1487993769,
                "answer_id": 42451669,
                "question_id": 42450296,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The problem description seems to assume that the ordering of the key-value pairs within a JSON object is fixed.  Different JSON-oriented tools (and indeed different versions of jq) have different takes on this.  In any case, the following assumes a version of jq that respects the ordering (e.g. jq 1.5); it also assumes that `inputs` is available, though that is inessential.\r\n\r\nThe key to the following solution is the helper function, `map_nth_value/2`, which modifies the value of the nth key in a JSON object:\r\n\r\n    def map_nth_value(n; filter):\r\n      to_entries\r\n      | (.[n] |= {&quot;key&quot;: .key, &quot;value&quot;: (.value | filter)} )\r\n      | from_entries ;\r\n      \r\n    [inputs | select(length &gt; 0) | split(&quot;,&quot;) | map(tonumber)] as $lists\r\n    | reduce range(0; $lists|length) as $i\r\n        ( $object;\r\n          .geo |= map_nth_value($i; .l = $lists[$i] ) )\r\n\r\nWith the above jq program in a file (say program.jq), and with the text file in a file (say input.txt) and the JSON object in a file (say object.json), the following invocation:\r\n\r\n    jq -R -n --argfile object object.json -f program.jq input.txt\r\n\r\nproduces:\r\n\r\n    {\r\n      &quot;events&quot;: {\r\n        &quot;-KKQQIUR7FAVxBOPOFhr&quot;: {\r\n          &quot;dateAdded&quot;: 1487592568926,\r\n          &quot;owner&quot;: &quot;62e6aaa0-a50c-4448-a381-f02efde2316d&quot;,\r\n          &quot;type&quot;: &quot;boycott&quot;\r\n        },\r\n        &quot;-KKjjM-pAXvTuEjDjoj_&quot;: {\r\n          &quot;dateAdded&quot;: 1487933370561,\r\n          &quot;owner&quot;: &quot;62e6aaa0-a50c-4448-a381-f02efde2316d&quot;,\r\n          &quot;type&quot;: &quot;boycott&quot;\r\n        }\r\n      },\r\n      &quot;geo&quot;: {\r\n        &quot;-KKQQIUR7FAVxBOPOFhr&quot;: {\r\n          &quot;.priority&quot;: &quot;qw3yttz1k9&quot;,\r\n          &quot;g&quot;: &quot;qw3yttz1k9&quot;,\r\n          &quot;l&quot;: [\r\n            49.28713,\r\n            -123.124026\r\n          ]\r\n        },\r\n        &quot;-KKjjM-pAXvTuEjDjoj_&quot;: {\r\n          &quot;.priority&quot;: &quot;qw3yttx6bv&quot;,\r\n          &quot;g&quot;: &quot;qw3yttx6bv&quot;,\r\n          &quot;l&quot;: [\r\n            36.12977,\r\n            -115.172811\r\n          ]\r\n        }\r\n      },\r\n      &quot;log&quot;: &quot;null&quot;,\r\n      &quot;users&quot;: {\r\n        &quot;62e6aaa0-a50c-4448-a381-f02efde2316d&quot;: {\r\n          &quot;events&quot;: {\r\n            &quot;-KKQQIUR7FAVxBOPOFhr&quot;: {\r\n              &quot;type&quot;: &quot;boycott&quot;\r\n            },\r\n            &quot;-KKjjM-pAXvTuEjDjoj_&quot;: {\r\n              &quot;type&quot;: &quot;boycott&quot;\r\n            }\r\n          }\r\n        }\r\n      }\r\n    }\r\n\r\n",
                "title": "Replacing specific fields in JSON from text file"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1488083226,
        "creation_date": 1487980905,
        "last_edit_date": 1488083226,
        "question_id": 42450296,
        "body_markdown": "I have a json structure and would like to replace strings in 2 fields that are in a seperate text file. \r\n\r\nHere is the json file with 2 records:\r\n\r\n    {\r\n      &quot;events&quot; : {\r\n        &quot;-KKQQIUR7FAVxBOPOFhr&quot; : {\r\n          &quot;dateAdded&quot; : 1487592568926,\r\n          &quot;owner&quot; : &quot;62e6aaa0-a50c-4448-a381-f02efde2316d&quot;,\r\n          &quot;type&quot; : &quot;boycott&quot;\r\n        },\r\n        &quot;-KKjjM-pAXvTuEjDjoj_&quot; : {\r\n          &quot;dateAdded&quot; : 1487933370561,\r\n          &quot;owner&quot; : &quot;62e6aaa0-a50c-4448-a381-f02efde2316d&quot;,\r\n          &quot;type&quot; : &quot;boycott&quot;\r\n        }\r\n      },\r\n      &quot;geo&quot; : {\r\n        &quot;-KKQQIUR7FAVxBOPOFhr&quot; : {\r\n          &quot;.priority&quot; : &quot;qw3yttz1k9&quot;,\r\n          &quot;g&quot; : &quot;qw3yttz1k9&quot;,\r\n          &quot;l&quot; : [ 40.762632, -73.973837 ]\r\n        },\r\n        &quot;-KKjjM-pAXvTuEjDjoj_&quot; : {\r\n          &quot;.priority&quot; : &quot;qw3yttx6bv&quot;,\r\n          &quot;g&quot; : &quot;qw3yttx6bv&quot;,\r\n          &quot;l&quot; : [ 41.889019, -87.626291 ]\r\n        }\r\n      },\r\n      &quot;log&quot; : &quot;null&quot;,\r\n      &quot;users&quot; : {\r\n        &quot;62e6aaa0-a50c-4448-a381-f02efde2316d&quot; : {\r\n          &quot;events&quot; : {\r\n            &quot;-KKQQIUR7FAVxBOPOFhr&quot; : {\r\n              &quot;type&quot; : &quot;boycott&quot;\r\n            },\r\n            &quot;-KKjjM-pAXvTuEjDjoj_&quot; : {\r\n              &quot;type&quot; : &quot;boycott&quot;\r\n            }\r\n          }\r\n        }\r\n      }\r\n    }\r\n\r\n\r\nAnd here is the txt file that I want to substitue in:\r\n\r\n    49.287130, -123.124026\r\n    36.129770, -115.172811\r\n\r\nThere are lots more records but I kept this to 2 for brevity.\r\n\r\nAny help would be appreciated. Thank you.",
        "link": "https://stackoverflow.com/questions/42450296/replacing-specific-fields-in-json-from-text-file",
        "title": "Replacing specific fields in JSON from text file"
    },
    {
        "tags": [
            "json",
            "unicode",
            "clojure",
            "standards",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1488233513,
                "last_edit_date": 1488233513,
                "creation_date": 1488045898,
                "answer_id": 42459687,
                "question_id": 42457416,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "It&#39;s definitely valid json, but the code unit `D83D` by itself is invalid. Remember, jq isn&#39;t merely interpreting the json, it&#39;s trying to get its value. So that&#39;s not just a stream of characters stored in json anymore once consumed by jq, it&#39;s a string with a definite value.\r\n\r\nThat value is a high surrogate, it must come in pairs which your input apparently doesn&#39;t have. So the string encoded in the file, while valid json, doesn&#39;t represent a valid unicode string which jq is trying to parse into.\r\n\r\nYou need to go through your json and complete the pair(s) if you want to be able to parse it using jq.\r\n\r\n&lt;hr&gt;\r\n\r\nIf you could at least ensure that it is valid json, you could probably use regular expressions to scan through the data to search for mismatched surrogates.  Something like this:\r\n\r\n    \\\\u[Dd][89ABab][0-9A-Fa-f]{2}(?!\\\\u[Dd][C-Fc-f][0-9A-Fa-f]{2})\r\n    |\r\n    (?&lt;!\\\\u[Dd][89ABab][0-9A-Fa-f]{2})\\\\u[Dd][C-Fc-f][0-9A-Fa-f]{2}\r\n\r\nThen you could either strip them off or make a best guess at the missing surrogate.",
                "title": "JQ can&#39;t parse an Unicode emoji character. Is it valid JSON?"
            },
            {
                "up_vote_count": 7,
                "is_accepted": true,
                "score": 7,
                "last_activity_date": 1598004661,
                "last_edit_date": 1633594450,
                "creation_date": 1488057500,
                "answer_id": 42461709,
                "question_id": 42457416,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The [JSON specification][1] says:\r\n\r\n&gt; A string is a sequence of zero or more Unicode characters [UNICODE].\r\n\r\nIn this sense, the string &quot;\\ud83d&quot; is NOT valid JSON ([&quot;+UD83D is not a valid Unicode character&quot;][2]), even though it conforms with the JSON ABNF.  As the standards document goes on to say, there is a discrepancy between the string specification and the ABNF:\r\n\r\n&gt; the ABNF in this specification allows member names and\r\n   string values to contain bit sequences that cannot encode Unicode\r\n   characters; for example, &quot;\\uDEAD&quot; (a single unpaired UTF-16\r\n   surrogate).  Instances of this have been observed, for example, when\r\n   a library truncates a UTF-16 string without checking whether the\r\n   truncation split a surrogate pair.  The behavior of software that\r\n   receives JSON texts containing such values is unpredictable ...\r\n\r\n\r\nSo it would be fair to say that:\r\n\r\n1. &quot;\\uD83D&quot; is not strictly valid JSON, even though it conforms to the ABNF; \r\n\r\n2. jq is within its rights here;\r\n\r\n3. jsonlint is wrong to accept &quot;\\uD83D&quot;.\r\n\r\n### “... strip out these characters”\r\nSee e.g https://stackoverflow.com/questions/12999651/how-to-remove-non-utf-8-characters-from-text-file\r\n\r\n  [1]: https://www.rfc-editor.org/rfc/rfc7159\r\n  [2]: http://www.fileformat.info/info/unicode/char/d83d/index.htm",
                "title": "JQ can&#39;t parse an Unicode emoji character. Is it valid JSON?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1703050067,
                "creation_date": 1703050067,
                "answer_id": 77689383,
                "question_id": 42457416,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use yq (https://github.com/mikefarah/yq) instead, it works without the parsing errors on large datasets where jq fails.",
                "title": "JQ can&#39;t parse an Unicode emoji character. Is it valid JSON?"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 6,
        "last_activity_date": 1703050067,
        "creation_date": 1488033545,
        "last_edit_date": 1488083121,
        "question_id": 42457416,
        "body_markdown": "I have a JSON file, which contains JSON from Clojure&#39;s `data.json` library. The data came from Twitter where people seem to smile a lot. \r\n\r\n    $ cat /tmp/myfile | jq .\r\n\r\nI get:\r\n\r\n    parse error: Invalid \\uXXXX\\uXXXX surrogate pair escape at line 1, column 14862268\r\n\r\nThe offending section is:\r\n\r\n    $ cut -c 14862258-14862269 /tmp/2017-02-23-2\r\n    79-7\\ud83d&quot;,\r\n\r\nSo, this escape code was found in a real JSON file and JQ can&#39;t read it.\r\n\r\n    echo &#39;&quot;\\ud83d&quot;&#39; | jq .\r\n\r\n[Fileformat.info seems to suggest][1] that it should come in a pair:\r\n\r\n    SMILING FACE WITH OPEN MOUTH\r\n    &quot;\\uD83D\\uDE03&quot;\r\n\r\n1. Is this truly an invalid character to find in a JSON file? Is my JSON technically invalid?\r\n\r\n2. Is there a simple utility I can pipe the data through to strip out these characters prior to JQ? Or can I make JQ relax it interpretation?\r\n\r\n\r\n  [1]: http://www.fileformat.info/info/unicode/char/1f603/index.htm",
        "link": "https://stackoverflow.com/questions/42457416/jq-cant-parse-an-unicode-emoji-character-is-it-valid-json",
        "title": "JQ can&#39;t parse an Unicode emoji character. Is it valid JSON?"
    },
    {
        "tags": [
            "arrays",
            "json",
            "bash",
            "unique",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1488177936,
                "creation_date": 1488177936,
                "answer_id": 42479385,
                "question_id": 42479103,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "0.  The sample lines you give are not valid JSON.  Since your preamble introduces them as JSON, the following will assume that you intended to present an array of JSON objects.\r\n\r\n1. The question is unclear in several respects, but from the example, it looks as though `unique` might be what you&#39;re looking for, so consider:\r\n\r\nInvocation: jq -c &#39;unique[]&#39; input.json\r\n\r\nOutput:\r\n\r\n    {&quot;header1&quot;:&quot;a&quot;,&quot;header2&quot;:&quot;1a&quot;,&quot;header3&quot;:&quot;1a&quot;,&quot;header4&quot;:&quot;apple&quot;}\r\n    {&quot;header1&quot;:&quot;a&quot;,&quot;header2&quot;:&quot;2a&quot;,&quot;header3&quot;:&quot;1a&quot;,&quot;header4&quot;:&quot;banana&quot;}\r\n    {&quot;header1&quot;:&quot;b&quot;,&quot;header2&quot;:&quot;1a&quot;,&quot;header3&quot;:&quot;1a&quot;,&quot;header4&quot;:&quot;orange&quot;}\r\n    {&quot;header1&quot;:&quot;b&quot;,&quot;header2&quot;:&quot;1a&quot;,&quot;header3&quot;:&quot;2a&quot;,&quot;header4&quot;:&quot;orange&quot;}\r\n    {&quot;header1&quot;:&quot;b&quot;,&quot;header2&quot;:&quot;2a&quot;,&quot;header3&quot;:&quot;2a&quot;,&quot;header4&quot;:&quot;orange&quot;}\r\n    {&quot;header1&quot;:&quot;c&quot;,&quot;header2&quot;:&quot;1a&quot;,&quot;header3&quot;:&quot;2a&quot;,&quot;header4&quot;:&quot;banana&quot;}\r\n    {&quot;header1&quot;:&quot;d&quot;,&quot;header2&quot;:&quot;1a&quot;,&quot;header3&quot;:&quot;1a&quot;,&quot;header4&quot;:&quot;apple&quot;}\r\n    {&quot;header1&quot;:&quot;d&quot;,&quot;header2&quot;:&quot;2a&quot;,&quot;header3&quot;:&quot;1a&quot;,&quot;header4&quot;:&quot;apple&quot;}\r\n    \r\n3. If you need the output in some other format, you could do that using jq as well, but the requirements are not so clear, so let&#39;s leave that as an exercise :-)\r\n\r\n",
                "title": "Unique combinations of different values in json using jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1503038569,
                "creation_date": 1503038569,
                "answer_id": 45750116,
                "question_id": 42479103,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Since as [peak](https://stackoverflow.com/users/997358/peak) indicated your input isn&#39;t legal JSON I&#39;ve taken the liberty of correcting it and converting to a list of individual objects:\r\n\r\n    {&quot;header1&quot;:&quot;a&quot;,&quot;header2&quot;:&quot;1a&quot;, &quot;header3&quot;:&quot;1a&quot;, &quot;header4&quot;:&quot;apple&quot;}\r\n    {&quot;header1&quot;:&quot;b&quot;,&quot;header2&quot;:&quot;2a&quot;, &quot;header3&quot;:&quot;2a&quot;, &quot;header4&quot;:&quot;orange&quot;}\r\n    {&quot;header1&quot;:&quot;c&quot;,&quot;header2&quot;:&quot;1a&quot;, &quot;header3&quot;:&quot;2a&quot;, &quot;header4&quot;:&quot;banana&quot;}\r\n    {&quot;header1&quot;:&quot;d&quot;,&quot;header2&quot;:&quot;2a&quot;, &quot;header3&quot;:&quot;1a&quot;, &quot;header4&quot;:&quot;apple&quot;}\r\n    {&quot;header1&quot;:&quot;a&quot;,&quot;header2&quot;:&quot;2a&quot;, &quot;header3&quot;:&quot;1a&quot;, &quot;header4&quot;:&quot;banana&quot;}\r\n    {&quot;header1&quot;:&quot;b&quot;,&quot;header2&quot;:&quot;1a&quot;, &quot;header3&quot;:&quot;2a&quot;, &quot;header4&quot;:&quot;orange&quot;}\r\n    {&quot;header1&quot;:&quot;b&quot;,&quot;header2&quot;:&quot;1a&quot;, &quot;header3&quot;:&quot;1a&quot;, &quot;header4&quot;:&quot;orange&quot;}\r\n    {&quot;header1&quot;:&quot;d&quot;,&quot;header2&quot;:&quot;1a&quot;, &quot;header3&quot;:&quot;1a&quot;, &quot;header4&quot;:&quot;apple&quot;}\r\n    {&quot;header1&quot;:&quot;a&quot;,&quot;header2&quot;:&quot;2a&quot;, &quot;header3&quot;:&quot;1a&quot;, &quot;header4&quot;:&quot;banana&quot;}\r\n\r\nIf this data is in `data.json` and you run\r\n\r\n    jq -M -s -f filter.jq data.json\r\n\r\nwith the following `filter.jq`\r\n\r\n    foreach .[] as $r (\r\n      {}\r\n    ; ($r | map(.)) as $p | if getpath($p) then empty else setpath($p;1) end\r\n    ; $r\r\n    )\r\n\r\nit will generate the following output in the original order with no duplicates.\r\n\r\n    {&quot;header1&quot;:&quot;a&quot;,&quot;header2&quot;:&quot;1a&quot;,&quot;header3&quot;:&quot;1a&quot;,&quot;header4&quot;:&quot;apple&quot;}\r\n    {&quot;header1&quot;:&quot;b&quot;,&quot;header2&quot;:&quot;2a&quot;,&quot;header3&quot;:&quot;2a&quot;,&quot;header4&quot;:&quot;orange&quot;}\r\n    {&quot;header1&quot;:&quot;c&quot;,&quot;header2&quot;:&quot;1a&quot;,&quot;header3&quot;:&quot;2a&quot;,&quot;header4&quot;:&quot;banana&quot;}\r\n    {&quot;header1&quot;:&quot;d&quot;,&quot;header2&quot;:&quot;2a&quot;,&quot;header3&quot;:&quot;1a&quot;,&quot;header4&quot;:&quot;apple&quot;}\r\n    {&quot;header1&quot;:&quot;a&quot;,&quot;header2&quot;:&quot;2a&quot;,&quot;header3&quot;:&quot;1a&quot;,&quot;header4&quot;:&quot;banana&quot;}\r\n    {&quot;header1&quot;:&quot;b&quot;,&quot;header2&quot;:&quot;1a&quot;,&quot;header3&quot;:&quot;2a&quot;,&quot;header4&quot;:&quot;orange&quot;}\r\n    {&quot;header1&quot;:&quot;b&quot;,&quot;header2&quot;:&quot;1a&quot;,&quot;header3&quot;:&quot;1a&quot;,&quot;header4&quot;:&quot;orange&quot;}\r\n    {&quot;header1&quot;:&quot;d&quot;,&quot;header2&quot;:&quot;1a&quot;,&quot;header3&quot;:&quot;1a&quot;,&quot;header4&quot;:&quot;apple&quot;}\r\n   \r\nNote that the\r\n\r\n    ($r | map(.))\r\n\r\nis used to generate an array containing just the values from each row\r\nwhich is assumed to always produce a unique key path. This is true for\r\nthe sample data but may not be true for more complex values.\r\n\r\nA slower but more robust `filter.jq` is\r\n\r\n    foreach .[] as $r (\r\n      {}\r\n    ; [$r | tojson] as $p | if getpath($p) then empty else setpath($p;1) end\r\n    ; $r\r\n    )\r\n\r\nwhich uses the json representation of the entire row as a unique key to determine if a row has been previously seen.\r\n",
                "title": "Unique combinations of different values in json using jq"
            }
        ],
        "is_answered": false,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1503038569,
        "creation_date": 1488176722,
        "last_edit_date": 1488179337,
        "question_id": 42479103,
        "body_markdown": "I have a json file(input.json) which looks like this : \r\n\r\n        \r\n    {&quot;header1&quot;:&quot;a&quot;,&quot;header2&quot;:1a, &quot;header3&quot;:1a, &quot;header4&quot;:&quot;apple&quot;},\r\n    {&quot;header1&quot;:&quot;b&quot;,&quot;header2&quot;:2a, &quot;header3&quot;:2a, &quot;header4&quot;:&quot;orange&quot;}\r\n    {&quot;header1&quot;:&quot;c&quot;,&quot;header2&quot;:1a, &quot;header3&quot;:2a, &quot;header4&quot;:&quot;banana&quot;},\r\n    {&quot;header1&quot;:&quot;d&quot;,&quot;header2&quot;:2a, &quot;header3&quot;:1a, &quot;header4&quot;:&quot;apple&quot;},\r\n    {&quot;header1&quot;:&quot;a&quot;,&quot;header2&quot;:2a, &quot;header3&quot;:1a, &quot;header4&quot;:&quot;banana&quot;},\r\n    {&quot;header1&quot;:&quot;b&quot;,&quot;header2&quot;:1a, &quot;header3&quot;:2a, &quot;header4&quot;:&quot;orange&quot;},\r\n    {&quot;header1&quot;:&quot;b&quot;,&quot;header2&quot;:1a, &quot;header3&quot;:1a, &quot;header4&quot;:&quot;orange&quot;},\r\n    {&quot;header1&quot;:&quot;d&quot;,&quot;header2&quot;:1a, &quot;header3&quot;:1a, &quot;header4&quot;:&quot;apple&quot;},\r\n    {&quot;header1&quot;:&quot;a&quot;,&quot;header2&quot;:2a, &quot;header3&quot;:1a, &quot;header4&quot;:&quot;banana&quot;} (repeat of line 5)\r\n\r\nI want to filter out only the unique combinations of each of the values jq. \r\nResults should look like:\r\n\r\n    {&quot;header1&quot;:&quot;a&quot;,&quot;header2&quot;:1a, &quot;header3&quot;:1a, &quot;header4&quot;:&quot;apple&quot;},\r\n    {&quot;header1&quot;:&quot;b&quot;,&quot;header2&quot;:2a, &quot;header3&quot;:2a, &quot;header4&quot;:&quot;orange&quot;}\r\n    {&quot;header1&quot;:&quot;c&quot;,&quot;header2&quot;:1a, &quot;header3&quot;:2a, &quot;header4&quot;:&quot;banana&quot;},\r\n    {&quot;header1&quot;:&quot;d&quot;,&quot;header2&quot;:2a, &quot;header3&quot;:1a, &quot;header4&quot;:&quot;apple&quot;},\r\n    {&quot;header1&quot;:&quot;a&quot;,&quot;header2&quot;:2a, &quot;header3&quot;:1a, &quot;header4&quot;:&quot;banana&quot;},\r\n    {&quot;header1&quot;:&quot;b&quot;,&quot;header2&quot;:1a, &quot;header3&quot;:2a, &quot;header4&quot;:&quot;orange&quot;},\r\n    {&quot;header1&quot;:&quot;b&quot;,&quot;header2&quot;:1a, &quot;header3&quot;:1a, &quot;header4&quot;:&quot;orange&quot;},\r\n    {&quot;header1&quot;:&quot;d&quot;,&quot;header2&quot;:1a, &quot;header3&quot;:1a, &quot;header4&quot;:&quot;apple&quot;}\r\n\r\nI tried doing group by of header1 with the other headers but it didn&#39;t generate unique results.\r\nI&#39;ve used `unique` but that didnt generate the proper results.\r\n\r\nHow can I get this? Im new to jq and not finding many tutorials on it.\r\n\r\nThanks\r\n",
        "link": "https://stackoverflow.com/questions/42479103/unique-combinations-of-different-values-in-json-using-jq",
        "title": "Unique combinations of different values in json using jq"
    },
    {
        "tags": [
            "json",
            "bash",
            "csv",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1488180456,
                "creation_date": 1488180456,
                "answer_id": 42479990,
                "question_id": 42479789,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You could use `sed`:\r\n\r\n    jq -r &quot;.detected,.result&quot; dum_1.json | sed &#39;N;s/\\n/ , /&#39;\r\n    true , Trojan.Win32.Generic!BT\r\n    true , FileCryptor.NJX\r\n    true , Generic.Ransom.Purge.DC87C66E\r\n\r\nThe `sed` `N` command read the next line, joining the 2 lines together.\r\n\r\nThe `s` command is replacing the newline `\\n` with the wanted pattern ` , `.\r\n\r\n",
                "title": "Parsing Complex JSON file with JQ Issue"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1488180493,
                "creation_date": 1488180493,
                "answer_id": 42480004,
                "question_id": 42479789,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "    jq -r &quot;.detected,.result&quot; dum_1.json |awk -v OFS=, &#39;NR%2{x=$0;next} {print x OFS $0}&#39;\r\n    true,Trojan.Win32.Generic!BT\r\n    true,FileCryptor.NJX\r\n    true,Generic.Ransom.Purge.DC87C66E\r\n",
                "title": "Parsing Complex JSON file with JQ Issue"
            },
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1488180681,
                "creation_date": 1488180681,
                "answer_id": 42480047,
                "question_id": 42479789,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "@csv will convert from a flat array to CSV, so this should get you started:\r\n\r\n    jq -r &#39;[.detected, .result] | @csv&#39;\r\n\r\nGiven your sample input, this will produce:\r\n\r\n    true,&quot;Trojan.Win32.Generic!BT&quot;\r\n    true,&quot;FileCryptor.NJX&quot;\r\n    true,&quot;Generic.Ransom.Purge.DC87C66E&quot;\r\n\r\nIf you want the quotation marks removed, then consider:\r\n\r\n    jq -r &#39;&quot;\\(.detected), \\(.result)&quot;&#39;",
                "title": "Parsing Complex JSON file with JQ Issue"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 3,
        "last_activity_date": 1488250511,
        "creation_date": 1488179610,
        "last_edit_date": 1488250511,
        "question_id": 42479789,
        "body_markdown": "I have big JSON file with 100000 results. I know how to do basic parsing with `&#39;JQ&#39;`.\r\n\r\n#virus.json\r\n\r\n  \r\n\r\n    {\r\n      &quot;detected&quot;: true,\r\n      &quot;result&quot;: &quot;Trojan.Win32.Generic!BT&quot;,\r\n      &quot;update&quot;: &quot;20170115&quot;,\r\n      &quot;version&quot;: &quot;1.5.0.42&quot;\r\n    }\r\n    {\r\n      &quot;detected&quot;: true,\r\n      &quot;result&quot;: &quot;FileCryptor.NJX&quot;,\r\n      &quot;update&quot;: &quot;20170115&quot;,\r\n      &quot;version&quot;: &quot;16.0.0.4749&quot;\r\n    }\r\n    {\r\n      &quot;detected&quot;: true,\r\n      &quot;result&quot;: &quot;Generic.Ransom.Purge.DC87C66E&quot;,\r\n      &quot;update&quot;: &quot;20170115&quot;,\r\n      &quot;version&quot;: &quot;1.0.1.9&quot;\r\n    }\r\n\r\n But on this JSON file , I would like to get the fields such as &quot;detected&quot; and &quot;result&quot; in a `CSV` format. I know how to get it individually using JQ. \r\n\r\nI tried , \r\n\r\n#1\r\n    $ jq -r &quot;.detected&quot; virus.json \r\n\r\n    true\r\n    true\r\n    true\r\n\r\n#2 \r\n   \r\n\r\n     $ jq -r &quot;.result&quot; dum_1.json \r\n\r\n        Trojan.Win32.Generic!BT\r\n        FileCryptor.NJX\r\n        Generic.Ransom.Purge.DC87C66E\r\n\r\n#3\r\n\r\n    jq -r &quot;.detected,.result&quot; dum_1.json \r\n    true\r\n    Trojan.Win32.Generic!BT\r\n    true\r\n    FileCryptor.NJX\r\n    true\r\n    Generic.Ransom.Purge.DC87C66E\r\n\r\nInstead of #3 , I would like the output to be as \r\n\r\n#Output \r\n\r\n    true , Trojan.Win32.Generic!BT\r\n    true , FileCryptor.NJX\r\n    true , Generic.Ransom.Purge.DC87C66E\r\n\r\nAny suggestion on how to get the results ? ",
        "link": "https://stackoverflow.com/questions/42479789/parsing-complex-json-file-with-jq-issue",
        "title": "Parsing Complex JSON file with JQ Issue"
    },
    {
        "tags": [
            "json",
            "parsing",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1488194088,
                "creation_date": 1488194088,
                "answer_id": 42484384,
                "question_id": 42484253,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Use this:\r\n\r\n    jq -r &#39;&quot;\\(.name):\\(.tags[])&quot;&#39; file.json",
                "title": "Parse specific output from json with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1488194100,
        "creation_date": 1488193698,
        "last_edit_date": 1488194100,
        "question_id": 42484253,
        "body_markdown": "I am new for jq and been trying to get desired output, but without success.\r\n\r\nSo let&#39;s say I have json content like this:  \r\n\r\n    {  \r\n    \t&quot;name&quot;: &quot;jack&quot;,  \r\n    \t&quot;tags&quot;: [&quot;1.0&quot;, &quot;2.0&quot;]  \r\n    }  \r\n\r\nAnd I would like to get ouput like this:  \r\n\r\n    jack:1.0  \r\n    jack:2.0\r\n\r\nHow to achieve that with jq?\r\n",
        "link": "https://stackoverflow.com/questions/42484253/parse-specific-output-from-json-with-jq",
        "title": "Parse specific output from json with jq"
    },
    {
        "tags": [
            "bash",
            "shell",
            "sh",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 10930,
                    "reputation": 802218,
                    "user_id": 20862,
                    "user_type": "registered",
                    "accept_rate": 50,
                    "profile_image": "https://www.gravatar.com/avatar/2343ae368d3241278581ce6c87f62a25?s=256&d=identicon&r=PG",
                    "display_name": "Ignacio Vazquez-Abrams",
                    "link": "https://stackoverflow.com/users/20862/ignacio-vazquez-abrams"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1488248383,
                "post_id": 42498997,
                "comment_id": 72136965,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 4473891,
                    "reputation": 61,
                    "user_id": 3639451,
                    "user_type": "registered",
                    "accept_rate": 83,
                    "profile_image": "https://www.gravatar.com/avatar/cc052ef968f5f1c12597d40ac51e86c9?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Jagdsh L K",
                    "link": "https://stackoverflow.com/users/3639451/jagdsh-l-k"
                },
                "reply_to_user": {
                    "account_id": 10930,
                    "reputation": 802218,
                    "user_id": 20862,
                    "user_type": "registered",
                    "accept_rate": 50,
                    "profile_image": "https://www.gravatar.com/avatar/2343ae368d3241278581ce6c87f62a25?s=256&d=identicon&r=PG",
                    "display_name": "Ignacio Vazquez-Abrams",
                    "link": "https://stackoverflow.com/users/20862/ignacio-vazquez-abrams"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1488248778,
                "post_id": 42498997,
                "comment_id": 72137074,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 47502,
                    "reputation": 213658,
                    "user_id": 140750,
                    "user_type": "registered",
                    "accept_rate": 92,
                    "profile_image": "https://www.gravatar.com/avatar/4c7af12cad08c95bc206a9636d164224?s=256&d=identicon&r=PG",
                    "display_name": "William Pursell",
                    "link": "https://stackoverflow.com/users/140750/william-pursell"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1488251127,
                "post_id": 42498997,
                "comment_id": 72137671,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1488248551,
                "creation_date": 1488248551,
                "answer_id": 42499037,
                "question_id": 42498997,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You need to quote the command substitution to prevent the result (`1 * 2 * 3`) from undergoing pathname expansion.\r\n\r\n    echo &quot;$(jq -n &#39;&quot;1\\n2\\n3&quot; | gsub(&quot;\\n&quot;; @t &quot; * &quot;)&#39;)&quot;\r\n\r\nKeep in mind, though, that there is no reason capture the output of a command if the *only* thing you do with it is pass it as the lone argument to `echo`. Just let the command run by itself.\r\n\r\n    $ echo &quot;$(jq -n &#39;&quot;1\\n2\\n3&quot; | gsub(&quot;\\n&quot;; @t &quot; * &quot;)&#39;)&quot;\r\n    &quot;1 * 2 * 3&quot;\r\n    $ jq -n &#39;&quot;1\\n2\\n3&quot; | gsub(&quot;\\n&quot;; @t &quot; * &quot;)&#39;\r\n    &quot;1 * 2 * 3&quot;\r\n\r\n(As a bonus, `jq` will probably produce colored output if you aren&#39;t capturing the output.)",
                "title": "jq - How to escape &#39; * &#39; (special character) in shell script?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1488248551,
        "creation_date": 1488248256,
        "question_id": 42498997,
        "body_markdown": "Im using the following command in shell script \r\n\r\n    echo $(jq -n &#39;&quot;1\\n2\\n3&quot; | gsub(&quot;\\n&quot;; @t &quot; * &quot;)&#39;)\r\n\r\nand the expected output is \r\n\r\n    &quot;1 * 2 * 3&quot; \r\n\r\nBut in shell script it replaces &#39;\\n&#39; with all the file names in the respective directory (i.e &#39;*&#39; is treated as a special parameter in this context).\r\n\r\n    1 file1 file2 2 file1 file2 3\r\n\r\nWhen we execute the same in a terminal it gives the expected output.\r\n\r\nCan anyone help me in this?\r\n",
        "link": "https://stackoverflow.com/questions/42498997/jq-how-to-escape-special-character-in-shell-script",
        "title": "jq - How to escape &#39; * &#39; (special character) in shell script?"
    },
    {
        "tags": [
            "json",
            "string",
            "escaping",
            "sh",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 91548,
                    "reputation": 255795,
                    "user_id": 251311,
                    "user_type": "registered",
                    "accept_rate": 97,
                    "profile_image": "https://www.gravatar.com/avatar/b6b0ca5d4ef200ec8e3cd1fa2aefd836?s=256&d=identicon&r=PG",
                    "display_name": "zerkms",
                    "link": "https://stackoverflow.com/users/251311/zerkms"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1488422347,
                "post_id": 42545752,
                "comment_id": 72227256,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 10365554,
                    "reputation": 23,
                    "user_id": 7644703,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b691fe9048c4179adb1985b6439e3772?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "ae701",
                    "link": "https://stackoverflow.com/users/7644703/ae701"
                },
                "reply_to_user": {
                    "account_id": 91548,
                    "reputation": 255795,
                    "user_id": 251311,
                    "user_type": "registered",
                    "accept_rate": 97,
                    "profile_image": "https://www.gravatar.com/avatar/b6b0ca5d4ef200ec8e3cd1fa2aefd836?s=256&d=identicon&r=PG",
                    "display_name": "zerkms",
                    "link": "https://stackoverflow.com/users/251311/zerkms"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1488422568,
                "post_id": 42545752,
                "comment_id": 72227331,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 91548,
                    "reputation": 255795,
                    "user_id": 251311,
                    "user_type": "registered",
                    "accept_rate": 97,
                    "profile_image": "https://www.gravatar.com/avatar/b6b0ca5d4ef200ec8e3cd1fa2aefd836?s=256&d=identicon&r=PG",
                    "display_name": "zerkms",
                    "link": "https://stackoverflow.com/users/251311/zerkms"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1488422804,
                "post_id": 42545752,
                "comment_id": 72227417,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 10365554,
                    "reputation": 23,
                    "user_id": 7644703,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b691fe9048c4179adb1985b6439e3772?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "ae701",
                    "link": "https://stackoverflow.com/users/7644703/ae701"
                },
                "reply_to_user": {
                    "account_id": 91548,
                    "reputation": 255795,
                    "user_id": 251311,
                    "user_type": "registered",
                    "accept_rate": 97,
                    "profile_image": "https://www.gravatar.com/avatar/b6b0ca5d4ef200ec8e3cd1fa2aefd836?s=256&d=identicon&r=PG",
                    "display_name": "zerkms",
                    "link": "https://stackoverflow.com/users/251311/zerkms"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1488423118,
                "post_id": 42545752,
                "comment_id": 72227498,
                "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": 1488427768,
                "post_id": 42545752,
                "comment_id": 72228816,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 10365554,
                    "reputation": 23,
                    "user_id": 7644703,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b691fe9048c4179adb1985b6439e3772?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "ae701",
                    "link": "https://stackoverflow.com/users/7644703/ae701"
                },
                "reply_to_user": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1488428681,
                "post_id": 42545752,
                "comment_id": 72229102,
                "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": 1488428832,
                "post_id": 42545752,
                "comment_id": 72229153,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 1143565,
                    "reputation": 535973,
                    "user_id": 1126841,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa05233b2357f8d11c22ef4cfc7bb85c?s=256&d=identicon&r=PG",
                    "display_name": "chepner",
                    "link": "https://stackoverflow.com/users/1126841/chepner"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1488477569,
                "post_id": 42545752,
                "comment_id": 72259272,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1488425443,
                "last_edit_date": 1488425443,
                "creation_date": 1488423392,
                "answer_id": 42546009,
                "question_id": 42545752,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "If you are trying to include literal backslashes:\r\n\r\n### (bash)\r\n\r\n    echo &#39;{&quot;tag_string&quot;:&quot;/\\\\/\\\\/\\\\ test&quot;}&#39; | jq\r\n    {\r\n      &quot;tag_string&quot;: &quot;/\\\\/\\\\/\\\\ test&quot;\r\n    }\r\n\r\n    echo &#39;{&quot;tag_string&quot;:&quot;/\\\\/\\\\/\\\\ test&quot;}&#39; | jq -r &#39;.[&quot;tag_string&quot;]&#39;\r\n    /\\/\\/\\ test\r\n \r\n\r\n### (sh)\r\n\r\n    echo &#39;{&quot;tag_string&quot;:&quot;/\\\\\\\\/\\\\\\\\/\\\\\\\\ test&quot;}&#39; | jq -r &#39;.[&quot;tag_string&quot;]&#39;\r\n    /\\/\\/\\ test\r\n\r\n    printf &quot;%s&quot; &#39;{&quot;tag_string&quot;:&quot;/\\\\/\\\\/\\\\ test&quot;}&#39; | jq -r &#39;.[&quot;tag_string&quot;]&#39;\r\n    /\\/\\/\\ test\r\n\r\n\r\n",
                "title": "JSON slashes and backslashes in string on bourne shell"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1488643776,
                "last_edit_date": 1488643776,
                "creation_date": 1488423790,
                "answer_id": 42546064,
                "question_id": 42545752,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "A forward slash character is legal, but a single backslash character is not.  According to [json.org][1] char description, the valid chars are:\r\n\r\n&lt;pre&gt;char\r\n    any-Unicode-character-\r\n        except-&quot;-or-\\-or-\r\n        control-character\r\n    \\&quot;\r\n    \\\\\r\n    \\/\r\n    \\b\r\n    \\f\r\n    \\n\r\n    \\r\r\n    \\t\r\n    \\u four-hex-digits &lt;/pre&gt;\r\n\r\nSo in your example, the single backslashes are not legal, you need either &quot;\\\\\\&quot; which is interpreted as double backslashes, or you need to remove them entirely.\r\n\r\n  [1]: http://json.org",
                "title": "JSON slashes and backslashes in string on bourne shell"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1488430042,
                "creation_date": 1488430042,
                "answer_id": 42547082,
                "question_id": 42545752,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "If you are trying to convert a file with non-JSON strings, then consider a tool such as any-json. Using the &quot;cson-to-json&quot; mode, &quot;\\\\/&quot; will be interpreted as &quot;/&quot;:\r\n\r\n    $ any-json -format=cson\r\n\r\nInput:\r\n\r\n    {&quot;tag_string&quot;:&quot;/\\/\\/\\ test&quot;}\r\n\r\nOutput:\r\n\r\n    {\r\n      &quot;tag_string&quot;: &quot;/// test&quot;\r\n    }\r\n\r\n",
                "title": "JSON slashes and backslashes in string on bourne shell"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1488643776,
        "creation_date": 1488421673,
        "last_edit_date": 1488424410,
        "question_id": 42545752,
        "body_markdown": "I am trying to parse json files that contain sequences of slashes and backslashes in some of their strings like this:\r\n\r\n    echo &#39;{&quot;tag_string&quot;:&quot;/\\/\\/\\ test&quot;}&#39; | jq\r\n\r\nwhich gives me:\r\n\r\n    parse error: Invalid escape at line 1, column 27\r\n\r\nI have tried escaping with backslashes at different positions, but I can&#39;t seem to find a correct way. How do I output the string as it is, without removing any character or getting errors?\r\n\r\nThis only works on bash, but not sh (or zsh):\r\n\r\n    echo &#39;{&quot;tag_string&quot;:&quot;/\\\\/\\\\/\\\\ test&quot;}&#39; | jq -r &#39;.tag_string&#39;\r\n    /\\/\\/\\ test\r\n",
        "link": "https://stackoverflow.com/questions/42545752/json-slashes-and-backslashes-in-string-on-bourne-shell",
        "title": "JSON slashes and backslashes in string on bourne shell"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 5654162,
                    "reputation": 345,
                    "user_id": 4473841,
                    "user_type": "registered",
                    "accept_rate": 94,
                    "profile_image": "https://www.gravatar.com/avatar/b36cde502df771c6648c458cf7391e6e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Darkwind",
                    "link": "https://stackoverflow.com/users/4473841/darkwind"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1488446579,
                "post_id": 42551038,
                "comment_id": 72237816,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1488448086,
                "post_id": 42551038,
                "comment_id": 72238870,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1488450614,
                "last_edit_date": 1488450614,
                "creation_date": 1488446655,
                "answer_id": 42551362,
                "question_id": 42551038,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You can use a `jq` filter as below as tested on [jq-play](https://jqplay.org/s/479MnPNJDF)!\r\n\r\n    jq &#39;. | to_entries[] | select(.key | startswith(&quot;photo&quot;)) | &quot;\\(.key) :\\(.value)&quot;&#39; json\r\n    &quot;photo_807 :Ih2RnaBTg2o.jpg&quot;\r\n    &quot;photo_604 :zodCm9fQgX8.jpg&quot;\r\n    &quot;photo_130 :4Dx-SUNKBw4.jpg&quot;\r\n    &quot;photo_75 :7COWb8ou1qA.jpg&quot;\r\n\r\n\r\n\r\nThe idea is to use the [to_entries[]](https://stedolan.github.io/jq/manual/#example23) built-in, which converts your input into a key-value pair as below. See below the output of just using `to_entries[]`\r\n\r\n    jq &#39;. | to_entries[]&#39; json\r\n    {\r\n      &quot;key&quot;: &quot;photo_807&quot;,\r\n      &quot;value&quot;: &quot;Ih2RnaBTg2o.jpg&quot;\r\n    }\r\n    {\r\n      &quot;key&quot;: &quot;photo_604&quot;,\r\n      &quot;value&quot;: &quot;zodCm9fQgX8.jpg&quot;\r\n    }\r\n    {\r\n      &quot;key&quot;: &quot;photo_130&quot;,\r\n      &quot;value&quot;: &quot;4Dx-SUNKBw4.jpg&quot;\r\n    }\r\n    {\r\n      &quot;key&quot;: &quot;photo_75&quot;,\r\n      &quot;value&quot;: &quot;7COWb8ou1qA.jpg&quot;\r\n    }\r\n    {\r\n      &quot;key&quot;: &quot;user_id&quot;,\r\n      &quot;value&quot;: 100\r\n    }\r\n    {\r\n      &quot;key&quot;: &quot;owner_id&quot;,\r\n      &quot;value&quot;: -2435432542783750\r\n    }\r\n    {\r\n      &quot;key&quot;: &quot;access_key&quot;,\r\n      &quot;value&quot;: &quot;fc5275423676514042234324265cc3df7607c&quot;\r\n    }\r\n    {\r\n      &quot;key&quot;: &quot;post_id&quot;,\r\n      &quot;value&quot;: 380435645368865100\r\n    }\r\n    {\r\n      &quot;key&quot;: &quot;date&quot;,\r\n      &quot;value&quot;: 14858616848616779000000000000\r\n    }\r\n    {\r\n      &quot;key&quot;: &quot;text&quot;,\r\n      &quot;value&quot;: &quot;&quot;\r\n    }\r\n    {\r\n      &quot;key&quot;: &quot;height&quot;,\r\n      &quot;value&quot;: 417\r\n    }\r\n    {\r\n      &quot;key&quot;: &quot;width&quot;,\r\n      &quot;value&quot;: 740\r\n    }\r\n    {\r\n      &quot;key&quot;: &quot;id&quot;,\r\n      &quot;value&quot;: 45624575446886885000000000\r\n    }\r\n    {\r\n      &quot;key&quot;: &quot;album_id&quot;,\r\n      &quot;value&quot;: -36\r\n    }\r\n\r\nOn this output, we are filtering on the `.key` value which starts with your string, `photo` in your case, using the built-in [startswith()](https://stedolan.github.io/jq/manual/#example49), and printing the both the `.key` and `.value` pair for the matching objects.",
                "title": "jq select dynamic items from json"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1488450614,
        "creation_date": 1488445722,
        "last_edit_date": 1488446751,
        "question_id": 42551038,
        "body_markdown": "I have JSON like this:\r\n\r\n    {\r\n      &quot;photo_807&quot;: &quot;Ih2RnaBTg2o.jpg&quot;,\r\n      &quot;photo_604&quot;: &quot;zodCm9fQgX8.jpg&quot;,\r\n      &quot;photo_130&quot;: &quot;4Dx-SUNKBw4.jpg&quot;,\r\n      &quot;photo_75&quot;: &quot;7COWb8ou1qA.jpg&quot;,\r\n      &quot;user_id&quot;: 100,\r\n      &quot;owner_id&quot;: -2435432542783750,\r\n      &quot;access_key&quot;: &quot;fc5275423676514042234324265cc3df7607c&quot;,\r\n      &quot;post_id&quot;: 380435645368865101,\r\n      &quot;date&quot;: 14858616848616779856424245814,\r\n      &quot;text&quot;: &quot;&quot;,\r\n      &quot;height&quot;: 417,\r\n      &quot;width&quot;: 740,\r\n      &quot;id&quot;: 45624575446886886564368555,\r\n      &quot;album_id&quot;: -36\r\n    }\r\n\r\nI want to get only Photo values, from output i want get this:\r\n\r\n    &quot;photo_807&quot;: &quot;Ih2RnaBTg2o.jpg&quot;\r\n    &quot;photo_604&quot;: &quot;zodCm9fQgX8.jpg&quot;\r\n    &quot;photo_130&quot;: &quot;4Dx-SUNKBw4.jpg&quot;\r\n\r\nNow about my problem, from next JSON file i will get photo items with new names like this:\r\n\r\n      &quot;photo_181&quot;: &quot;Ih2RnaBTg2o.jpg&quot;,\r\n      &quot;photo_583&quot;: &quot;zodCm9fQgX8.jpg&quot;,\r\n      &quot;photo_975&quot;: &quot;4Dx-SUNKBw4.jpg&quot;,\r\n      &quot;photo_32&quot;: &quot;7COWb8ou1qA.jpg&quot;,\r\n\r\n  How I can get this values from dynamic items photo_* ?\r\n  \r\n  I try something like this:\r\n\r\n      cat  ./json3.txt | jq  &#39;.response.items[].attachments[].photo | select(.photo | startswith(&quot;photo&quot;))&#39;\r\n\r\nBut it doesn&#39;t work. \r\n\r\nWhen I run :\r\n\r\n    cat  ./json3.txt | jq  &#39;.response.items[].attachments[].photo&#39;  \r\n\r\n  I got this output with all items:\r\n\r\n    {\r\n      &quot;photo_807&quot;: &quot;Ih2RnaBTg2o.jpg&quot;,\r\n      &quot;photo_604&quot;: &quot;zodCm9fQgX8.jpg&quot;,\r\n      &quot;photo_130&quot;: &quot;4Dx-SUNKBw4.jpg&quot;,\r\n      &quot;photo_75&quot;: &quot;7COWb8ou1qA.jpg&quot;,\r\n      &quot;user_id&quot;: 100,\r\n      &quot;owner_id&quot;: -2435432542783750,\r\n      &quot;access_key&quot;: &quot;fc5275423676514042234324265cc3df7607c&quot;,\r\n      &quot;post_id&quot;: 380435645368865101,\r\n      &quot;date&quot;: 14858616848616779856424245814,\r\n      &quot;text&quot;: &quot;&quot;,\r\n      &quot;height&quot;: 417,\r\n      &quot;width&quot;: 740,\r\n      &quot;id&quot;: 45624575446886886564368555,\r\n      &quot;album_id&quot;: -36\r\n    }\r\n\r\n  Can someone help me?\r\n  \r\n  Thanks in advance! ",
        "link": "https://stackoverflow.com/questions/42551038/jq-select-dynamic-items-from-json",
        "title": "jq select dynamic items from json"
    },
    {
        "tags": [
            "json",
            "bash",
            "serialization",
            "associative-array",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 4734553,
                    "reputation": 1499,
                    "user_id": 3829310,
                    "user_type": "registered",
                    "accept_rate": 72,
                    "profile_image": "https://i.sstatic.net/blWdU.jpg?s=256",
                    "display_name": "Steve Amerige",
                    "link": "https://stackoverflow.com/users/3829310/steve-amerige"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1488453760,
                "post_id": 42553309,
                "comment_id": 72242658,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 1143565,
                    "reputation": 535973,
                    "user_id": 1126841,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa05233b2357f8d11c22ef4cfc7bb85c?s=256&d=identicon&r=PG",
                    "display_name": "chepner",
                    "link": "https://stackoverflow.com/users/1126841/chepner"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1488461073,
                "post_id": 42553309,
                "comment_id": 72247570,
                "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"
                },
                "reply_to_user": {
                    "account_id": 1143565,
                    "reputation": 535973,
                    "user_id": 1126841,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa05233b2357f8d11c22ef4cfc7bb85c?s=256&d=identicon&r=PG",
                    "display_name": "chepner",
                    "link": "https://stackoverflow.com/users/1126841/chepner"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1488461676,
                "post_id": 42553309,
                "comment_id": 72248038,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 4734553,
                    "reputation": 1499,
                    "user_id": 3829310,
                    "user_type": "registered",
                    "accept_rate": 72,
                    "profile_image": "https://i.sstatic.net/blWdU.jpg?s=256",
                    "display_name": "Steve Amerige",
                    "link": "https://stackoverflow.com/users/3829310/steve-amerige"
                },
                "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": 1488463128,
                "post_id": 42553309,
                "comment_id": 72249141,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1488572991,
                "last_edit_date": 1490005774,
                "creation_date": 1488464566,
                "answer_id": 42557971,
                "question_id": 42553309,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "1) jq is Turing complete, so it&#39;s all just a question of which hammer to use.  \r\n\r\n2)\r\n\r\n&gt;An improvement would have been:\r\n&gt;\r\n&gt; {\r\n&gt;  &quot;\\&quot;a.b\\&quot;[0]&quot;: &quot;value&quot;\r\n&gt; }\r\n\r\nThat is easily accomplished using a helper function along these lines:\r\n\r\n    def flattenPath(delim):\r\n      reduce .[] as $s (&quot;&quot;;\r\n        if $s|type == &quot;number&quot; \r\n        then ((if . == &quot;&quot; then &quot;.&quot; else . end) + &quot;[\\($s)]&quot;)\r\n        else . + ($s | tostring | if index(delim) then &quot;\\&quot;\\(.)\\&quot;&quot; else . end)\r\n        end );\r\n\r\n3) \r\n\r\n&gt; I do processing on the associative arrays, and in the end I want to update the JSON with those changes.\r\n \r\nThis suggests you might have posed an [xy-problem][1].  However, if you really do want to serialize and unserialize some JSON text, then the natural way to do so using jq is using `leaf_paths`, as illustrated by the following serialization/deserialization functions:\r\n\r\n    # Emit (path, value) pairs\r\n    # Usage: jq -c -f serialize.jq input.json &gt; serialized.json\r\n    def serialize: leaf_paths as $p | ($p, getpath($p));\r\n\r\n\r\n    # Usage: jq -n -f unserialize.jq serialized.json\r\n    def unserialize:\r\n      def pairwise(s):\r\n        foreach s as $i ([]; \r\n          if length == 1 then . + [$i] else [$i] end;\r\n          select(length == 2));\r\n      reduce pairwise(inputs) as $p (null; setpath($p[0]; $p[1]));\r\n\r\n\r\nIf using bash, you could use `readarray` (`mapfile`) to read the paths and values into a single array, or if you want to distinguish between the paths and values more easily, you could (for example) use the approach illustrated by the following:\r\n\r\n    i=0\r\n    while read -r line ; do\r\n      path[$i]=&quot;$line&quot;; read -r line; value[$i]=&quot;$line&quot;\r\n      i=$((i + 1))\r\n    done &lt; serialized.json\r\n\r\nBut there are many other alternatives.\r\n\r\n  [1]: https://meta.stackexchange.com/questions/66377/what-is-the-xy-problem",
                "title": "How to Flatten JSON using jq and Bash into Bash Associative Array where Key=Selector?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1488572991,
        "creation_date": 1488451774,
        "last_edit_date": 1495541376,
        "question_id": 42553309,
        "body_markdown": "As a follow-up to [Flatten Arbitrary JSON][1], I&#39;m looking to take the flattened results and make them suitable for doing queries and updates back to the original JSON file.\r\n\r\n**Motivation**: I&#39;m writing Bash (4.2+) scripts (on CentOS 7) that read JSON into a Bash associative array using the JSON selector/filter as the key. I do processing on the associative arrays, and in the end I want to update the JSON with those changes.\r\n\r\nThe preceding solution gets me close to this goal. I think there are two things that it doesn&#39;t do:\r\n\r\n 1. It doesn&#39;t quote keys that require quoting. For example, the key `com.acme` would need to be quoted because it contains a special character.\r\n 2. Array indexes are not represented in a form that can be used to query the original JSON.\r\n\r\n**Existing Solution**\r\n\r\nThe solution from the above is:\r\n\r\n    $ jq --stream -n --arg delim &#39;.&#39; &#39;reduce (inputs|select(length==2)) as $i ({};\r\n    [$i[0][]|tostring] as $path_as_strings\r\n        | ($path_as_strings|join($delim)) as $key\r\n        | $i[1] as $value\r\n        | .[$key] = $value\r\n    )&#39; input.json\r\n\r\nFor example, if `input.json` contains:\r\n\r\n    {\r\n       &quot;a.b&quot;:\r\n       [\r\n          &quot;value&quot;\r\n       ]\r\n    }\r\n\r\nthen the output is:\r\n\r\n    {\r\n      &quot;a.b.0&quot;: &quot;value&quot;\r\n    }\r\n\r\n**What is Really Wanted**\r\n\r\nAn improvement would have been:\r\n\r\n    {\r\n      &quot;\\&quot;a.b\\&quot;[0]&quot;: &quot;value&quot;\r\n    }\r\n\r\nBut what I really want is output formatted so that it could be sourced directly in a Bash program (implying the array name is passed to `jq` as an argument):\r\n\r\n    ArrayName[&#39;&quot;a.b&quot;[0]&#39;]=&#39;value&#39;  # Note &#39;value&#39; might need escapes for Bash\r\n\r\nI&#39;m looking to have the more human-readable syntax above as opposed to the more general:\r\n\r\n    ArrayName[&#39;.[&quot;a.b&quot;][0]&#39;]=&#39;value&#39;\r\n\r\nI don&#39;t know if `jq` can handle all of this. My present solution is to take the output from the preceding solution and to post-process it to the form that I want. Here&#39;s the work in process:\r\n\r\n    #!/bin/bash\r\n    Flatten()                                                                                                                                                                                                                       \r\n    {\r\n    local -r OPTIONS=$(getopt -o d:m:f: -l &quot;delimiter:,mapname:,file:&quot; -n &quot;${FUNCNAME[0]}&quot; -- &quot;$@&quot;)\r\n    eval set -- &quot;$OPTIONS&quot;\r\n\r\n    local Delimiter=&#39;.&#39; MapName=map File=\r\n    while true ; do\r\n       case &quot;$1&quot; in\r\n       -d|--delimiter)   Delimiter=&quot;$2&quot;; shift 2;;\r\n       -m|--mapname)     MapName=&quot;$2&quot;; shift 2;;\r\n       -f|--file)        File=&quot;$2&quot;; shift 2;;\r\n       --)               shift; break;;\r\n       esac\r\n    done\r\n\r\n    local -a Array=()\r\n    readarray -t Array &lt;&lt;&lt;&quot;$(\r\n       jq -c -S --stream -n --arg delim &quot;$Delimiter&quot; &#39;reduce (inputs|select(length==2)) as $i ({}; .[[$i[0][]|tostring]|join($delim)] = $i[1])&#39; &lt;&lt;&lt;&quot;$(sed &#39;s|^\\s*[#%].*||&#39; &quot;$File&quot;)&quot; |\r\n       jq -c &quot;to_entries|map(\\&quot;\\(.key)=\\(.value|tostring)\\&quot;)|.[]&quot; |\r\n       sed -e &#39;s|^&quot;||&#39; -e &#39;s|&quot;$||&#39; -e &#39;s|=|\\t|&#39;)&quot;\r\n\r\n    if [[ ! -v $MapName ]]; then\r\n       local -gA $MapName\r\n    fi\r\n\r\n    . &lt;(\r\n       IFS=$&#39;\\t&#39;\r\n       while read -r Key Value; do\r\n          printf &quot;$MapName[\\&quot;%s\\&quot;]=%q\\n&quot; &quot;$Key&quot; &quot;$Value&quot;\r\n       done &lt;&lt;&lt;&quot;$(printf &quot;%s\\n&quot; &quot;${Array[@]}&quot;)&quot;\r\n    )\r\n    }\r\n    declare -A Map\r\n    Flatten -m Map -f &quot;$1&quot;\r\n    declare -p Map\r\n\r\nWith the output:\r\n\r\n    $ ./Flatten.sh &lt;(echo &#39;{&quot;a.b&quot;:[&quot;value&quot;]}&#39;)\r\n    declare -A Map=&#39;([a.b.0]=&quot;value&quot; )&#39;\r\n\r\n  [1]: https://stackoverflow.com/questions/42299905/using-jq-flatten-arbitrary-json-to-delimiter-separated-flat-dictionary",
        "link": "https://stackoverflow.com/questions/42553309/how-to-flatten-json-using-jq-and-bash-into-bash-associative-array-where-key-sele",
        "title": "How to Flatten JSON using jq and Bash into Bash Associative Array where Key=Selector?"
    },
    {
        "tags": [
            "json",
            "object",
            "filtering",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1488777788,
                "last_edit_date": 1488777788,
                "creation_date": 1488597491,
                "answer_id": 42591671,
                "question_id": 42584824,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The output that you have indicated you want is not JSON, and it&#39;s unclear to me what the desired output is, but the following seems to come close:\r\n\r\n    reduce inputs as $d (null; setpath( $d[0: ($d|length) - 1]; $d[-1] ) )\r\n\r\n\r\nWith your input, and using jq -n, this produces:\r\n\r\n    {\r\n      &quot;key1&quot;: {\r\n        &quot;key2&quot;: &quot;mykey&quot;\r\n      },\r\n      &quot;key3&quot;: {\r\n        &quot;key4&quot;: &quot;mykey&quot;\r\n      }\r\n    }\r\n\r\nHopefully, you&#39;ll be able to take it from here.\r\n\r\n### Example:\r\n\r\n    def data: \r\n      { &quot;key1&quot;: { &quot;key2&quot;: {&quot;mykey&quot;: {&quot;a&quot;: 123} } },\r\n        &quot;key3&quot;: { &quot;key4&quot;: {&quot;mykey&quot;: {&quot;b&quot;: 234} } },\r\n        &quot;key4&quot;: { &quot;key1&quot;: {&quot;key2&quot; : {&quot;a&quot;: 123} } }\r\n      };\r\n    \r\n    def selection(mykey):\r\n      . as $in\r\n      | reduce (paths(objects) | select(.[-1] == mykey)) as $path\r\n          (null; setpath($path; $in|getpath($path)) );\r\n    \r\n    data | selection(&quot;mykey&quot;)\r\n    \r\nInvocation: jq -n -c -f example.jq\r\n\r\nOutput:\r\n    \r\n    {&quot;key1&quot;:{&quot;key2&quot;:{&quot;mykey&quot;:{&quot;a&quot;:123}}},\r\n     &quot;key3&quot;:{&quot;key4&quot;:{&quot;mykey&quot;:{&quot;b&quot;:234}}}}\r\n\r\n",
                "title": "tag jq how to combine multiple paths into one object"
            },
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1488715992,
                "creation_date": 1488715992,
                "answer_id": 42608224,
                "question_id": 42584824,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "With guidance from peak&#39;s responses I can now better pose and answer my question.\r\n\r\nI have expanded the data object that peak used in his example so it better represents the problem I was trying to solve.  Now the data better illustrates that &quot;key2&quot; and &quot;key10&quot; have &quot;mykey&quot; while &quot;key6&quot;, &quot;key8&quot;, and &quot;key11&quot; do not.  What I was trying to express in my question is that I wanted to retain the full paths of &quot;key2&quot; and &quot;key10&quot; which would include &quot;another&quot; as well as &quot;mykey&quot;.  I realized that a small modification to peak&#39;s example selection criterion would do that.  I only need to add a filter to the selection to retain the 1st two elements of each path that includes &quot;mykey&quot;:\r\n\r\n    def data: \r\n      { &quot;key1&quot;: { &quot;key2&quot;: {&quot;mykey&quot;: {&quot;a&quot;: 123},\r\n                           &quot;another&quot;:{&quot;q&quot;: &quot;six&quot;} },\r\n                  &quot;key6&quot;: {&quot;key7&quot;: {&quot;d&quot;: 997} } },\r\n        &quot;key3&quot;: { &quot;key8&quot;: {&quot;key9&quot;: {&quot;b&quot;: 234} },\r\n                  &quot;key10&quot;: {&quot;mykey&quot;: {&quot;d&quot;: 997},\r\n                           &quot;another&quot;:{&quot;q&quot;: &quot;seven&quot;} } },\r\n        &quot;key4&quot;: { &quot;key11&quot;: {&quot;key5&quot; : {&quot;a&quot;: 123} } }\r\n      };\r\n    \r\n    def selection(mykey):\r\n    \r\n      . as $in \r\n      | reduce (paths(objects) | select(last(.[])==mykey)|.[0:2]) as $path\r\n          (null; setpath($path; $in|getpath($path)) );\r\n    \r\n    data | selection(&quot;mykey&quot;)\r\n\r\nWhich returns what I desired:\r\n\r\n    {&quot;key1&quot;:{&quot;key2&quot;:{&quot;mykey&quot;:{&quot;a&quot;:123},\r\n                     &quot;another&quot;:{&quot;q&quot;:&quot;six&quot;}}},\r\n     &quot;key3&quot;:{&quot;key6&quot;:{&quot;mykey&quot;:{&quot;d&quot;:997},\r\n                     &quot;another&quot;:{&quot;q&quot;:&quot;seven&quot;}}}\r\n    }\r\n\r\nYou will note the selection now indcludes &quot;|.[0:2]&quot;.\r\n\r\nThanks to peak for setting my on the right track.  I have voted for his answer as it helped me better phrase my question and give me the insight to solve it.\r\n \r\n\r\n\r\n",
                "title": "tag jq how to combine multiple paths into one object"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1488777788,
        "creation_date": 1488561219,
        "last_edit_date": 1488777150,
        "question_id": 42584824,
        "body_markdown": "I have an object that I can filter to several paths I wish to keep.  The paths are of the form:\r\n\r\n    [\r\n      &quot;key1&quot;,\r\n      &quot;key2&quot;,\r\n      &quot;mykey&quot;\r\n    ]\r\n    [\r\n      &quot;key3&quot;,\r\n      &quot;key4&quot;,\r\n      &quot;mykey&quot;\r\n    ]\r\n     \r\nWhat I want is:\r\n    \r\n    { &quot;key1&quot;:{\r\n          &quot;key2&quot;: .key2\r\n           },\r\n      &quot;key3&quot;:{\r\n          &quot;key4&quot;: .key4\r\n           }\r\n    }\r\n\r\nThe closest I can get is:\r\n\r\n    { &quot;key1&quot;:{\r\n       &quot;key2&quot;: .key2\r\n          }\r\n    }\r\n    {  &quot;key3&quot;:{\r\n          &quot;key4&quot;: .key4\r\n    }\r\n\r\nusing:\r\n\r\n    (paths(objects)|select(last(.[])==&quot;mykey&quot;)) as $path|\r\n    getpath([$path[0],$path[1]]) as $getpath|\r\n    {($path[0]):{($path[1]):$getpath}}\r\n\r\nThough I can pipe this output to a jq -s &#39;.&#39; command, I cannot find a way to sum the reconstructions of the paths together within the original set of filters.  It appears that the filters reset at the end of each object. $path appears to hold only one path array at a time, rather than be an array of paths.  This prevents me from iterating over $path in a reduce function.\r\n\r\nI have created the following script that works but I am interested in finding how to use the paths() function, as well.  I have not figured out how to make it very useful to me, as yet.\r\n \r\n\r\n    (to_entries |\r\n     map(select(.[&quot;value&quot;][]?|has(&quot;mykey&quot;)?))|[.[].key]) as $rooms|\r\n    (to_entries |\r\n     map(select(.[&quot;value&quot;][]?|has(&quot;mykey&quot;)?))|[.[].value]) as $roomvals| #allows room paths to be avail\r\n    \r\n    ##### creates object containing only those locations and sensors within the locations that include &quot;mykey&quot; objs\r\n    \r\n    reduce\r\n    range(0;$rooms|length) as $i ({};\r\n    .+{($rooms[$i]): ($roomvals[$i] | to_entries |\r\n    map(select(.[&quot;value&quot;]|has(&quot;mykey&quot;)))|{(.[][&quot;key&quot;]):.[][&quot;value&quot;]})})\r\n\r\nAny assistance on these approaches or the suggestion of alternative approaches is appreciated.\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/42584824/tag-jq-how-to-combine-multiple-paths-into-one-object",
        "title": "tag jq how to combine multiple paths into one object"
    },
    {
        "tags": [
            "data-manipulation",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1488576041,
                "last_edit_date": 1488576041,
                "creation_date": 1488575002,
                "answer_id": 42588390,
                "question_id": 42588027,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "If I understand your question correctly, you should be able to accomplish what you want using `reduce`, along the lines of:\r\n\r\n    reduce .[] as $o\r\n      ({\r\n         people: [],\r\n         terms: [],\r\n         jobs: [],\r\n         locations: []\r\n       }; ......\r\n     )\r\n\r\n\r\nSee the jq documentation regarding `reduce`, but in brief, you would replace ...... with the jq instructions for building up your normalized representation.  \r\n\r\nThe easiest way to check for duplicates is probably using `index/1`.  I&#39;d suggest using helper functions (`def ...`) to keep things easy-to-read and easy-to-maintain.\r\n\r\n### Numerical id\r\nIf you need to generate a numerical id, then it might be easier to use the idiom:\r\n \r\n    . as $in | reduce range(0;length) as $i (INITIAL; $in[$i] as $o | ......)",
                "title": "Normalizing data in jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1488576041,
        "creation_date": 1488573411,
        "last_edit_date": 1488574750,
        "question_id": 42588027,
        "body_markdown": "Imagine data that looks something like:\r\n\r\n    [{\r\n        &quot;names&quot;: {\r\n            &quot;official_full&quot;: &quot;John Smith&quot;,\r\n            &quot;nickname&quot;: &quot;Johnny&quot;\r\n        },\r\n        &quot;positions&quot;: [{\r\n            &quot;start&quot;: &quot;1993-01-05&quot;,\r\n            &quot;end&quot;: &quot;2002-12-03&quot;,\r\n            &quot;title&quot;: &quot;Executive VP of Operations&quot;,\r\n            &quot;city&quot;: &quot;Winnipeg&quot;,\r\n            &quot;state&quot;: &quot;Michigan&quot;\r\n        }, ...]\r\n    }, ...]\r\n\r\nIs it possible in jq to normalize the data like below?\r\n\r\n    {\r\n        people: [{\r\n            &quot;full_name&quot;: &quot;John Smith&quot;\r\n        }, ...],\r\n\r\n        terms: [{\r\n            &quot;start&quot;: &quot;1993-01-05&quot;,\r\n            &quot;end&quot;: &quot;2002-12-03&quot;,\r\n            &quot;person&quot;: 1,\r\n            &quot;job&quot;: 0\r\n        }, ...],\r\n\r\n        jobs: [{\r\n            &quot;title&quot;: &quot;Executive VP of Operations&quot;,\r\n            &quot;location&quot;: 0\r\n        }, ...],\r\n\r\n        locations: [{\r\n            &quot;city&quot;: &quot;Winnipeg&quot;,\r\n            &quot;state&quot;: &quot;Michigan&quot;\r\n        }, ...]\r\n    }\r\n\r\nI&#39;m kind of new to jq so I don&#39;t know where to really begin. My main issue is how to create an object beforehand that would then be populated as I iterate through the passed in json i.e.\r\n\r\n    {\r\n        people: [],\r\n        terms: [],\r\n        jobs: [],\r\n        locations: []\r\n    }\r\n\r\nand how do I get the index of an appended object?\r\n\r\nI&#39;m not sure if this is even easy to do with jq. I might just write a nodejs script using normalizrjs.\r\n\r\nAnother issue is making sure an object such as a `job` or `location` isn&#39;t duplicated so I&#39;d want to make sure there isn&#39;t an object with duplicate fields. This I feel like may not be so hard. I would just need to compare an object with what&#39;s in the array before inserting it",
        "link": "https://stackoverflow.com/questions/42588027/normalizing-data-in-jq",
        "title": "Normalizing data in jq"
    },
    {
        "tags": [
            "json",
            "linux",
            "bash",
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 129317,
                    "reputation": 5627,
                    "user_id": 327815,
                    "user_type": "registered",
                    "accept_rate": 75,
                    "profile_image": "https://www.gravatar.com/avatar/17f2e18da0338911cd6ea464ff2613d1?s=256&d=identicon&r=PG",
                    "display_name": "Jokester",
                    "link": "https://stackoverflow.com/users/327815/jokester"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1488680528,
                "post_id": 42603670,
                "comment_id": 72337751,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 10334532,
                    "reputation": 43,
                    "user_id": 7623179,
                    "user_type": "registered",
                    "accept_rate": 0,
                    "profile_image": "https://www.gravatar.com/avatar/ea481e5b02243436c07aeb426493b68c?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Christi123321",
                    "link": "https://stackoverflow.com/users/7623179/christi123321"
                },
                "reply_to_user": {
                    "account_id": 129317,
                    "reputation": 5627,
                    "user_id": 327815,
                    "user_type": "registered",
                    "accept_rate": 75,
                    "profile_image": "https://www.gravatar.com/avatar/17f2e18da0338911cd6ea464ff2613d1?s=256&d=identicon&r=PG",
                    "display_name": "Jokester",
                    "link": "https://stackoverflow.com/users/327815/jokester"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1488680674,
                "post_id": 42603670,
                "comment_id": 72337784,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 3959308,
                    "reputation": 53394,
                    "user_id": 3266847,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/U0oyt.png?s=256",
                    "display_name": "Benjamin W.",
                    "link": "https://stackoverflow.com/users/3266847/benjamin-w"
                },
                "edited": false,
                "score": 4,
                "creation_date": 1488684864,
                "post_id": 42603670,
                "comment_id": 72338621,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": -1,
                "last_activity_date": 1488685924,
                "creation_date": 1488685924,
                "answer_id": 42604322,
                "question_id": 42603670,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "I&#39;m 99% sure I understand things correctly so here goes: I understand you want to take the lines that say &quot;summary&quot; in the second paste and extract the values.  I don&#39;t know json and I&#39;m assuming your `jq` command formats the json data nicely, filling the line breaks and so forth.  Assuming there will only be one `summary` on a line, that the summary value never contains quoted double quotes, and the value will never cross a line break, you can accomplish what you want with the following:\r\n\r\n    egrep &#39;^ *&quot;summary&quot;:&#39; json.txt | while IFS= read line; do expr match &quot;$line&quot; &#39; *&quot;summary&quot;: &quot;\\(.*\\)&quot;.*&#39;; done\r\n    \r\nWhat this says to loop (`while`) over all lines in the file `json.txt` that contain a `summary` field at the beginning of the line (`^`) except for unlimited spaces (` *`) (`egrep &#39;^ *&quot;summary&quot;:&#39; json.txt |`), reading (`read`) them into the variable `line` without losing whitespace (`IFS=`), and then extract (`expr match`) from that line (`&quot;$line&quot;`) the contents of the second quoted string (`&#39; *&quot;summary&quot;: &quot;\\(.*\\)&quot;.*&#39;`), where `\\(` and `\\)` isolate what you want to print out (move the quotes inside these delimiters if you want them included in the output).  `.*` means a string of any (zero or more) characters.  `|` means take the output of the left command and feed it to the input of the right command. \r\n\r\nThis is very simple.  I am assuming that there are json tools to do what you want to do but I don&#39;t know what they are.  They may be more complicated than this but if you are going to do a lot of json processing it may behoove you to find them and learn them.",
                "title": "How can I filter parts after they are inside of [ and ]?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1488694279,
                "creation_date": 1488694279,
                "answer_id": 42605124,
                "question_id": 42603670,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "&gt; How can I filter parts after they are inside of [ and ]?\r\n\r\nThere are basically two ways:\r\n\r\n1. If you want to preserve the array, then pipe into: map(select(...))\r\n\r\n2. Otherwise, pipe into .[] | select(...)\r\n\r\n",
                "title": "How can I filter parts after they are inside of [ and ]?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1502860461,
                "creation_date": 1502860461,
                "answer_id": 45705546,
                "question_id": 42603670,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "jq can probably solve this.\r\n\r\nTo extract just the `.summary` values from each element of `.daily.data` with `[]`, use \r\n\r\n    .daily.data[].summary\r\n\r\nRunning this over the value from the specified pastebin returns\r\n\r\n    &quot;Leichter Regen am Vormittag und Nacht.&quot;\r\n    &quot;Leichter Regen am Vormittag.&quot;\r\n    &quot;Den ganzen Tag lang &#252;berwiegend bew&#246;lkt.&quot;\r\n    &quot;Leichter Regen von nachmittags bis abends.&quot;\r\n    &quot;Den ganzen Tag lang stark bew&#246;lkt.&quot;\r\n    &quot;Abends Nieselregen.&quot;\r\n    &quot;Den ganzen Tag lang Regen.&quot;\r\n    &quot;Leichter Regen am Vormittag und Abend.&quot;\r\n\r\nTo obtain a version with each element of `.daily.data` replaced with an object containing only the summary use the filter\r\n    \r\n     .daily.data[] |= {summary}\r\n\r\nRunning this over the value from the specified pastebin returns\r\n\r\n    {\r\n      &quot;latitude&quot;: 53,\r\n      &quot;longitude&quot;: 9,\r\n      &quot;timezone&quot;: &quot;Europe/Berlin&quot;,\r\n      &quot;offset&quot;: 1,\r\n      &quot;daily&quot;: {\r\n        &quot;summary&quot;: &quot;Die ganze Woche leichter Regen mit einem Temperaturminimum von 7&#176;C am Mittwoch.&quot;,\r\n        &quot;icon&quot;: &quot;rain&quot;,\r\n        &quot;data&quot;: [\r\n          {\r\n            &quot;summary&quot;: &quot;Leichter Regen am Vormittag und Nacht.&quot;\r\n          },\r\n          {\r\n            &quot;summary&quot;: &quot;Leichter Regen am Vormittag.&quot;\r\n          },\r\n          {\r\n            &quot;summary&quot;: &quot;Den ganzen Tag lang &#252;berwiegend bew&#246;lkt.&quot;\r\n          },\r\n          {\r\n            &quot;summary&quot;: &quot;Leichter Regen von nachmittags bis abends.&quot;\r\n          },\r\n          {\r\n            &quot;summary&quot;: &quot;Den ganzen Tag lang stark bew&#246;lkt.&quot;\r\n          },\r\n          {\r\n            &quot;summary&quot;: &quot;Abends Nieselregen.&quot;\r\n          },\r\n          {\r\n            &quot;summary&quot;: &quot;Den ganzen Tag lang Regen.&quot;\r\n          },\r\n          {\r\n            &quot;summary&quot;: &quot;Leichter Regen am Vormittag und Abend.&quot;\r\n          }\r\n        ]\r\n      }\r\n    }\r\n\r\nIf something else is desired it can probably be accomplished with tweaking.",
                "title": "How can I filter parts after they are inside of [ and ]?"
            }
        ],
        "is_answered": false,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1502860461,
        "creation_date": 1488679834,
        "question_id": 42603670,
        "body_markdown": "Im trying to filter a .json file which I got from the dark sky api.\r\nI have trouble to do the same thing with multiple apis which output .json files (spotify, reddit, lastfm and dark sky).\r\nThis is the whole .json file from : http://pastebin.com/rxqHBumk.\r\nI can filter that file with the command: jq &#39;.daily.data&#39; till that state: http://pastebin.com/Mukz14rJ but I cant filter it further than that. \r\n\r\nI would apriciate every help since Im stuck on this point.",
        "link": "https://stackoverflow.com/questions/42603670/how-can-i-filter-parts-after-they-are-inside-of-and",
        "title": "How can I filter parts after they are inside of [ and ]?"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1488834684,
                "post_id": 42633045,
                "comment_id": 72398789,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 270035,
                    "reputation": 8656,
                    "user_id": 559742,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/bdc0803d3578379d994aa10fcbf4c15f?s=256&d=identicon&r=PG",
                    "display_name": "Roger",
                    "link": "https://stackoverflow.com/users/559742/roger"
                },
                "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": 1488840378,
                "post_id": 42633045,
                "comment_id": 72401673,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 19375,
                    "reputation": 447959,
                    "user_id": 45375,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/39f6e2dc52425b1e08027c01bb880be0?s=256&d=identicon&r=PG",
                    "display_name": "mklement0",
                    "link": "https://stackoverflow.com/users/45375/mklement0"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1488842193,
                "post_id": 42633045,
                "comment_id": 72402411,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1488828200,
                "creation_date": 1488828200,
                "answer_id": 42633905,
                "question_id": 42633045,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "the Couchdb engine is append only, it means that each document will append into a file manager by Couchdb, and each file is related to a db.\r\n\r\nto use properly think how to avoid updates in the same document, remember all revisions will be storage.\r\n\r\nmy suggestion for each document.\r\n\r\n&lt;!-- language: lang-js --&gt;\r\n\r\n    {\r\n      &quot;name&quot;: &quot;John Black&quot;,\r\n      &quot;entries&quot;: [\r\n        {\r\n          &quot;test&quot;: &quot;Lorem ipsum dolor sit amet.&quot;,\r\n          &quot;value&quot;: 27\r\n        }, \r\n        {\r\n           &quot;text&quot;: &quot;Ut tempus lectus ut mi.&quot;,\r\n           &quot;value&quot;: 23\r\n        }\r\n      ],\r\n      &quot;type&quot;: &quot;user&quot;\r\n    }\r\n\r\n&lt;!-- end snippet --&gt;\r\n",
                "title": "JQ - format JSON array appending values to a specific a value"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1488835483,
                "last_edit_date": 1488835483,
                "creation_date": 1488835040,
                "answer_id": 42635726,
                "question_id": 42633045,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "This is an appropriate use case for a reducer. Most of the below is related not to joining items under shared keys, but to getting them into the desired nested-list form:\r\n\r\n    jq -n &#39;[\r\n      inputs |\r\n      reduce .[] as $item ({}; .[$item[0]] += [$item[1]]) |\r\n      to_entries |\r\n      .[] |\r\n      [.key, .value]\r\n    ]&#39; &lt;&lt;&lt;&quot;$A&quot;\r\n\r\n...yields as output (edited only for compactness with regard to whitespace):\r\n\r\n    [\r\n      [&quot;John Black&quot;, [[&quot;Lorem ipsum dolor sit amet.&quot;, 27], [&quot;Ut tempus lectus ut mi.&quot;,23]]],\r\n      [&quot;Peter Pan&quot;, [[&quot;Quisque pulvinar odio.&quot;,22], [&quot;Nec ut lorem quis interdum elit.&quot;, 32]]],\r\n      [&quot;Gary Halbert&quot;, [[&quot;Placerat aliquam.&quot;, 17]]],\r\n      [&quot;Richard Gere&quot;, [[&quot;Porttitor commodo fermentum.&quot;, 28]]]\r\n    ]",
                "title": "JQ - format JSON array appending values to a specific a value"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1488835483,
        "creation_date": 1488825236,
        "last_edit_date": 1488834303,
        "question_id": 42633045,
        "body_markdown": "I am trying to get this:\r\n\r\n\t[\t\r\n\t\t[&quot;John Black&quot;,[ \r\n\t\t\t[&quot;Lorem ipsum dolor sit amet.&quot;,27], \r\n\t\t\t[&quot;Ut tempus lectus ut mi.&quot;,23]\r\n\t\t]],\r\n\t\t[&quot;Peter Pan&quot;,[ \r\n\t\t\t[&quot;Quisque pulvinar odio.&quot;,22],\r\n\t\t\t[&quot;Nec ut lorem quis interdum elit.&quot;,32]\r\n\t\t]],\r\n\t\t[&quot;Gary Halbert&quot;,[ \r\n\t\t\t[&quot;Placerat aliquam.&quot;,17]\r\n\t\t]],\r\n\t\t[&quot;Richard Gere&quot;,[ \r\n\t\t\t[&quot;Porttitor commodo fermentum.&quot;,28]\r\n\t\t]]\r\n\t]\r\n\r\nTill now, this is what I got:\r\n\r\n\texport A=$(cat &lt;&lt;&#39;EOL&#39;\r\n\t[\r\n\t[&quot;John Black&quot;,[&quot;Lorem ipsum dolor sit amet.&quot;,27]],\r\n\t[&quot;Peter Pan&quot;,[&quot;Quisque pulvinar odio.&quot;,22]],\r\n\t[&quot;John Black&quot;,[&quot;Ut tempus lectus ut mi.&quot;,23]],\r\n\t[&quot;Gary Halbert&quot;,[&quot;Placerat aliquam.&quot;,17]],\r\n\t[&quot;Peter Pan&quot;,[&quot;Nec ut lorem quis interdum elit.&quot;,32]],\r\n\t[&quot;Richard Gere&quot;,[&quot;Porttitor commodo fermentum.&quot;,28]]\r\n\t]\r\n\tEOL\r\n\t)\r\n\techo &quot;$A&quot; | jq &#39;map({(.[0]): .[1]}) | add&#39;\r\n\r\nResulting this:\r\n\r\n\t{\r\n\t  &quot;John Black&quot;: [\r\n\t\t&quot;Ut tempus lectus ut mi.&quot;,\r\n\t\t23\r\n\t  ],\r\n\t  &quot;Peter Pan&quot;: [\r\n\t\t&quot;Nec ut lorem quis interdum elit.&quot;,\r\n\t\t32\r\n\t  ],\r\n\t  &quot;Gary Halbert&quot;: [\r\n\t\t&quot;Placerat aliquam.&quot;,\r\n\t\t17\r\n\t  ],\r\n\t  &quot;Richard Gere&quot;: [\r\n\t\t&quot;Porttitor commodo fermentum.&quot;,\r\n\t\t28\r\n\t  ]\r\n\t}\r\n\r\nI am using jq-1.5.\r\nAny ideas? Thanks.",
        "link": "https://stackoverflow.com/questions/42633045/jq-format-json-array-appending-values-to-a-specific-a-value",
        "title": "JQ - format JSON array appending values to a specific a value"
    },
    {
        "tags": [
            "json",
            "recursion",
            "key",
            "jq",
            "tree-traversal"
        ],
        "answers": [
            {
                "up_vote_count": 23,
                "is_accepted": true,
                "score": 23,
                "last_activity_date": 1488837523,
                "creation_date": 1488837523,
                "answer_id": 42636398,
                "question_id": 42635140,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "A robust way (with respect to different jq versions) to delete all keys matching a pattern (say PATTERN) would be to use the idiom:\r\n\r\n    with_entries(select( .key | test(PATTERN) | not))\r\n\r\nPlugging this into `walk/1` yields:\r\n\r\n    walk(if type == &quot;object&quot; then with_entries(select(.key | test(PATTERN) | not)) else . end)\r\n\r\n",
                "title": "Jq: recursively delete all keys that match a given pattern"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 13,
        "last_activity_date": 1488912802,
        "creation_date": 1488832875,
        "last_edit_date": 1488912802,
        "question_id": 42635140,
        "body_markdown": "How to recursively delete all keys that match a given pattern? \r\n\r\nI have following jq config, but it doesn&#39;t seem to work:\r\n\r\n    walk( if (type == &quot;object&quot; and (.[] | test(&#39;.*&#39;))) then del(.) else . end)",
        "link": "https://stackoverflow.com/questions/42635140/jq-recursively-delete-all-keys-that-match-a-given-pattern",
        "title": "Jq: recursively delete all keys that match a given pattern"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1488838044,
                "creation_date": 1488838044,
                "answer_id": 42636517,
                "question_id": 42635730,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "In brief, use `empty` instead of `del(.)`.  After simplifying:\r\n\r\n   walk(if type == &quot;object&quot; and has(&quot;index&quot;) and (.index | test(&quot;monitoring&quot;)) \r\n        then empty else . end )\r\n",
                "title": "Jq: why does del() leave null in place?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1488838044,
        "creation_date": 1488835046,
        "question_id": 42635730,
        "body_markdown": "I have to recursively remove objects that contain a given key value. \r\n\r\nThe Json is:\r\n\r\n    {\r\n        &quot;health&quot;: &quot;yellow&quot;,\r\n        &quot;status&quot;: &quot;open&quot;,\r\n        &quot;index&quot;: &quot;.monitoring-es-2-2017.03.03&quot;,\r\n        &quot;uuid&quot;: &quot;Py3FY-UwSjmda3jbYeIdMg&quot;,\r\n        &quot;pri&quot;: &quot;1&quot;,\r\n        &quot;rep&quot;: &quot;1&quot;,\r\n        &quot;docs.count&quot;: &quot;23494&quot;,\r\n        &quot;docs.deleted&quot;: &quot;78&quot;,\r\n        &quot;store.size&quot;: &quot;12mb&quot;,\r\n        &quot;pri.store.size&quot;: &quot;12mb&quot;\r\n      },\r\n      {\r\n        &quot;health&quot;: &quot;yellow&quot;,\r\n        &quot;status&quot;: &quot;open&quot;,\r\n        &quot;index&quot;: &quot;robot-log-01.02.2017&quot;,\r\n        &quot;uuid&quot;: &quot;lFndm8gDS2OAGXZhP5KSkw&quot;,\r\n        &quot;pri&quot;: &quot;5&quot;,\r\n        &quot;rep&quot;: &quot;1&quot;,\r\n        &quot;docs.count&quot;: &quot;127887&quot;,\r\n        &quot;docs.deleted&quot;: &quot;0&quot;,\r\n        &quot;store.size&quot;: &quot;35.1mb&quot;,\r\n        &quot;pri.store.size&quot;: &quot;35.1mb&quot;\r\n      }\r\n\r\nConfig is:\r\n\r\n    walk( if ((type == &quot;object&quot; and has(&quot;index&quot;)) and (.&quot;index&quot; | test(&quot;monitoring*&quot;))) then del(.) else . end )\r\n\r\nOutput is:\r\n\r\n    null,\r\n          {\r\n            &quot;health&quot;: &quot;yellow&quot;,\r\n            &quot;status&quot;: &quot;open&quot;,\r\n            &quot;index&quot;: &quot;robot-log-01.02.2017&quot;,\r\n            &quot;uuid&quot;: &quot;lFndm8gDS2OAGXZhP5KSkw&quot;,\r\n            &quot;pri&quot;: &quot;5&quot;,\r\n            &quot;rep&quot;: &quot;1&quot;,\r\n            &quot;docs.count&quot;: &quot;127887&quot;,\r\n            &quot;docs.deleted&quot;: &quot;0&quot;,\r\n            &quot;store.size&quot;: &quot;35.1mb&quot;,\r\n            &quot;pri.store.size&quot;: &quot;35.1mb&quot;\r\n          }\r\n\r\nWhy does del() leave null in place? How to avoid it?",
        "link": "https://stackoverflow.com/questions/42635730/jq-why-does-del-leave-null-in-place",
        "title": "Jq: why does del() leave null in place?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1488896589,
                "last_edit_date": 1488896589,
                "creation_date": 1488879358,
                "answer_id": 42644665,
                "question_id": 42643920,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You can try this `jq`:\r\n\r\n    jq -r &#39;.Data1|.[]|.Data2|[.SUBSCRIBER_ID, .OFFERS[].Offer]|@csv&#39; file &gt; out.csv\r\n\r\n(OR) As suggested by @peak,\r\n\r\n    jq -r &#39;.Data1[].Data2|[.SUBSCRIBER_ID, .OFFERS[].Offer]|@csv&#39; file\r\n\r\nAnother one method:\r\n\r\n    jq -r &#39;.[]|.[]|map([.SUBSCRIBER_ID, .OFFERS[].Offer])|.[]|@csv&#39; file\r\n\r\n**Input:**\r\n\r\n    $ cat file.json\r\n    {\r\n      &quot;Data1&quot;: [\r\n        {\r\n          &quot;Data2&quot;: {\r\n            &quot;SUBSCRIBER_ID&quot;: &quot;999050280010099&quot;,\r\n            &quot;MSISDN&quot;: &quot;999050280010099&quot;,\r\n            &quot;EMAIL&quot;: &quot;john@email.com&quot;,\r\n            &quot;OFFERS&quot;: [\r\n              {\r\n                &quot;Offer&quot;: 12344,\r\n                &quot;EffectiveDate&quot;: &quot;1488787236&quot;,\r\n                &quot;ExpiryDate&quot;: &quot;4070869200&quot;\r\n              }\r\n            ],\r\n            &quot;IsGroup&quot;: &quot;false&quot;\r\n          }\r\n        }\r\n      ]\r\n    }\r\n\r\n**Test:**\r\n\r\n    $ jq -r &#39;.Data1|.[]|.Data2|[.SUBSCRIBER_ID, .OFFERS[].Offer]|@csv&#39; file.json\r\n    &quot;999050280010099&quot;,12344\r\n\r\n    $ jq -r &#39;.[]|.[]|map([.SUBSCRIBER_ID, .OFFERS[].Offer])|.[]|@csv&#39; file.json\r\n    &quot;999050280010099&quot;,12344\r\n\r\n",
                "title": "How to capture values from JSON parent and sub-parent parameter using JQ?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1488896589,
        "creation_date": 1488876954,
        "last_edit_date": 1488880954,
        "question_id": 42643920,
        "body_markdown": "I have this below JSON file which I need to capture using JQ, but so far I only manage to capture the parent parameter (SUBSCRIBER_ID), but unable to capture the sub-parent parameter which is &quot;Offer&quot;.\r\n\r\nNeed your guys help on providing a correct JQ filter to capture both &quot;SUBSCRIBER_ID&quot; and &quot;Offer&quot; value.\r\n\r\n#JSON#\r\n\r\n    {&quot;Data1&quot;: [\r\n       {&quot;Data2&quot;: {\r\n              &quot;SUBSCRIBER_ID&quot; : &quot;999050280010099&quot;,\r\n              &quot;MSISDN&quot; : &quot;999050280010099&quot;,\r\n              &quot;EMAIL&quot; : &quot;john@email.com&quot;,\r\n              &quot;OFFERS&quot; : [\r\n                      {\r\n                           &quot;Offer&quot; : 12344,\r\n                           &quot;EffectiveDate&quot; : &quot;1488787236&quot;,\r\n                           &quot;ExpiryDate&quot; : &quot;4070869200&quot;\r\n                      }               ],\r\n              &quot;IsGroup&quot; : &quot;false&quot;,\r\n         }}\r\n    ]}\r\n\r\n------------------------------------------------------------------------\r\n#My JQ Filter which is not working#\r\n\r\n    &#39;.Data1 | .[] | .Data2 | to_entries |  map(.value) | @csv&#39; -r\r\n\r\n#Expected output:#\r\n\r\n    SUBSCRIBER_ID,Offer\r\n    999050280010099,12344",
        "link": "https://stackoverflow.com/questions/42643920/how-to-capture-values-from-json-parent-and-sub-parent-parameter-using-jq",
        "title": "How to capture values from JSON parent and sub-parent parameter using JQ?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 92406,
                    "reputation": 4136,
                    "user_id": 253266,
                    "user_type": "registered",
                    "accept_rate": 63,
                    "profile_image": "https://www.gravatar.com/avatar/60f8be1907b4d9c4d1c4a6a4b0556bc7?s=256&d=identicon&r=PG",
                    "display_name": "hyankov",
                    "link": "https://stackoverflow.com/users/253266/hyankov"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1488982032,
                "post_id": 42673485,
                "comment_id": 72471534,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 2019981,
                    "reputation": 2314,
                    "user_id": 1806392,
                    "user_type": "registered",
                    "accept_rate": 59,
                    "profile_image": "https://i.sstatic.net/m96tp.jpg?s=256",
                    "display_name": "nik",
                    "link": "https://stackoverflow.com/users/1806392/nik"
                },
                "reply_to_user": {
                    "account_id": 92406,
                    "reputation": 4136,
                    "user_id": 253266,
                    "user_type": "registered",
                    "accept_rate": 63,
                    "profile_image": "https://www.gravatar.com/avatar/60f8be1907b4d9c4d1c4a6a4b0556bc7?s=256&d=identicon&r=PG",
                    "display_name": "hyankov",
                    "link": "https://stackoverflow.com/users/253266/hyankov"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1488982237,
                "post_id": 42673485,
                "comment_id": 72471668,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 92406,
                    "reputation": 4136,
                    "user_id": 253266,
                    "user_type": "registered",
                    "accept_rate": 63,
                    "profile_image": "https://www.gravatar.com/avatar/60f8be1907b4d9c4d1c4a6a4b0556bc7?s=256&d=identicon&r=PG",
                    "display_name": "hyankov",
                    "link": "https://stackoverflow.com/users/253266/hyankov"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1488982266,
                "post_id": 42673485,
                "comment_id": 72471687,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 2019981,
                    "reputation": 2314,
                    "user_id": 1806392,
                    "user_type": "registered",
                    "accept_rate": 59,
                    "profile_image": "https://i.sstatic.net/m96tp.jpg?s=256",
                    "display_name": "nik",
                    "link": "https://stackoverflow.com/users/1806392/nik"
                },
                "reply_to_user": {
                    "account_id": 92406,
                    "reputation": 4136,
                    "user_id": 253266,
                    "user_type": "registered",
                    "accept_rate": 63,
                    "profile_image": "https://www.gravatar.com/avatar/60f8be1907b4d9c4d1c4a6a4b0556bc7?s=256&d=identicon&r=PG",
                    "display_name": "hyankov",
                    "link": "https://stackoverflow.com/users/253266/hyankov"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1488982333,
                "post_id": 42673485,
                "comment_id": 72471726,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1488982932,
                "last_edit_date": 1488982932,
                "creation_date": 1488982584,
                "answer_id": 42673706,
                "question_id": 42673485,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You can use `jq` like this:\r\n\r\n    jq -r &#39;to_entries[0].value&#39; file.json\r\n\r\n---\r\n\r\nExplanation:\r\n\r\nThe `to_entries` function will transform the json like this:\r\n\r\n    jq &#39;to_entries[0]&#39; &lt;&lt;&lt; &#39;{&quot;b&quot;:{&quot;y&quot;:1, &quot;z&quot;:2}}&#39;\r\n    {\r\n      &quot;key&quot;: &quot;b&quot;,\r\n      &quot;value&quot;: {\r\n        &quot;y&quot;: 1,\r\n        &quot;z&quot;: 2\r\n      }\r\n    }\r\n\r\nAdding `.value` gives you the value only.\r\n",
                "title": "Skip wrapping element"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1488988261,
                "creation_date": 1488988261,
                "answer_id": 42675888,
                "question_id": 42673485,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Even easier:\r\n\r\n    jq &#39;.[]&#39;\r\n\r\nOutput (with the -c option):\r\n\r\n    {&quot;x&quot;:0}\r\n    {&quot;y&quot;:1,&quot;z&quot;:2}\r\n",
                "title": "Skip wrapping element"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1488988261,
        "creation_date": 1488981981,
        "last_edit_date": 1488982284,
        "question_id": 42673485,
        "body_markdown": "I have a couple of files, each having a differently named wrapper element. For example: `{&quot;a&quot;:{&quot;x&quot;:0}}` and  `{&quot;b&quot;:{&quot;y&quot;:1, &quot;z&quot;:2}}`.\r\n\r\nWho can I select the content of the most outer wrapping element without selecting it by name?",
        "link": "https://stackoverflow.com/questions/42673485/skip-wrapping-element",
        "title": "Skip wrapping element"
    },
    {
        "tags": [
            "json",
            "bash",
            "shell",
            "grep",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1488987946,
                "creation_date": 1488987946,
                "answer_id": 42675773,
                "question_id": 42675550,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You can use the following :\r\n\r\n    jq &quot;.$1 | { keys: keys_unsorted, values: [.[]] }&quot;\r\n\r\nwhere `$1` should provide the name of the item you want to address (note that this assume you&#39;re using this in a script. You will probably want to use fedorqui&#39;s alternative instead).\r\n\r\nIt will produce an object whose `keys` property will be an array of the keys of `$1` and `values` an array of the associated values :\r\n\r\n\t$ echo &#39;{\r\n\t &quot;images1&quot; :\r\n\t\t{\r\n\t\t  &quot;size&quot; : &quot;29x29&quot;,\r\n\t\t  &quot;idiom&quot; : &quot;iphone&quot;,\r\n\t\t  &quot;filename&quot; : &quot;Icon-Small@2x.png&quot;,\r\n\t\t  &quot;scale&quot; : &quot;2x&quot;\r\n\t\t},\r\n\t &quot;images2&quot; :\r\n\t\t{\r\n\t\t  &quot;size&quot; : &quot;29x30&quot;,\r\n\t\t  &quot;idiom&quot; : &quot;iphone2&quot;,\r\n\t\t  &quot;filename&quot; : &quot;Icon-Small@2x.png2&quot;,\r\n\t\t  &quot;scale&quot; : &quot;22x&quot;\r\n\t\t}\r\n\t}&#39; | jq &quot;.images1 | { keys: keys_unsorted, values: [.[]] }&quot;\r\n\t{\r\n\t  &quot;keys&quot;: [\r\n\t\t&quot;size&quot;,\r\n\t\t&quot;idiom&quot;,\r\n\t\t&quot;filename&quot;,\r\n\t\t&quot;scale&quot;\r\n\t  ],\r\n\t  &quot;values&quot;: [\r\n\t\t&quot;29x29&quot;,\r\n\t\t&quot;iphone&quot;,\r\n\t\t&quot;Icon-Small@2x.png&quot;,\r\n\t\t&quot;2x&quot;\r\n\t  ]\r\n\t}\r\n",
                "title": "How to separate all the keys and values and store in an array using shell script with jq parser"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1488993097,
        "creation_date": 1488987351,
        "last_edit_date": 1488993097,
        "question_id": 42675550,
        "body_markdown": "I have a JSON file like this:\r\n\r\n    {\r\n     &quot;images1&quot; : \r\n        {\r\n          &quot;size&quot; : &quot;29x29&quot;,\r\n          &quot;idiom&quot; : &quot;iphone&quot;,\r\n          &quot;filename&quot; : &quot;Icon-Small@2x.png&quot;,\r\n          &quot;scale&quot; : &quot;2x&quot;\r\n        },\r\n     &quot;images2&quot; : \r\n        {\r\n          &quot;size&quot; : &quot;29x30&quot;,\r\n          &quot;idiom&quot; : &quot;iphone2&quot;,\r\n          &quot;filename&quot; : &quot;Icon-Small@2x.png2&quot;,\r\n          &quot;scale&quot; : &quot;22x&quot;\r\n        }\r\n    }\r\n\r\nI will pass JSON object name as an input. So if I know &quot;images1&quot; is the object, then I need all the keys and values of that object to be stored in two separate arrays, so that I can make use of them in further processing.\r\n\r\nAny help is greatly appreciated.\r\nThanks",
        "link": "https://stackoverflow.com/questions/42675550/how-to-separate-all-the-keys-and-values-and-store-in-an-array-using-shell-script",
        "title": "How to separate all the keys and values and store in an array using shell script with jq parser"
    },
    {
        "tags": [
            "json",
            "jq",
            "unique-id"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1886182,
                    "reputation": 5204,
                    "user_id": 1705337,
                    "user_type": "registered",
                    "accept_rate": 65,
                    "profile_image": "https://i.sstatic.net/vzyhp.png?s=256",
                    "display_name": "Morgoth",
                    "link": "https://stackoverflow.com/users/1705337/morgoth"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1489067627,
                "post_id": 42697048,
                "comment_id": 72516148,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 5248540,
                    "reputation": 2234,
                    "user_id": 4193473,
                    "user_type": "registered",
                    "accept_rate": 81,
                    "profile_image": "https://www.gravatar.com/avatar/369d81383d53787f8bc51e7b2112eb34?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "hgl",
                    "link": "https://stackoverflow.com/users/4193473/hgl"
                },
                "reply_to_user": {
                    "account_id": 1886182,
                    "reputation": 5204,
                    "user_id": 1705337,
                    "user_type": "registered",
                    "accept_rate": 65,
                    "profile_image": "https://i.sstatic.net/vzyhp.png?s=256",
                    "display_name": "Morgoth",
                    "link": "https://stackoverflow.com/users/1705337/morgoth"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1489068718,
                "post_id": 42697048,
                "comment_id": 72516952,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 1886182,
                    "reputation": 5204,
                    "user_id": 1705337,
                    "user_type": "registered",
                    "accept_rate": 65,
                    "profile_image": "https://i.sstatic.net/vzyhp.png?s=256",
                    "display_name": "Morgoth",
                    "link": "https://stackoverflow.com/users/1705337/morgoth"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1489088110,
                "post_id": 42697048,
                "comment_id": 72530021,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1489081952,
                "last_edit_date": 1489081952,
                "creation_date": 1489076301,
                "answer_id": 42700324,
                "question_id": 42697048,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The key to a simple solution here is to break the problem down into easy pieces. This can be accomplished by defining a helper function, `addId/1`.  Once that is done, the rest is straightforward:\r\n\r\n    # starting at start, add {id: ID} to each object in the input array \r\n    def addId(start):\r\n      reduce .[] as $o\r\n        ([];\r\n         length as $l \r\n         | .[length] = ($o | (.id = start + $l)));\r\n    \r\n    reduce .[] as $o\r\n      ( {start: -1, answer: []};\r\n        (.start + 1) as $next\r\n        | .answer += [$o | (.objects |= addId($next))]\r\n        | .start += ($o.objects | length) )\r\n    | .answer\r\n\r\n",
                "title": "How to generate continuing indices for multiple objects in nested arrays that are in an array"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1489129906,
                "creation_date": 1489129906,
                "answer_id": 42712384,
                "question_id": 42697048,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Inspired by @peak answer, I came up with this solution. Not much difference, just shorter way to generate IDs and opt for `foreach` instead of `reduce` since there is intermediate result involved.\r\n\r\n    def addIdsStartWith($start):\r\n        [to_entries | map((.value.id = .key + $start) | .value)];\r\n\r\n    [foreach .[] as $set (\r\n        {start: 0};\r\n        .set = $set |\r\n            .start as $start | .set.objects |= addIdsStartWith($start) |\r\n            .start += ($set.objects | length);\r\n        .set\r\n    )]",
                "title": "How to generate continuing indices for multiple objects in nested arrays that are in an array"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1489129906,
        "creation_date": 1489067180,
        "last_edit_date": 1489076522,
        "question_id": 42697048,
        "body_markdown": "Given\r\n\r\n    [{\r\n      &quot;objects&quot;: [{\r\n        &quot;key&quot;: &quot;value&quot;\r\n      },{\r\n        &quot;key&quot;: &quot;value&quot;\r\n      }]\r\n    }, {\r\n      &quot;objects&quot;: [{\r\n        &quot;key&quot;: &quot;value&quot;\r\n      }, {\r\n        &quot;key&quot;: &quot;value&quot;\r\n      }]\r\n    }]\r\n\r\nHow do I generate\r\n\r\n    [{\r\n      &quot;objects&quot;: [{\r\n        &quot;id&quot;: 0,\r\n        &quot;key&quot;: &quot;value&quot;\r\n      },{\r\n        &quot;id&quot;: 1,\r\n        &quot;key&quot;: &quot;value&quot;\r\n      }]\r\n    }, {\r\n      &quot;objects&quot;: [{\r\n        &quot;id&quot;: 2,\r\n        &quot;key&quot;: &quot;value&quot;\r\n      }, {\r\n        &quot;id&quot;: 3,\r\n        &quot;key&quot;: &quot;value&quot;\r\n      }]\r\n    }]\r\n\r\n\r\nUsing jq?\r\n\r\nI tried to use this one, but `id`s are all `0`:\r\n\r\n    jq &#39;[(-1) as $i | .[] | {objects: [.objects[] | {id: ($i + 1 as $i | $i), key}]}]&#39;",
        "link": "https://stackoverflow.com/questions/42697048/how-to-generate-continuing-indices-for-multiple-objects-in-nested-arrays-that-ar",
        "title": "How to generate continuing indices for multiple objects in nested arrays that are in an array"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1489089767,
                "creation_date": 1489089767,
                "answer_id": 42704430,
                "question_id": 42701268,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The key to a simple jq solution here is to read the raw text file using &#39;jq -R -s&#39;, and to read the JSON using one of the options in the --arg family.  Here, I&#39;ll use `--argfile` for simplicity and robustness across jq versions, but please note that the documentation says it is deprecated.\r\n\r\nWith the following jq program in a file, say program.jq:\r\n\r\n    . as $file\r\n    | $json\r\n    | (.content = $file + &quot;\\n&quot; + .content)\r\n\r\nand the following text in the file `contents.txt`:\r\n\r\n    Line 1 of contents.txt;\r\n    line 2.\r\n\r\nand the following JSON in curl.json: \r\n\r\n    {\r\n      &quot;content&quot;: &quot;My JSON content&quot;,\r\n      &quot;owner&quot;: &quot;etc&quot;\r\n    }\r\n\r\nthe invocation:\r\n\r\n    jq -R -s --argfile json curl.json -f program.jq contents.txt\r\n\r\nproduces:\r\n\r\n    {\r\n      &quot;content&quot;: &quot;Line 1 of contents.txt;\\nline 2.\\n\\nMy JSON content&quot;,\r\n      &quot;owner&quot;: &quot;etc&quot;\r\n    }\r\n\r\nIf using bash, instead of putting the curl output into a file, you could use: --argfile json &lt;(curl ....)",
                "title": "jq add file contents into json and update"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1489089767,
        "creation_date": 1489078929,
        "question_id": 42701268,
        "body_markdown": "I&#39;m trying to use take a JSON object from a REST API `GET` call, then add the contents of a raw file (.md file in this case) into it using [jq][1], before updating the same object using a `PUT` call.\r\n\r\nI&#39;m using the following to GET the file and write it locally:\r\n\r\n`curl -u USERNAME:PASSWORD &#39;https://example.com/myfile.json&#39; | cat &gt; ./test.json`\r\n\r\nThe format of the JSON file is as follows:\r\n\r\n    {\r\n      &quot;content&quot; : &quot;My JSON content&quot;,\r\n      &quot;owner&quot;:...\r\n    }\r\n\r\nI&#39;d like to add the content of the raw file into `content`, so the result is as follows:\r\n\r\n    {\r\n      &quot;content&quot; : &quot;My markdown file contents.\\n\\nMy JSON content&quot;,\r\n      &quot;owner&quot;:...\r\n    }\r\n\r\nand then update the original JSON using a `PUT` call:\r\n\r\n`curl -u USERNAME:PASSWORD -d @./test.json -H &quot;Content-Type: application/json&quot; -X PUT &#39;https://example.com/myfile.json&#39;`\r\n\r\nI&#39;m wondering **how I can add the file content into my `JSON` file like that using jq**, if it is possible?\r\n\r\n  [1]: https://stedolan.github.io/jq/",
        "link": "https://stackoverflow.com/questions/42701268/jq-add-file-contents-into-json-and-update",
        "title": "jq add file contents into json and update"
    },
    {
        "tags": [
            "json",
            "google-bigquery",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1489087979,
                "last_edit_date": 1495540442,
                "creation_date": 1489087979,
                "answer_id": 42703931,
                "question_id": 42701295,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "So, you essentially want to transpose (pivot) your data in BigQuery Table such that instead of having data in rows as below   \r\n\r\n[![enter image description here][1]][1] \r\n\r\nyou will have your data in columns as below   \r\n\r\n[![enter image description here][2]][2] \r\n\r\nThus, my recommendation would be    \r\nFirst, load your data as is to start with  \r\nSo now, instead of doing schema transformation outside of BigQuery, let’s rather do it within BigQuery!   \r\n\r\nBelow would be an example of how to achieve transformation you are looking for (assuming you have max three items/objects in array)     \r\n\r\n&lt;!-- language-all: lang-sql --&gt;\r\n\r\n    #standardSQL\r\n    SELECT \r\n      port, notes, \r\n      STRUCT(\r\n        seeds[SAFE_OFFSET(0)] AS g__0, \r\n        seeds[SAFE_OFFSET(1)] AS g__1, \r\n        seeds[SAFE_OFFSET(2)] AS g__2\r\n      ) AS seeds \r\n    FROM yourTable   \r\n\r\nYou can test this with dummy data using CTE like below   \r\n\r\n    #standardSQL\r\n    WITH yourTable AS (\r\n      SELECT \r\n        4500 AS port, &#39;This is an example&#39; AS notes,\r\n        [STRUCT&lt;seed INT64, guid STRING&gt;\r\n            (12, &#39;eaf612&#39;), (23, &#39;bea143&#39;), (38, &#39;efk311&#39;)\r\n        ] AS seeds\r\n      UNION ALL SELECT \r\n        4501 AS port, &#39;This is an example 2&#39; AS notes,\r\n        [STRUCT&lt;seed INT64, guid STRING&gt;\r\n            (42, &#39;eaf412&#39;), (53, &#39;bea153&#39;)\r\n        ] AS seeds\r\n    )\r\n    SELECT \r\n      port, notes, \r\n      STRUCT(\r\n        seeds[SAFE_OFFSET(0)] AS g__0, \r\n        seeds[SAFE_OFFSET(1)] AS g__1, \r\n        seeds[SAFE_OFFSET(2)] AS g__2\r\n      ) AS seeds \r\n    FROM yourTable   \r\n\r\n\r\nSo, technically, if you know max number of items/object in seeds array – you can just manually write needed SQL statement, to run it against real data.    \r\nHope you got an idea \r\n\r\nOf course you can script /automate process – you can find examples for similar pivoting tasks here:  \r\n\r\nhttps://stackoverflow.com/a/40766540/5221944   \r\nhttps://stackoverflow.com/a/42287566/5221944\r\n\r\n\r\n  [1]: https://i.sstatic.net/SpwtP.png\r\n  [2]: https://i.sstatic.net/a27JY.png",
                "title": "jq: Turn an array of objects into individual objects and use each array index as a new key"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1489088321,
                "creation_date": 1489088321,
                "answer_id": 42704010,
                "question_id": 42701295,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The following jq program should do the trick.  At least it produces the desired results for the given JSON.  The program is so short and straightforward that I&#39;ll let it speak for itself:\r\n\r\n    def array2object(prefix):\r\n      . as $in\r\n      | reduce range(0;length) as $i ({}; .[&quot;\\(prefix)_\\($i)&quot;] = $in[$i]);\r\n    \r\n    .seeds |= array2object(&quot;g__&quot;)",
                "title": "jq: Turn an array of objects into individual objects and use each array index as a new key"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 3,
        "last_activity_date": 1489088321,
        "creation_date": 1489079047,
        "question_id": 42701295,
        "body_markdown": "I have several large json objects (think GB scale), where the object values in some of the innermost levels are arrays of objects. I&#39;m using jq 1.4 and I&#39;m trying to break these arrays into individual objects, each of which will have a key such as g__0 or g__1, where the numbers correspond to the index in the original array, as returned by the `keys` function. The number of objects in each array may be arbitrarily large (in my example it is equal to 3). At the same time I want to keep the remaining structure. \r\n\r\nFor what it&#39;s worth the original structure comes from MongoDB, but I am unable to change it at this level. I will then use this json file to create a schema for BigQuery, where an example column will be `seeds.g__1.guid` and so on.\r\n  \r\nWhat I have:\r\n\r\n    {\r\n     &quot;port&quot;: 4500,\r\n     &quot;notes&quot;: &quot;This is an example&quot;,\r\n     &quot;seeds&quot;: [\r\n      {\r\n        &quot;seed&quot;: 12,\r\n        &quot;guid&quot;: &quot;eaf612&quot;\r\n      },\r\n      {\r\n        &quot;seed&quot;: 23,\r\n        &quot;guid&quot;: &quot;bea143&quot;\r\n      },\r\n      {\r\n        &quot;seed&quot;: 38,\r\n        &quot;guid&quot;: &quot;efk311&quot;\r\n      }\r\n      ]\r\n    }\r\n  \r\nWhat I am hoping to achieve:\r\n\r\n    {\r\n      &quot;port&quot;: 4500,\r\n      &quot;notes&quot;: &quot;This is an example&quot;,\r\n      &quot;seeds&quot;: {\r\n        &quot;g__0&quot;: {\r\n          &quot;seed&quot;: 12,\r\n          &quot;guid&quot;: &quot;eaf612&quot;\r\n        },\r\n        &quot;g__1&quot;: {\r\n          &quot;seed&quot;: 23,\r\n          &quot;guid&quot;: &quot;bea143&quot;\r\n        },\r\n        &quot;g__2&quot;: {\r\n          &quot;seed&quot;: 38,\r\n          &quot;guid&quot;: &quot;efk311&quot;\r\n        }\r\n      }\r\n    }\r\n\r\nThanks!",
        "link": "https://stackoverflow.com/questions/42701295/jq-turn-an-array-of-objects-into-individual-objects-and-use-each-array-index-as",
        "title": "jq: Turn an array of objects into individual objects and use each array index as a new key"
    },
    {
        "tags": [
            "json",
            "recursion",
            "tree",
            "jq",
            "recursive-datastructures"
        ],
        "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": 1489086302,
                "post_id": 42701983,
                "comment_id": 72528978,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1489087787,
                "creation_date": 1489087787,
                "answer_id": 42703887,
                "question_id": 42701983,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Since your data structure is recursive, a recursive helper function is what&#39;s needed here:\r\n\r\n\r\n    def flat:\r\n      [.name] + (.children[] // {} | if has(&quot;name&quot;) then flat else [] end);\r\n  \r\n  \r\n    flat | join(&quot;/&quot;) \r\n\r\nWith your input, the output using `jq -r` would be:\r\n\r\n    root/foo/bar\r\n    root/foo/baz\r\n    root/zoo/zar/zaz\r\n\r\n",
                "title": "Build string from variable-depth nested JSON values"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1489331985,
        "creation_date": 1489081196,
        "last_edit_date": 1489331985,
        "question_id": 42701983,
        "body_markdown": "I&#39;m attempting to follow all branches in a tree-styled JSON object to create one long, concatenated string from each branch. The number of children and the maximum depth per node are unknown, so the result must be generalized to any amount. \r\n\r\nThe data I&#39;m working with is similar to the following:  \r\n\r\n    {\r\n        &quot;name&quot;:&quot;root&quot;,\r\n        &quot;children&quot;: [\r\n        \t{\r\n           \t\t&quot;name&quot;:&quot;foo&quot;,\r\n    \t       \t&quot;children&quot;:[\r\n                \t{\r\n                    \t&quot;name&quot;:&quot;bar&quot;,\r\n    \t                &quot;children&quot;:[]\r\n        \t        },\r\n            \t    {\r\n                \t    &quot;name&quot;:&quot;baz&quot;,\r\n                    \t&quot;children&quot;:[]\r\n                \t}\r\n        \t\t]\r\n        \t},\r\n       \t\t{\r\n         \t   &quot;name&quot;:&quot;zoo&quot;,\r\n          \t\t&quot;children&quot;: [\r\n                \t{\r\n                    \t&quot;name&quot;:&quot;zar&quot;,\r\n    \t                &quot;children&quot;: [\r\n        \t                {\r\n            \t                &quot;name&quot;:&quot;zaz&quot;,\r\n                \t            &quot;children&quot;: []\r\n                    \t    }   \r\n                    \t]\r\n                \t}\r\n            \t]\r\n        \t}\r\n    \t]\r\n    }\r\n\r\nI came close in [this jqplay example][1].\r\n\r\nYou can see this works in the naive case where there is only a single child. Where I&#39;m most confused is how to &quot;reset&quot; the parent in the scenarios of multiple children. Instead of recursing   \r\n`root -&gt; foo -&gt; bar -&gt; baz`  \r\nI&#39;d want   \r\n`root -&gt; foo -&gt; bar`  \r\n`root -&gt; foo -&gt; baz`\r\n\r\n\r\nDesired output from the jqplay above:  \r\n`&quot;root/foo/bar&quot;\r\n&quot;root/foo/baz&quot;\r\n&quot;root/zoo/zar/zaz&quot;`\r\n\r\nI would prefer a pure jq solution, a general Bash solution would also work. \r\n\r\n\r\n  [1]: https://jqplay.org/s/QA0f2qEE4S",
        "link": "https://stackoverflow.com/questions/42701983/build-string-from-variable-depth-nested-json-values",
        "title": "Build string from variable-depth nested JSON values"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1454932,
                    "reputation": 2568,
                    "user_id": 1370785,
                    "user_type": "registered",
                    "accept_rate": 59,
                    "profile_image": "https://i.sstatic.net/qHntk.png?s=256",
                    "display_name": "NastyDiaper",
                    "link": "https://stackoverflow.com/users/1370785/nastydiaper"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1489095487,
                "post_id": 42705676,
                "comment_id": 72533759,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 219684,
                    "reputation": 39148,
                    "user_id": 476716,
                    "user_type": "registered",
                    "accept_rate": 77,
                    "profile_image": "https://www.gravatar.com/avatar/4e325890903afc8269eb2c1aa57587b3?s=256&d=identicon&r=PG",
                    "display_name": "OrangeDog",
                    "link": "https://stackoverflow.com/users/476716/orangedog"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1489758901,
                "post_id": 42705676,
                "comment_id": 72824857,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 113656,
                    "reputation": 2149,
                    "user_id": 299209,
                    "user_type": "registered",
                    "accept_rate": 35,
                    "profile_image": "https://www.gravatar.com/avatar/c1fc0e1dee65573215cdf9335ba19f71?s=256&d=identicon&r=PG",
                    "display_name": "philk",
                    "link": "https://stackoverflow.com/users/299209/philk"
                },
                "reply_to_user": {
                    "account_id": 219684,
                    "reputation": 39148,
                    "user_id": 476716,
                    "user_type": "registered",
                    "accept_rate": 77,
                    "profile_image": "https://www.gravatar.com/avatar/4e325890903afc8269eb2c1aa57587b3?s=256&d=identicon&r=PG",
                    "display_name": "OrangeDog",
                    "link": "https://stackoverflow.com/users/476716/orangedog"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1489766971,
                "post_id": 42705676,
                "comment_id": 72830669,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1489758814,
                "last_edit_date": 1489758814,
                "creation_date": 1489098249,
                "answer_id": 42706666,
                "question_id": 42705676,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Your overall requirements are unclear, but you might want to consider using `walk` if you really want to update an arbitrary JSON text in the manner you suggest.  For simplicity, though, I&#39;ll assume you simply have an array of objects of the kind you show.\r\n\r\nLet&#39;s start with the simple task of changing TRUE/FALSE to true/false. This could be accomplished directly as follows:\r\n\r\n    map( map_values(if . == &quot;TRUE&quot; then true \r\n                    elif . == &quot;FALSE&quot; then false\r\n                    else .\r\n                    end) )\r\n\r\nBut because of your &#39;at least one &quot;Shop&quot; set to &quot;TRUE&quot;&#39; requirement, it will be helpful to define an auxiliary function:\r\n\r\n     def toboolean:\r\n       if . == &quot;TRUE&quot; then true \r\n       elif . == &quot;FALSE&quot; then false\r\n       else .\r\n       end;\r\n\r\nSo the first task can be accomplished by:\r\n\r\n    map(map_values(toboolean))\r\n\r\nNow we&#39;re good to go.  Assuming your jq has `any/2`, and under one interpretation of your overall requirements, we could write:\r\n\r\n    map( if any( to_entries[];\r\n                 (.key|startswith(&quot;Shop&quot;)) and .value==&quot;TRUE&quot; )\r\n         then map_values(toboolean)\r\n         else .\r\n         end)\r\n\r\nOr if only the &quot;Shop&quot; values are to be altered:\r\n\r\n    map( if any( to_entries[];\r\n                 (.key|startswith(&quot;Shop&quot;)) and .value==&quot;TRUE&quot; )\r\n         then with_entries( if .key|startswith(&quot;Shop&quot;)\r\n                            then .value |= toboolean\r\n                            else .\r\n                            end)\r\n         else .\r\n         end)\r\n\r\n\r\nIf your jq does not have `any/2`, then please consider upgrading; if that is not an option, you could write your own (inefficient) version using `reduce`. \r\n\r\n\r\n### Using when/2\r\n\r\nThe solutions above can be streamlined using the generic function `when/2`, defined as:\r\n\r\n    def when(filter; action): if filter//null then action else . end;\r\n\r\nFor example, the eight-line solution above becomes this four-liner, which might also be easier to read once one becomes familiar with `when/2`:\r\n    \r\n    map( when( any( to_entries[];\r\n                    (.key|startswith(&quot;Shop&quot;)) and .value==&quot;TRUE&quot; );\r\n         with_entries( when( .key|startswith(&quot;Shop&quot;);\r\n                             .value |= toboolean) ) ))\r\n\r\n\r\n\r\n",
                "title": "Replace all &quot;TRUE&quot; and &quot;FALSE&quot; values in a json with their respective boolean value"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1697350802,
                "creation_date": 1697350802,
                "answer_id": 77295498,
                "question_id": 42705676,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The following code will replace string &quot;TRUE&quot; with Boolean `true` and you can pipe that to a similar expression for &quot;FALSE&quot;:\r\n\r\n```\r\n.[][] |= if . == &quot;TRUE&quot; then true end\r\n```\r\n\r\nTo select the items that have keys starting with &quot;Shop&quot; and have at least one of their value set to `true` you can pipe the result to:\r\n\r\n```\r\nmap(select(with_entries(select((.key | startswith(&quot;Shop&quot;)) and .value))!={}))\r\n```\r\n\r\nOr all combined:\r\n\r\n```\r\n.[][] |= if . == &quot;TRUE&quot; then true end \r\n  | .[][] |= if . == &quot;FALSE&quot; then false end \r\n  | map(select(with_entries(select((.key | startswith(&quot;Shop&quot;)) and .value))!={}))\r\n```\r\n\r\nThe inner `select` here selects only those properties from the object, with key starting with &quot;Shop&quot; and with truthy value. We are assuming here, that you do not have values other than &quot;TRUE&quot; and &quot;FALSE&quot; for these properties to start with. If any such properties found the resulting object `with_entries` operated on will not be empty, so we can use that as the condition for the outer `select` - this will result in objects that we are not interested in being skipped. Finally, `map` which is a synonym for `[.[]|f]` is used so that we get a proper json array back, and not a stream of multiple json objects.",
                "title": "Replace all &quot;TRUE&quot; and &quot;FALSE&quot; values in a json with their respective boolean value"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1697350802,
        "creation_date": 1489094637,
        "last_edit_date": 1489766954,
        "question_id": 42705676,
        "body_markdown": "I have this input JSON\r\n\r\n    [{\r\n       &quot;Name&quot;:&quot;Wolfenstein&quot;,\r\n       &quot;24 Hour&quot;:&quot;FALSE&quot;,\r\n       &quot;Shop 1&quot;:&quot;TRUE&quot;,\r\n       &quot;Shop 2&quot;:&quot;FALSE&quot;,\r\n    }]\r\n\r\nand want to change all &quot;FALSE&quot; and &quot;TRUE&quot; values to `false` and `true` respectively.\r\n\r\n    [{\r\n       &quot;Name&quot;:&quot;Wolfenstein&quot;,\r\n       &quot;24 Hour&quot;:false,\r\n       &quot;Shop 1&quot;:true,\r\n       &quot;Shop 2&quot;:false,\r\n    }]\r\n\r\nAs a bonus, I only want to select those array items whose keys start with &quot;Shop&quot; and have at least on &quot;Shop&quot; set to &quot;TRUE&quot;.\r\nWhat would be the jq filter to use?",
        "link": "https://stackoverflow.com/questions/42705676/replace-all-true-and-false-values-in-a-json-with-their-respective-boolean-va",
        "title": "Replace all &quot;TRUE&quot; and &quot;FALSE&quot; values in a json with their respective boolean value"
    },
    {
        "tags": [
            "bash",
            "gcloud",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 220255,
                    "reputation": 20999,
                    "user_id": 477563,
                    "user_type": "registered",
                    "accept_rate": 90,
                    "profile_image": "https://www.gravatar.com/avatar/07a89fb7b2fd8ece1e9e39e95e004a36?s=256&d=identicon&r=PG",
                    "display_name": "Mr. Llama",
                    "link": "https://stackoverflow.com/users/477563/mr-llama"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1489101607,
                "post_id": 42707331,
                "comment_id": 72536536,
                "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": 1489102607,
                "post_id": 42707331,
                "comment_id": 72536879,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1489150733,
                "creation_date": 1489150733,
                "answer_id": 42718996,
                "question_id": 42707331,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "I&#39;m sure this is possible with `jq`, but in general working with gcloud lists is going to be easier using the built-in formatting and filtering:\r\n\r\n\r\n    $ gcloud compute instances list \\\r\n         --filter &#39;metadata.items.key:kafka&#39; \\\r\n         --format &#39;value(name)&#39;\r\n\r\n`--filter` tells you which items to pick; in this case, it grabs the instance metadata, looks at the items, and checks the keys for those containing `kafka` (use `=` instead to look for keys that are *exactly* `kafka`).\r\n\r\n\r\n`--format` tells you to grab just one `value()` (as opposed to a table, JSON, YAML) from each matching item; that item will be the `name` of the instance.\r\n\r\n\r\nYou can learn more by running `gcloud topic filters`, `gcloud topic formats`, and `gcloud topic projections`.",
                "title": "How to filter unique values with jq?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1502868222,
                "creation_date": 1502868222,
                "answer_id": 45707425,
                "question_id": 42707331,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a simple jq solution using **if** and **any**:\r\n\r\n          if .metadata.items | any(.key == &quot;kafka&quot;) then . else empty end\r\n        | .name\r\n",
                "title": "How to filter unique values with jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1502868222,
        "creation_date": 1489101291,
        "last_edit_date": 1489138590,
        "question_id": 42707331,
        "body_markdown": "I&#39;m using the gcloud describe command to get metadata information about instances.What&#39;s the best way to filter the json response with jq to get the name of the instance - if it contains &quot;kafka&quot; as a key.\r\n\r\n.name + &quot; &quot; + .metadata.items[]?.key | select(contains(&quot;kafka&quot;))&#39;\r\n\r\nBasically if items contains kafka print name.This is just a small excerpt from the json file.\r\n\r\n  \r\n\r\n      &quot;metadata&quot;: {\r\n        &quot;fingerprint&quot;: &quot;xxxxx=&quot;,\r\n        &quot;items&quot;: [\r\n          {\r\n            &quot;key&quot;: &quot;kafka&quot;,\r\n            &quot;value&quot;: &quot;xxx=&quot;\r\n          },\r\n          {\r\n            &quot;key&quot;: &quot;some_key&quot;,\r\n            &quot;value&quot;: &quot;vars&quot;\r\n          }\r\n        ],\r\n        &quot;kind&quot;: &quot;compute#metadata&quot;\r\n      },\r\n      &quot;name&quot;: &quot;instance-name&quot;,\r\n      &quot;networkInterfaces&quot;: [\r\n        {\r\n          &quot;accessConfigs&quot;: [\r\n            {\r\n              &quot;kind&quot;: &quot;compute#accessConfig&quot;,\r\n              &quot;name&quot;: &quot;External NAT&quot;,\r\n              &quot;natIP&quot;: &quot;ip&quot;,\r\n              &quot;type&quot;: &quot;ONE_TO_ONE_NAT&quot;\r\n            }\r\n          ],\r\n          &quot;kind&quot;: &quot;compute#networkInterface&quot;,\r\n          &quot;name&quot;: &quot;&quot;,\r\n          &quot;network&quot;: xxxxx\r\n        }\r\n      ],",
        "link": "https://stackoverflow.com/questions/42707331/how-to-filter-unique-values-with-jq",
        "title": "How to filter unique values with jq?"
    },
    {
        "tags": [
            "json",
            "python-3.x",
            "awk",
            "sed",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1827668,
                    "reputation": 3157,
                    "user_id": 6404949,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://lh6.googleusercontent.com/-ksf1VmNZnPA/AAAAAAAAAAI/AAAAAAAAExQ/uleAWJ-xbJg/s256-rj/photo.jpg",
                    "display_name": "VIPIN KUMAR",
                    "link": "https://stackoverflow.com/users/6404949/vipin-kumar"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1489144687,
                "post_id": 42715792,
                "comment_id": 72554143,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 1306358,
                    "reputation": 42647,
                    "user_id": 1255289,
                    "user_type": "registered",
                    "accept_rate": 89,
                    "profile_image": "https://www.gravatar.com/avatar/5ed02658b2440179f00eeff8beb7aa4c?s=256&d=identicon&r=PG",
                    "display_name": "miken32",
                    "link": "https://stackoverflow.com/users/1255289/miken32"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1489168125,
                "post_id": 42715792,
                "comment_id": 72569064,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1491316392,
                "last_edit_date": 1495540459,
                "creation_date": 1491316392,
                "answer_id": 43210227,
                "question_id": 42715792,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Since this question has both jq and awk tags, I&#39;d recoomend using jq and awk as explained here: https://stackoverflow.com/questions/28744361/split-a-json-file-into-separate-file\r\n\r\nYou can easily pad the key names in jq or awk.",
                "title": "split json file into object per file"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1491316392,
        "creation_date": 1489140855,
        "last_edit_date": 1489173924,
        "question_id": 42715792,
        "body_markdown": "I have a JSON file, with a structure like this:\r\n\r\n    {\r\n    &quot;106&quot; : {\r\n          &quot;id54011&quot; : [\r\n             {\r\n                &quot;partno1&quot; : &quot;16690617&quot;\r\n             },\r\n             {\r\n                &quot;partno2&quot; : &quot;5899180&quot;\r\n             }\r\n          ],\r\n          &quot;parts&quot; : [\r\n             &quot;0899180&quot;,\r\n             &quot;16920617&quot;\r\n          ],\r\n          &quot;id5632&quot; : [\r\n             {\r\n                &quot;partno1&quot; : &quot;090699180&quot;\r\n             }\r\n          ]\r\n       },\r\n       &quot;560&quot; : {\r\n          &quot;id9452&quot; : [\r\n             {\r\n                &quot;partno2&quot; : &quot;1569855&quot;\r\n             }\r\n          ],\r\n          &quot;parts&quot; : [\r\n             &quot;03653624&quot;,\r\n             &quot;15899855&quot;\r\n          ],\r\n          &quot;id578&quot; : [\r\n             {\r\n                &quot;partno3&quot; : &quot;0366393624&quot;\r\n             },\r\n             {\r\n                &quot;partno4&quot; : &quot;0363213624&quot;\r\n             }\r\n          ]\r\n       }\r\n    }\r\n    \r\nI need to split this JSON into multiple files, using this method:\r\n\r\nEach JSON file will consist of one object. Using the example file above, I should end up with `000106.json`, and `000560.json`. (All names, must have 6 digits, so zeros must be added.)\r\n\r\nI have tried to use an iteration grouper, in python, and jq, for this, but no luck up to now.\r\n\r\nExpected output:\r\nJSON file 1, named `000106.json`:\r\n\r\n    {\r\n       &quot;106&quot; : {\r\n           &quot;id54011&quot; : [\r\n               {\r\n                   &quot;partno1&quot; : &quot;16690617&quot;\r\n               },\r\n               {\r\n                   &quot;partno2&quot; : &quot;5899180&quot;\r\n               }\r\n           ],\r\n           &quot;parts&quot; : [\r\n               &quot;0899180&quot;,\r\n               &quot;16920617&quot;\r\n           ],\r\n           &quot;id5632&quot; : [\r\n               {\r\n                   &quot;partno1&quot; : &quot;090699180&quot;\r\n               }\r\n           ]\r\n       }\r\n    }\r\n    \r\nJSON file 2, named `000560.json`:\r\n\r\n    {\r\n        &quot;560&quot; : {\r\n            &quot;id9452&quot; : [\r\n                {\r\n                    &quot;partno2&quot; : &quot;1569855&quot;\r\n                }\r\n            ],\r\n            &quot;parts&quot; : [\r\n                &quot;03653624&quot;,\r\n                &quot;15899855&quot;\r\n            ],\r\n            &quot;id578&quot; : [\r\n                {\r\n                    &quot;partno3&quot; : &quot;0366393624&quot;\r\n                },\r\n                {\r\n                    &quot;partno4&quot; : &quot;0363213624&quot;\r\n                }\r\n            ]\r\n        }\r\n    }",
        "link": "https://stackoverflow.com/questions/42715792/split-json-file-into-object-per-file",
        "title": "split json file into object per file"
    },
    {
        "tags": [
            "json",
            "bash",
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 4828661,
                    "reputation": 3255,
                    "user_id": 4166604,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f17d18f5a2248f70a9cd88491412741a?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Andy",
                    "link": "https://stackoverflow.com/users/4166604/andy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1586118467,
                "post_id": 42716734,
                "comment_id": 108003321,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 124,
                "is_accepted": true,
                "score": 123,
                "last_activity_date": 1489144560,
                "creation_date": 1489144560,
                "answer_id": 42717073,
                "question_id": 42716734,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "AFAIK `jq` does not support in-place editing, so you must redirect to a temporary file first and then replace your original file with it, or use `sponge` utility from the moreutils package, like that:\r\n\r\n    jq &#39;.address = &quot;abcde&quot;&#39; test.json|sponge test.json\r\n\r\nThere are other techniques to &quot;redirect to the same file&quot;, like saving your output in a variable e.t.c. &quot;Unix &amp; Linux StackExchange&quot; is a good place to start, if you want to learn more about this.",
                "title": "Modify a key-value in a json using jq in-place"
            },
            {
                "up_vote_count": 179,
                "is_accepted": false,
                "score": 178,
                "last_activity_date": 1575473869,
                "last_edit_date": 1575473869,
                "creation_date": 1489149480,
                "answer_id": 42718624,
                "question_id": 42716734,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use a temporary file; it&#39;s what any program that claims to do in-place editing is doing.\r\n\r\n    tmp=$(mktemp)\r\n    jq &#39;.address = &quot;abcde&quot;&#39; test.json &gt; &quot;$tmp&quot; &amp;&amp; mv &quot;$tmp&quot; test.json\r\n\r\nIf the address isn&#39;t hard-coded, pass the correct address via a `jq` argument:\r\n\r\n    address=abcde\r\n    jq --arg a &quot;$address&quot; &#39;.address = $a&#39; test.json &gt; &quot;$tmp&quot; &amp;&amp; mv &quot;$tmp&quot; test.json",
                "title": "Modify a key-value in a json using jq in-place"
            },
            {
                "up_vote_count": 13,
                "is_accepted": false,
                "score": 13,
                "last_activity_date": 1586016321,
                "creation_date": 1586016321,
                "answer_id": 61030874,
                "question_id": 42716734,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Just to add to chepner answer and if you want it in a shell script.\r\n\r\ntest.json\r\n\r\n    {\r\n      &quot;name&quot;: &quot;abcd&quot;,\r\n      &quot;age&quot;: 30,\r\n      &quot;address&quot;: &quot;abc&quot;\r\n    }\r\n\r\nscript.sh\r\n\r\n    #!/bin/bash\r\n    address=&quot;abcde&quot;\r\n    age=40\r\n    \r\n    # Strings:\r\n    jq --arg a &quot;${address}&quot; &#39;.address = $a&#39; test.json &gt; &quot;tmp&quot; &amp;&amp; mv &quot;tmp&quot; test.json\r\n        \r\n    # Integers:\r\n    jq --argjson a &quot;${age}&quot; &#39;.age = $a&#39; test.json &gt; &quot;tmp&quot; &amp;&amp; mv &quot;tmp&quot; test.json\r\n\r\n\r\n\r\n\r\n",
                "title": "Modify a key-value in a json using jq in-place"
            },
            {
                "up_vote_count": 85,
                "is_accepted": false,
                "score": 83,
                "last_activity_date": 1644415741,
                "last_edit_date": 1644415741,
                "creation_date": 1586121517,
                "answer_id": 61049639,
                "question_id": 42716734,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Temp files add more complexity when not needed (unless you are truly dealing with JSON files so large you cannot fit them in memory (GB to 100&#39;s of GB or TB, depending on how much RAM/parallelism you have)\r\n\r\nThe Pure bash way.\r\n\r\n```\r\ncontents=&quot;$(jq &#39;.address = &quot;abcde&quot;&#39; test.json)&quot; &amp;&amp; \\\r\necho -E &quot;${contents}&quot; &gt; test.json\r\n```\r\n\r\n## Pros\r\n\r\n- No temp file to juggle\r\n- Pure bash\r\n- Don&#39;t need an admin to install `sponge`, which is not installed by default\r\n- Simpler\r\n\r\n## Cons\r\n\r\n- This works perfectly fine for json because it cannot contain a literal null character. If you were to try this outside the json arena, it would fail when a null is encountered (and you would have to do some encoding/decoding workarounds). Bash variables cannot store literal nulls.\r\n\r\n**Note**: this can not be combined as &quot;one command&quot; (like @codekandis\r\n suggested), since redirection sometimes starts *before* the left hand side (LHS) of an expression is run, and starting redirection before running `jq` erroneously empties the file, hence two separate commands. It may &quot;seem&quot; to work when you try it, but this is misleading and has a very high probability of failing as soon as the circumstances change.\r\n\r\n*Update*: Added `-E` option to disable escape characters _just in case_ you are on `systems where they are interpreted by default.` (Which I&#39;ve never actually seen)",
                "title": "Modify a key-value in a json using jq in-place"
            },
            {
                "up_vote_count": 10,
                "is_accepted": false,
                "score": 10,
                "last_activity_date": 1617692493,
                "last_edit_date": 1617692493,
                "creation_date": 1617634501,
                "answer_id": 66954991,
                "question_id": 42716734,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Example for nested json with changing single and multiple values. \r\n\r\nconfig.json\r\n\r\n    {\r\n      &quot;Parameters&quot;: {\r\n        &quot;Environment&quot;: &quot;Prod&quot;,\r\n        &quot;InstanceType&quot;: &quot;t2.micro&quot;,\r\n        &quot;AMIID&quot;: &quot;ami-02d8e11&quot;,\r\n        &quot;ConfigRegion&quot;: &quot;eu-west-1&quot;\r\n      }\r\n    }\r\n\r\n\r\nwith the below command, you can edit multiple values. \r\n\r\n\r\n    tmp=$(mktemp)\r\n    jq &#39;.Parameters.AMIID = &quot;ami-02d8sdfsdf&quot; | .Parameters.Environment = &quot;QA&quot;&#39; config.json &gt; &quot;$tmp&quot; &amp;&amp; mv &quot;$tmp&quot; config.json\r\n\r\n\r\nwith the below command, you can edit single value. \r\n\r\n    tmp=$(mktemp)\r\n    jq &#39;.Parameters.AMIID = &quot;ami-02d8sdfsdf&quot;&#39; config.json &gt; &quot;$tmp&quot; &amp;&amp; mv &quot;$tmp&quot; config.json\r\n\r\n\r\n",
                "title": "Modify a key-value in a json using jq in-place"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": -2,
                "last_activity_date": 1666684054,
                "last_edit_date": 1666684054,
                "creation_date": 1625080364,
                "answer_id": 68200468,
                "question_id": 42716734,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I didn&#39;t like any of the solutions and created the [`sde` utility](https://github.com/dvershinin/sde).\r\n\r\n```bash\r\npip install sde\r\n```\r\n\r\nThen, e.g. for the following JSON data:\r\n\r\n```json\r\n{\r\n  &quot;Parameters&quot;: {\r\n    &quot;Environment&quot;: &quot;Prod&quot;,\r\n    &quot;InstanceType&quot;: &quot;t2.micro&quot;,\r\n    &quot;AMIID&quot;: &quot;ami-02d8e11&quot;,\r\n    &quot;ConfigRegion&quot;: &quot;eu-west-1&quot;\r\n  }   \r\n}\r\n```\r\n\r\n you can simply do:\r\n\r\n```bash\r\nsde Parameters.Environment Dev test.json\r\n```\r\n",
                "title": "Modify a key-value in a json using jq in-place"
            },
            {
                "up_vote_count": 9,
                "is_accepted": false,
                "score": 9,
                "last_activity_date": 1631720045,
                "creation_date": 1631720045,
                "answer_id": 69196044,
                "question_id": 42716734,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "this should work\r\n```\r\naddress = aaaaa\r\necho $(jq --arg a &quot;$address&quot; &#39;.address = ($a)&#39; test.json) &gt; test.json\r\n```\r\nfor whatever reason, without the echo, it makes a bin file and my python script was not able to parse it.\r\n\r\n",
                "title": "Modify a key-value in a json using jq in-place"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1663015246,
                "creation_date": 1663015246,
                "answer_id": 73695035,
                "question_id": 42716734,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I took the best of a couple answers [here][1] and [here][2].\r\n\r\nThis uses a parameter named `actionname` as an input to an assignment of the `name` property at the document level. ACTION_NAME is just an envvar I want to use as the replacement value.\r\n```bash\r\ncontents=&quot;$(jq --arg actionname ${ACTION_NAME} &#39;.name = $actionname&#39; ./${ACTION_NAME}/package.json)&quot; &amp;&amp; \\\r\necho -E &quot;${contents}&quot; &gt; ${ACTION_NAME}/package.json;\r\n```\r\n\r\n\r\n  [1]: https://stackoverflow.com/a/61049639/901899\r\n  [2]: https://stackoverflow.com/a/69196044/901899",
                "title": "Modify a key-value in a json using jq in-place"
            }
        ],
        "is_answered": true,
        "answer_count": 8,
        "score": 169,
        "last_activity_date": 1690384720,
        "creation_date": 1489143582,
        "last_edit_date": 1684861149,
        "question_id": 42716734,
        "body_markdown": "I have a json in which I want to modify a particular value but the terminal always displays the json with the modified value but it does not actually change the value in the particular file. \r\n\r\nSample json:\r\n\r\n```json\r\n{\r\n    &quot;name&quot;: &quot;abcd&quot;,\r\n    &quot;age&quot;: 30,\r\n    &quot;address&quot;: &quot;abc&quot;\r\n}\r\n```\r\n\r\nI want to change the value of address in the file itself but so far I&#39;ve been unable to do so. I tried using:\r\n\r\n    jq &#39;.address = &quot;abcde&quot;&#39; test.json\r\nbut it didn&#39;t work. Any suggestions?",
        "link": "https://stackoverflow.com/questions/42716734/modify-a-key-value-in-a-json-using-jq-in-place",
        "title": "Modify a key-value in a json using jq in-place"
    }
]