[
    {
        "tags": [
            "arrays",
            "json",
            "csv",
            "sum",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1541471748,
                "creation_date": 1541471748,
                "answer_id": 53165045,
                "question_id": 53163379,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Given your input and an invocation of jq with the -r option, the following filter:\r\n\r\n     .vms[]\r\n    | [.hostname, .state, .platform, (.Disks | map(.size|tonumber) | add)]\r\n    | join(&quot;,&quot;)\r\n\r\nproduces:\r\n\r\n    host1,running,linux,62277025792\r\n    host2,running,linux,39519165044\r\n\r\nAdding the headers and exploring what happens when `join(&quot;,&quot;)` is replaced by `@csv` are left as exercises :-)\r\n\r\n",
                "title": "aggregate array attribute and convert to csv"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1541471748,
        "creation_date": 1541458001,
        "question_id": 53163379,
        "body_markdown": "I have the following file ( vms.json ) that i am trying to convert csv while adding the disk size element.\r\n\r\n**vms.json**\r\n\r\n        {\r\n    &quot;vms&quot;: [\r\n    {\r\n      &quot;hostname&quot;: &quot;host1&quot;,\r\n      &quot;state&quot;: &quot;running&quot;,\r\n      &quot;platform&quot;: &quot;linux&quot;,\r\n      &quot;Disks&quot;: [\r\n        {\r\n          &quot;index&quot;: 1,\r\n          &quot;volume_name&quot;: &quot;/boot&quot;,\r\n          &quot;size&quot;: &quot;34359738368&quot;\r\n        },\r\n        {\r\n          &quot;index&quot;: 2,\r\n          &quot;volume_name&quot;: &quot;/data&quot;,\r\n          &quot;size&quot;: &quot;27917287424&quot;\r\n        }\r\n     ]\r\n    },\r\n    {\r\n      &quot;hostname&quot;: &quot;host2&quot;,\r\n      &quot;state&quot;: &quot;running&quot;,\r\n      &quot;platform&quot;: &quot;linux&quot;,\r\n      &quot;Disks&quot;: [\r\n        {\r\n          &quot;index&quot;: 1,\r\n          &quot;volume_name&quot;: &quot;/boot&quot;,\r\n          &quot;size&quot;: &quot;34359738368&quot;\r\n        },\r\n        {\r\n          &quot;index&quot;: 2,\r\n          &quot;volume_name&quot;: &quot;/user_data&quot;,\r\n          &quot;size&quot;: &quot;5159324276&quot;\r\n        },\r\n        {\r\n          &quot;index&quot;: 3,\r\n          &quot;volume_name&quot;: &quot;/temporary&quot;,\r\n          &quot;size&quot;: &quot;102400&quot;\r\n        }\r\n      ]\r\n    }\r\n    ]\r\n    }\r\n\r\n**vms.csv**\r\n\r\n    hostname,state,platform,Disks\r\n    host1,running,linux,62277025792\r\n    host2,running,linux,39519165044\r\n\r\nI would like to use jq to perform this conversion, however \r\nHow can this be achieved using jq and @csv filter?\r\n",
        "link": "https://stackoverflow.com/questions/53163379/aggregate-array-attribute-and-convert-to-csv",
        "title": "aggregate array attribute and convert to csv"
    },
    {
        "tags": [
            "python",
            "json",
            "jq",
            "gerrit"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 7869117,
                    "reputation": 62566,
                    "user_id": 5947043,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/jUK37.png?s=256",
                    "display_name": "ADyson",
                    "link": "https://stackoverflow.com/users/5947043/adyson"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1541497515,
                "post_id": 53169040,
                "comment_id": 93228265,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2550933,
                    "reputation": 13299,
                    "user_id": 2214695,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/dee2ef257601e05c5659f04de9cb7c67?s=256&d=identicon&r=PG",
                    "display_name": "oliv",
                    "link": "https://stackoverflow.com/users/2214695/oliv"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1541498068,
                "post_id": 53169040,
                "comment_id": 93228573,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 12319404,
                    "reputation": 109,
                    "user_id": 8989055,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/e7e71eaa08ef3cd25bf1b3ab7a680ceb?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Sergii",
                    "link": "https://stackoverflow.com/users/8989055/sergii"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1541498342,
                "post_id": 53169040,
                "comment_id": 93228726,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1541520362,
                "last_edit_date": 1541520362,
                "creation_date": 1541504026,
                "answer_id": 53171073,
                "question_id": 53169040,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could use the jq program like in the following example:\r\n\r\n    ssh -p 29418 gerrit.abc.se gerrit query --format=JSON project:dddd status:merged branch:master change:Ie2ef9e47f --submit-records |\r\n     jq --raw-output &#39;\r\n       .submitRecords[]? \r\n       | .labels[]\r\n       | .label + &quot; = &quot; + .status + &quot; by &quot; + .by.name&#39;\r\n    \r\n    Code-Review =&gt; OK by Marcelo Avila de Oliveira\r\n    Verification =&gt; OK by Gerrit\r\n\r\nSee more info about the jq [here][1].\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/",
                "title": "How to parse JSON output of gerrit query to extract data?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1689076763,
        "creation_date": 1541496481,
        "last_edit_date": 1541531084,
        "question_id": 53169040,
        "body_markdown": "I have a scenario, where I am trying to extract some data from output of gerrit query. But unable to do using awk\r\n\r\nCommand:\r\n\r\n    ssh -p 29418 gerrit.abc.se gerrit query --format=JSON project:dddd status:merged branch:master change:Ie2ef9e47f --submit-records\r\n    \r\nOutput of above command:\r\n\r\n    {\r\n      &quot;project&quot;: &quot;dddd&quot;,\r\n      &quot;branch&quot;: &quot;master&quot;,\r\n      &quot;id&quot;: &quot;Ie2ef9e47fc6c046091d93521198bf0a1075cb77e&quot;,\r\n      &quot;number&quot;: 3984134,\r\n      &quot;subject&quot;: &quot;adding configuration&quot;,\r\n      &quot;owner&quot;: {\r\n        &quot;name&quot;: &quot;abc&quot;,\r\n        &quot;email&quot;: &quot;abc.com&quot;,\r\n        &quot;username&quot;: &quot;eshakuy&quot;\r\n      },\r\n      &quot;url&quot;: &quot;https://gerrit.abc.se/3984134&quot;,\r\n      &quot;commitMessage&quot;: &quot;adding configuration\\n\\nChange-Id: Ie2ef9e47fc6c046091d93521198bf0a1075cb77e\\n&quot;,\r\n      &quot;createdOn&quot;: 1533208993,\r\n      &quot;lastUpdated&quot;: 1536301464,\r\n      &quot;open&quot;: false,\r\n      &quot;status&quot;: &quot;MERGED&quot;,\r\n      &quot;submitRecords&quot;: [\r\n        {\r\n          &quot;status&quot;: &quot;OK&quot;,\r\n          &quot;labels&quot;: [\r\n            {\r\n              &quot;label&quot;: &quot;Verified&quot;,\r\n              &quot;status&quot;: &quot;OK&quot;,\r\n              &quot;by&quot;: {\r\n                &quot;name&quot;: &quot;ADP Automation&quot;,\r\n                &quot;username&quot;: &quot;adpauto&quot;\r\n              }\r\n            },\r\n            {\r\n              &quot;label&quot;: &quot;Code-Review&quot;,\r\n              &quot;status&quot;: &quot;OK&quot;,\r\n              &quot;by&quot;: {\r\n                &quot;name&quot;: &quot;abc&quot;,\r\n                &quot;email&quot;: &quot;abc.com&quot;,\r\n                &quot;username&quot;: &quot;eeeee&quot;\r\n              }\r\n            }\r\n          ]\r\n        }\r\n      ]\r\n    }\r\n    {\r\n      &quot;type&quot;: &quot;stats&quot;,\r\n      &quot;rowCount&quot;: 1,\r\n      &quot;runTimeMilliseconds&quot;: 10,\r\n      &quot;moreChanges&quot;: false\r\n    }\r\n\r\nWhat I want to extract from above output is:\r\n\r\n    submit Records:\r\n    \r\n    label:Verified status:OK name:ADP Automation\r\n    lable:Code-Review status:OK name:abc\r\n\r\nThat is the only information I need to display/store in csv file. \r\n",
        "link": "https://stackoverflow.com/questions/53169040/how-to-parse-json-output-of-gerrit-query-to-extract-data",
        "title": "How to parse JSON output of gerrit query to extract data?"
    },
    {
        "tags": [
            "json",
            "mapping",
            "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": 1541544761,
                "post_id": 53181061,
                "comment_id": 93252738,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1541588994,
                "last_edit_date": 1541588994,
                "creation_date": 1541545916,
                "answer_id": 53181478,
                "question_id": 53181061,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Assuming the text file is in dict.txt and the JSON file is in source.json, the invocation\r\n\r\n    jq -Rs --argfile target source.json dict.txt &#39;\r\n      ([ split(&quot;\\n&quot;)[]\r\n         | select(length&gt;0) \r\n         | split(&quot; &quot;) \r\n         | { (.[0]): .[1]} ] \r\n       | add) as $dict\r\n      | $target\r\n      | .features |= map(.value = $dict[.feature])&#39;\r\n\r\nwould yield the desired output.\r\n\r\nThe main reason for including `select(length&gt;0)` is to skip any empty strings that might result from using `split(&quot;\\n&quot;)` to split an entire file.\r\n\r\n\r\n\r\n",
                "title": "jq: Insert values according to mappings from external file"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1541810220,
        "creation_date": 1541543414,
        "last_edit_date": 1541810220,
        "question_id": 53181061,
        "body_markdown": "I was wondering how I can complete this task by command line jq. I make up a file with similar nested structure as follows:\r\n\r\n    {\r\n        &quot;item&quot;: &quot;item1&quot;,\r\n        &quot;features&quot;: [\r\n            {\r\n                &quot;feature&quot;: &quot;feature_a&quot;,\r\n                &quot;value&quot;: &quot;&quot;\r\n            },\r\n            {\r\n                &quot;feature&quot;: &quot;feature_b&quot;,\r\n                &quot;value&quot;: &quot;&quot;\r\n            }\r\n         ]\r\n    }\r\n\r\nNow I have another file that maps the `feature` to `value`:\r\n\r\n    feature_a value_1\r\n    feature_b value_2\r\n\r\nSo I would like to insert the `value` into the first json file, according to the maps, resulting the following output:\r\n\r\n    {\r\n        &quot;item&quot;: &quot;item1&quot;;\r\n        &quot;features&quot;: [\r\n            {\r\n                &quot;feature&quot;: &quot;feature_a&quot;,\r\n                &quot;value&quot;: &quot;value_1&quot;\r\n            },\r\n            {\r\n                &quot;feature&quot;: &quot;feature_b&quot;,\r\n                &quot;value&quot;: &quot;value_2&quot;\r\n            }\r\n         ]\r\n    }\r\n\r\nHow I can achieve above operation by `jq`?\r\nThanks in advance!",
        "link": "https://stackoverflow.com/questions/53181061/jq-insert-values-according-to-mappings-from-external-file",
        "title": "jq: Insert values according to mappings from external file"
    },
    {
        "tags": [
            "json",
            "string",
            "object",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1541647775,
                "creation_date": 1541647775,
                "answer_id": 53201151,
                "question_id": 53200945,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`.SecretString` is not so secret, but it is the JSON string representation of a JSON object. To parse it, simply use `fromjson`, so you could, for example, obtain the username with:\r\n\r\n    .SecretString | fromjson | .username",
                "title": "How do I get a key-value pair out of a JSON string using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1541703658,
        "creation_date": 1541646093,
        "last_edit_date": 1541703658,
        "question_id": 53200945,
        "body_markdown": "This is what I have:\r\n\r\n    {\r\n        &quot;ARN&quot;: &quot;sdfsdfsdfsdfds&quot;,\r\n        &quot;Name&quot;: &quot;sdfsdfsdfsdsf&quot;,\r\n        &quot;VersionId&quot;: &quot;sdfsdfsdfsdfsdf&quot;,\r\n        &quot;SecretString&quot;: &quot;{\\&quot;username\\&quot;:\\&quot;myusername\\&quot;,\\&quot;password\\&quot;:\\&quot;mypassword\\&quot;}&quot;,\r\n        &quot;VersionStages&quot;: [\r\n            &quot;AWSCURRENT&quot;\r\n        ],\r\n        &quot;CreatedDate&quot;: 1541641750.607\r\n    }\r\n\r\nHow do I get `mykey` and `myvalue` out of this JSON?\r\n\r\n`jq &#39;.SecretString&#39; -r` gives me this:\r\n\r\n    {&quot;username&quot;:&quot;myusername&quot;,&quot;password&quot;:&quot;mypassword&quot;}\r\n\r\nBut how do I get `myusername` and `mypassword` out of that?\r\n\r\nOk, this seems to work, but should I be piping it back into jq like this? Feels like im doing it wrong:\r\n\r\n    jq &#39;.SecretString&#39; -r | jq &#39;.username&#39; -r\r\n    jq &#39;.SecretString&#39; -r | jq &#39;.password&#39; -r",
        "link": "https://stackoverflow.com/questions/53200945/how-do-i-get-a-key-value-pair-out-of-a-json-string-using-jq",
        "title": "How do I get a key-value pair out of a JSON string using jq"
    },
    {
        "tags": [
            "csv",
            "jq",
            "frequency-distribution"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1541776761,
                "last_edit_date": 1541776761,
                "creation_date": 1541766609,
                "answer_id": 53225755,
                "question_id": 53225044,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can try this jq filter:\r\n\r\n    jq -sr &#39;group_by(.new)|.[]|[.[0].new, length]|@tsv&#39;\r\n    813 ROT 2\r\n    9878 SU 1\r\n\r\nOption `-s` allows to get full content of the file into an array (to apply the filter to the full content).\r\n\r\nOption `-r` displays raw data.\r\n\r\nThe `group_by` function groups into an array all object having the same `new` key.\r\n\r\nThe `.[0].new` gets the value of the key `new` and `length` the number of key with the same value.\r\n\r\nThe operator `@tsv` formats into tab separated values.\r\n\r\n",
                "title": "using jq to output in tsv unique values of an element with frequency of occurrence"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1541782244,
        "creation_date": 1541763467,
        "last_edit_date": 1541782244,
        "question_id": 53225044,
        "body_markdown": "given the following json, how could i create a tsv, that would output the frequencies of the values found in it (in the new element)?\r\n\r\n    {&quot;_id&quot;:{&quot;$someid&quot;:&quot;545&quot;},&quot;new&quot;:&quot;813 ROT&quot;,&quot;old&quot;:{&quot;$someid&quot;:&quot;5fe&quot;}}\r\n    {&quot;_id&quot;:{&quot;$someid&quot;:&quot;659889a&quot;},&quot;new&quot;:&quot;9878 SU&quot;,&quot;old&quot;:{&quot;$someid&quot;:&quot;5bc&quot;}}\r\n    {&quot;_id&quot;:{&quot;$someid&quot;:&quot;986978754b&quot;},&quot;new&quot;:&quot;813 ROT&quot;,&quot;old&quot;:{&quot;$someid&quot;:&quot;5bc1af&quot;}}\r\n\r\ndesired output:\r\n\r\n    813 ROT 2\r\n    9878 SU 1\r\n\r\ni can extract the values with .new, but do not know how to group them and create the tsv then\r\n\r\nwhat i have tried:\r\n\r\n    def counter(stream):   reduce stream as $s ({}; .[$s|tostring] += 1);  counter(inputs | .new) | to_entries[] | {ItemId: (.key), Count: .value}\r\n\r\nbut gives output:\r\n\r\n    {\r\n      &quot;ItemId&quot;: &quot;9878 SU&quot;,\r\n      &quot;Count&quot;: 1\r\n    }\r\n    {\r\n      &quot;ItemId&quot;: &quot;813 ROT&quot;,\r\n      &quot;Count&quot;: 1\r\n    }\r\n\r\ni use version of jq found in ubuntu 16.04 repositories\r\n",
        "link": "https://stackoverflow.com/questions/53225044/using-jq-to-output-in-tsv-unique-values-of-an-element-with-frequency-of-occurren",
        "title": "using jq to output in tsv unique values of an element with frequency of occurrence"
    },
    {
        "tags": [
            "amazon-web-services",
            "jq",
            "aws-cli"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1541779386,
                "creation_date": 1541779386,
                "answer_id": 53229265,
                "question_id": 53229035,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can try this jq filter:\r\n\r\n    jq &#39;.[]|{id,env:.ENVIRONMENT[],usage:(.Usage[]//null),name:.Name[]}&#39; file\r\n\r\nwhich is almost the same as you, except the `.Usage[]//null` which gives the `Usage` or if not present `null`.\r\n\r\nNote that your first attempt is the same as:\r\n\r\n    jq &#39;.[]|flatten&#39; \r\n\r\n(requires jq 1.5 though)",
                "title": "Return Multiple Blocks in JQ With Formatting"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1541780917,
                "creation_date": 1541780917,
                "answer_id": 53229655,
                "question_id": 53229035,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "In general, one has to be careful about using .[] multiple times in the way that the OP has done.  If you just want the first item in each array, then you could use `.[0]` as follows:\r\n\r\n    .[]\r\n    | {id, env: .ENVIRONMENT[0], usage: .Usage[0], name: .Name[0]}\r\n\r\n(This approach handles the case of some arrays being empty quite nicely.)\r\n\r\nIf (for example) the `.ENVIRONMENT` array might have more than one item, you might want to consider another variant such as:\r\n\r\n    .[]\r\n    | range(0; .ENVIRONMENT|length) as $i\r\n    | {id, env: .ENVIRONMENT[$i], usage: .Usage[$i], name: .Name[$i]}\r\n\r\n\r\n",
                "title": "Return Multiple Blocks in JQ With Formatting"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1541780917,
        "creation_date": 1541778627,
        "question_id": 53229035,
        "body_markdown": "I have the below json as input:\r\n\r\n    [\r\n        {\r\n            &quot;ENVIRONMENT&quot;: [\r\n                &quot;sit&quot;\r\n            ], \r\n            &quot;Usage&quot;: [], \r\n            &quot;id&quot;: &quot;i-098a99bd2bd0ac86b&quot;, \r\n            &quot;Name&quot;: [\r\n                &quot;instance1&quot;\r\n            ]\r\n        }, \r\n        {\r\n            &quot;ENVIRONMENT&quot;: [\r\n                &quot;uat&quot;\r\n            ], \r\n            &quot;Usage&quot;: [\r\n                &quot;testing&quot;\r\n            ], \r\n            &quot;id&quot;: &quot;i-0b210876db6d028f3&quot;, \r\n            &quot;Name&quot;: [\r\n                &quot;instance2&quot;\r\n            ]\r\n        }\r\n    ]\r\n\r\nI can use `jq &#39;.[] | [.id, .ENVIRONMENT[], .Usage[], .Name[]]&#39;` in order to get the following:\r\n\r\n    [\r\n      &quot;i-098a99bd2bd0ac86b&quot;,\r\n      &quot;sit&quot;,\r\n      &quot;instance1&quot;\r\n    ]\r\n    [\r\n      &quot;i-0b210876db6d028f3&quot;,\r\n      &quot;uat&quot;,\r\n      &quot;testing&quot;,\r\n      &quot;instance2&quot;\r\n    ]\r\n\r\nOr I could use `jq &#39;.[] | {id: .id, env: .ENVIRONMENT[], usage: .Usage[], name: .Name[]}&#39;` to get the following (it only returns one of instances):\r\n\r\n    {\r\n      &quot;id&quot;: &quot;i-0b210876db6d028f3&quot;,\r\n      &quot;env&quot;: &quot;uat&quot;,\r\n      &quot;usage&quot;: &quot;testing&quot;,\r\n      &quot;name&quot;: &quot;instance2&quot;\r\n    }\r\n\r\nIs there a way I can get the second method&#39;s formatting, but return all the instances like the first method gives me? I suppose for the tag that doesn&#39;t exist in one of the instances, usage would be empty or null.",
        "link": "https://stackoverflow.com/questions/53229035/return-multiple-blocks-in-jq-with-formatting",
        "title": "Return Multiple Blocks in JQ With Formatting"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1541781718,
                "last_edit_date": 1541781718,
                "creation_date": 1541780730,
                "answer_id": 53229612,
                "question_id": 53229452,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I was able to obtain the expected result from your sample JSON using the following :\r\n\r\n    group_by(.org, .rc.&quot;$event&quot;)[] | [.[0].rc.&quot;$event&quot;, .[0].org, length] | @tsv\r\n\r\nYou can [try it on jqplay.org](https://jqplay.org/s/FPBiC8xt3p).\r\n\r\nThe modification of the `group_by` clause ensures we will have one entry by pair of `.org`/`.rc.$event` (without it we would only have one entry by `.org`, which might hide some `.rc.$event`).\r\n\r\nThen we add the `.rc.$event` to the array you create just as you did with the `.org`, accessing the value of the first item of the array since we know they&#39;re all the same anyway.\r\n\r\nTo sort the result, you can put it in an array and use `sort_by(.[0])` which will sort by the first element of the rows :\r\n\r\n    [group_by(.org, .rc.&quot;$event&quot;)[] | [.[0].rc.&quot;$event&quot;, .[0].org, length]] | sort_by(.[0])[] | @tsv",
                "title": "groupby an element with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1541793600,
        "creation_date": 1541780150,
        "last_edit_date": 1541793600,
        "question_id": 53229452,
        "body_markdown": "I have the following json: \r\n\r\n    {&quot;us&quot;:{&quot;$event&quot;:&quot;5bbf4a4f43d8950b5b0cc6d2&quot;},&quot;org&quot;:&quot;TΙ UIH&quot;,&quot;rc&quot;:{&quot;$event&quot;:&quot;13&quot;}}\r\n    {&quot;us&quot;:{&quot;$event&quot;:&quot;5bbf4a4f43d8950b5b0cc6d3&quot;},&quot;org&quot;:&quot;TΙ UIH&quot;,&quot;rc&quot;:{&quot;$event&quot;:&quot;13&quot;}}\r\n    {&quot;us&quot;:{&quot;$event&quot;:&quot;5bbf4a4f43d8950b5b0cc6d4&quot;},&quot;org&quot;:&quot;AB KIO&quot;,&quot;rc&quot;:{&quot;$event&quot;:&quot;13&quot;}}\r\n    {&quot;us&quot;:{&quot;$event&quot;:&quot;5bbf4a4f43d8950b5b0cc6d5&quot;},&quot;org&quot;:&quot;GH SVS&quot;,&quot;rc&quot;:{&quot;$event&quot;:&quot;17&quot;}}\r\n\r\nHow could i achieve the following output result? (tsv)\r\n\r\n    13 TΙ UIH 2\r\n    13 AB KIO 1\r\n    17 GH SVS 1\r\n\r\nso far from what i have searched,\r\n\r\n    jq -sr &#39;group_by(.org)|.[]|[.[0].org, length]|@tsv&#39;\r\n\r\nhow could i add one more group_by to achieve the desired result?\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/53229452/groupby-an-element-with-jq",
        "title": "groupby an element with jq"
    },
    {
        "tags": [
            "bash",
            "if-statement",
            "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": 3,
                "creation_date": 1541797914,
                "post_id": 53233221,
                "comment_id": 93353528,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1143565,
                    "reputation": 535973,
                    "user_id": 1126841,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa05233b2357f8d11c22ef4cfc7bb85c?s=256&d=identicon&r=PG",
                    "display_name": "chepner",
                    "link": "https://stackoverflow.com/users/1126841/chepner"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1541798366,
                "post_id": 53233221,
                "comment_id": 93353651,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1002989,
                    "reputation": 1385,
                    "user_id": 1017466,
                    "user_type": "registered",
                    "accept_rate": 50,
                    "profile_image": "https://www.gravatar.com/avatar/73d62289ed695b520ad2a3ae80c45277?s=256&d=identicon&r=PG",
                    "display_name": "bluethundr",
                    "link": "https://stackoverflow.com/users/1017466/bluethundr"
                },
                "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": 1541800089,
                "post_id": 53233221,
                "comment_id": 93354176,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1541801144,
                "last_edit_date": 1541801144,
                "creation_date": 1541800445,
                "answer_id": 53233717,
                "question_id": 53233221,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; I&#39;m using an &#39;if&#39; statement so that the right jq query gets used based on the aws policy that we&#39;re reading.\r\n\r\nBut jq is telling you that your jq query is not always valid.  So one option would be to make your jq query more robust, e.g. by using postfix `?` (e.g. `.Effect?`), or testing the type of the input, etc.",
                "title": "Suppress Errors in readarray Command in Bash"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1542137481,
                "creation_date": 1542137481,
                "answer_id": 53288254,
                "question_id": 53233221,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I didn&#39;t redirect jq&#39;s standard error, only the standard error of aws. Putting the `2&gt; /dev/null` to the end of the jq command works.",
                "title": "Suppress Errors in readarray Command in Bash"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1542137481,
        "creation_date": 1541797256,
        "last_edit_date": 1541797845,
        "question_id": 53233221,
        "body_markdown": "I&#39;m parsing AWS policy documents and I&#39;m trying to send the errors in this command to /dev/null so that the user doesn&#39;t see them.\r\n\r\nThis is my code:\r\n\r\n    readarray -t aws_policy_effects &lt; \\\r\n        &lt;( if aws iam get-policy-version --policy-arn &quot;$aws_policy_arn&quot; \\\r\n                  --version-id &quot;$aws_policy_version_id&quot;  --profile=&quot;$aws_key&quot; 2&gt; /dev/null | \\\r\n              jq -r &#39;.PolicyVersion.Document.Statement[].Effect&#39;\r\n           then\r\n               true\r\n           else\r\n               aws iam get-policy-version --policy-arn &quot;$aws_policy_arn&quot; \\\r\n                       --version-id &quot;$aws_policy_version_id&quot; --profile=&quot;$aws_key&quot; | \\\r\n                   jq -r &#39;.PolicyVersion.Document.Statement.Effect&#39;\r\n              fi)\r\n\r\nI&#39;m using an &#39;if&#39; statement so that the right jq query gets used based on the aws policy that we&#39;re reading.\r\n\r\nI will get this error:\r\n\r\n    jq: error (at &lt;stdin&gt;:22): Cannot index string with string &quot;Effect&quot;\r\n\r\nBecause this command always run as the first condition of the if (if there&#39;s no list the statement of the AWS policy document):\r\n\r\n    ++ jq -r &#39;.PolicyVersion.Document.Statement[].Effect&#39;\r\n    ++ aws iam get-policy-version --policy-arn arn:aws:iam::123456789101:policy/IP_RESTRICTION --version-id v11 --profile=company-lab\r\n\r\nWhy isn&#39;t the error being buried by sending it to /dev/null? How can I get the error to not print out to the screen using this if statement?",
        "link": "https://stackoverflow.com/questions/53233221/suppress-errors-in-readarray-command-in-bash",
        "title": "Suppress Errors in readarray Command in Bash"
    },
    {
        "tags": [
            "arrays",
            "json",
            "bash",
            "dictionary",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 4663062,
                    "reputation": 89888,
                    "user_id": 3776858,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Cagbk.jpg?s=256",
                    "display_name": "Cyrus",
                    "link": "https://stackoverflow.com/users/3776858/cyrus"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1541874755,
                "post_id": 53242090,
                "comment_id": 93369835,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9598625,
                    "reputation": 13,
                    "user_id": 7126964,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d7a8216c51c3d6777c337af6e324766c?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "wazairi",
                    "link": "https://stackoverflow.com/users/7126964/wazairi"
                },
                "reply_to_user": {
                    "account_id": 4663062,
                    "reputation": 89888,
                    "user_id": 3776858,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Cagbk.jpg?s=256",
                    "display_name": "Cyrus",
                    "link": "https://stackoverflow.com/users/3776858/cyrus"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1541875310,
                "post_id": 53242090,
                "comment_id": 93369987,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1542024316,
                "last_edit_date": 1542024316,
                "creation_date": 1541879745,
                "answer_id": 53242855,
                "question_id": 53242090,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here\r\n\r\n    jq -r --arg array &quot;$array&quot; \\\r\n      &#39;from_entries | .[($array | split(&quot; &quot;))[]]&#39; \\\r\n      dictionary.json\r\n\r\nOutput\r\n\r\n    value01\r\n    value02\r\n    value03\r\n\r\nSee `man jq` for further information.",
                "title": "Use jq to replace array values from dictionary"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1541882168,
                "creation_date": 1541882168,
                "answer_id": 53243173,
                "question_id": 53242090,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using `INDEX/2`, which constructs a dictionary:\r\n\r\n    echo &#39;key01 key02 key03&#39; |\r\n      jq -Rr --argfile dict dictionary.json &#39;\r\n        INDEX($dict[]; .key) as $d\r\n        | split(&quot; &quot;) | map( $d[.]|.value )\r\n        | join(&quot; &quot;)&#39;\r\n\r\nyields:\r\n\r\n    value01 value02 value03\r\n\r\nIf your jq does not have `INDEX`, then now would be an excellent time to upgrade to jq 1.6; alternatively, you can simply snarf its def by googling: `jq &quot;def INDEX&quot;`\r\n\r\n\r\n",
                "title": "Use jq to replace array values from dictionary"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1542024316,
        "creation_date": 1541874315,
        "last_edit_date": 1541875601,
        "question_id": 53242090,
        "body_markdown": "I have a dictionary which looks like:\r\n\r\n    cat dictionary.json\r\n    [\r\n      {\r\n        &quot;key&quot;: &quot;key01&quot;,\r\n        &quot;value&quot;: &quot;value01&quot;\r\n      },\r\n      {\r\n        &quot;key&quot;: &quot;key02&quot;,\r\n        &quot;value&quot;: &quot;value02&quot;\r\n      },\r\n      {\r\n        &quot;key&quot;: &quot;key03&quot;,\r\n        &quot;value&quot;: &quot;value03&quot;,\r\n        &quot;extraProperty&quot;: {\r\n          &quot;foo&quot;: &quot;bar&quot;\r\n        }\r\n      },\r\n      {\r\n        &quot;key&quot;: &quot;key04&quot;,\r\n        &quot;value&quot;: &quot;value04&quot;\r\n      }\r\n    ]\r\n\r\nThen, I have an array which is:\r\n\r\n    echo $array\r\n    key01 key02 key03\r\n\r\nExpected output:\r\n\r\n    value01 value02 value03\r\n\r\nI have some trouble to make jq using an array which is not json format.\r\nI tried various solutions that I found, but none of them worked.\r\nThis post https://stackoverflow.com/questions/34878915/jq-how-to-select-objects-based-on-a-whitelist-of-property-values seems to solve a similar problem but it doesn&#39;t work with my input:\r\n\r\n    echo $array | jq --argfile whitelist dictionary.json &#39;select(any(.key== $whitelist[]; .value))&#39;\r\n    parse error: Invalid numeric literal at line 1, column 6\r\n\r\nI also tried to use\r\n\r\n    jq -n --arg array $array --argfile whitelist dico.json &#39;select(any(.key== $whitelist[]; .valuee))&#39;\r\n    jq: error: key02/0 is not defined at &lt;top-level&gt;, line 1:\r\n    key02\r\n    jq: 1 compile error\r\n\r\nThanks!",
        "link": "https://stackoverflow.com/questions/53242090/use-jq-to-replace-array-values-from-dictionary",
        "title": "Use jq to replace array values from dictionary"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1541952545,
                "post_id": 53250318,
                "comment_id": 93385985,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2765901,
                    "reputation": 387,
                    "user_id": 2381631,
                    "user_type": "registered",
                    "accept_rate": 90,
                    "profile_image": "https://www.gravatar.com/avatar/f76586ce5207597e0f2dfc1666c5878b?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "dfernan",
                    "link": "https://stackoverflow.com/users/2381631/dfernan"
                },
                "reply_to_user": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1541954044,
                "post_id": 53250318,
                "comment_id": 93386425,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1541963423,
                "creation_date": 1541963423,
                "answer_id": 53252221,
                "question_id": 53250318,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This is probably not the best way to do what you want, but it does get the desired output and it has the conditional you asked about.\r\n\r\n    jq &#39;.[].b |= map(\r\n       [ .c,\r\n         (if .d == &quot;dd1&quot; then &quot;d1&quot; elif .d == &quot;dd2&quot; then &quot;d2&quot; else . end),\r\n         .f // empty\r\n       ] )&#39;\r\n",
                "title": "jq update list elements based on values"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1542013841,
                "creation_date": 1542013841,
                "answer_id": 53258933,
                "question_id": 53250318,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Without changing the value of the `d` key, you would use this jq filter:\r\n\r\n    jq &#39;.[].b[]|=(to_entries|map(.value))&#39; file\r\n\r\nThat updates the `b` array into all values of the inner objects.\r\n\r\nIf you want to update the `d`, you could use this filter:\r\n\r\n    jq &#39;.[].b[] |= (to_entries|\r\n                      map(\r\n                        if(.key==&quot;d&quot;) then \r\n                           .value|=sub(&quot;d+&quot;;&quot;d&quot;) \r\n                        else . \r\n                        end\r\n                        |.value)\r\n                    )&#39; file\r\n\r\nthat adds a check if the key is `d` the associated value is updated to remove the duplicated `d` character from the string. This requires jq to support for regex (to be able to use the `sub` function). ",
                "title": "jq update list elements based on values"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": -1,
        "last_activity_date": 1542013841,
        "creation_date": 1541950740,
        "last_edit_date": 1541953958,
        "question_id": 53250318,
        "body_markdown": "Is it possible to use `jq` to turn the following JSON data\r\n\r\n    [\r\n        {\r\n            &quot;a&quot;: null,\r\n            &quot;b&quot;: [\r\n                {\r\n                    &quot;c&quot;: &quot;cc&quot;,\r\n                    &quot;d&quot;: &quot;dd1&quot;\r\n                },\r\n                {\r\n                    &quot;c&quot;: &quot;cc&quot;,\r\n                    &quot;d&quot;: &quot;dd1&quot;,\r\n                    &quot;e&quot;: &quot;ee&quot;,\r\n                    &quot;f&quot;: &quot;ff&quot;\r\n                }\r\n            ]\r\n        },\r\n        {\r\n            &quot;b&quot;: [\r\n                {\r\n                    &quot;c&quot;: &quot;cc&quot;,\r\n                    &quot;d&quot;: &quot;dd2&quot;,\r\n                    &quot;e&quot;: &quot;ee&quot;,\r\n                    &quot;f&quot;: &quot;ff&quot;\r\n                }\r\n            ]\r\n        }\r\n    ]\r\ninto\r\n\r\n    [\r\n        {\r\n            &quot;a&quot;: null,\r\n            &quot;b&quot;: [\r\n                [\r\n                    &quot;cc&quot;, &quot;d1&quot;\r\n                ],\r\n                [\r\n                    &quot;cc&quot;, &quot;d1&quot;, &quot;ff&quot;\r\n                ]\r\n            ]\r\n        },\r\n        {\r\n            &quot;b&quot;: [\r\n                [\r\n                    &quot;cc&quot;, &quot;d2&quot;, &quot;ff&quot;\r\n                ]\r\n            ]\r\n        }\r\n    ]\r\n?\r\n\r\nNote that the purpose is to reduce the `b` list with certain elements of its items based on a condition. The condition assigns the string `d1` if the value of `d` is `dd1`, otherwise `d2` is assigned if `dd2` is present.\r\n\r\nThe following unsuccessful attempt demonstrates the idea:\r\n\r\n    $ jq -r &#39;.[].b[] = [.[].b[].c, ?, .[].b[].f?]&#39;",
        "link": "https://stackoverflow.com/questions/53250318/jq-update-list-elements-based-on-values",
        "title": "jq update list elements based on values"
    },
    {
        "tags": [
            "bash",
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1143565,
                    "reputation": 535973,
                    "user_id": 1126841,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa05233b2357f8d11c22ef4cfc7bb85c?s=256&d=identicon&r=PG",
                    "display_name": "chepner",
                    "link": "https://stackoverflow.com/users/1126841/chepner"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1541967642,
                "post_id": 53252798,
                "comment_id": 93390346,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1541978464,
                "post_id": 53252798,
                "comment_id": 93392978,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1541967726,
                "creation_date": 1541967726,
                "answer_id": 53252872,
                "question_id": 53252798,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The input of `jq` is a list, which doesn&#39;t have *any* keys, let alone one named `name`. You want\r\n\r\n    jq -r &#39;.[].name&#39;\r\n\r\ninstead.\r\n\r\nUnrelated, you don&#39;t need the variable `counter`. You can simply append to your array with `OB_I+=(&quot;$val&quot;)`.",
                "title": "why i get this error jq: error Cannot index array with string from json file?"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1541967726,
        "creation_date": 1541967299,
        "question_id": 53252798,
        "body_markdown": "i&#39;m trying to build script that takes specific attribute value and store it in the array , this is the following JSON file:   \r\n\r\n        [\r\n     {\r\n      &quot;id&quot;: 1, \r\n      &quot;name&quot;: &quot;myna&quot;, \r\n      &quot;description&quot;: &quot;Simple Question&quot;, \r\n      &quot;speaker&quot;: &quot;USER&quot;, \r\n     }, \r\n     {\r\n      &quot;all_Id&#39;s&quot;: [\r\n       &quot;11111&quot;\r\n      ], \r\n      &quot;user&quot;: &quot;me&quot;, \r\n     }, \r\n     {\r\n      &quot;id&quot;: 2, \r\n      &quot;name&quot;: &quot;mry&quot;, \r\n      &quot;description&quot;: &quot;Simple&quot;, \r\n      &quot;speaker&quot;: &quot;aaa&quot;,\r\n     }\r\n      ]  \r\nas you see object in json file don&#39;t have the same attributes so i&#39;m looking only on object has &quot;name &quot; attribute,the following script  reads the Json file and return the values of **attribute name only** ,but i build something wrond as theERROR always on the &quot;{&quot; of the last object in file I don&#39;t know why , what i am i doing wrong?  \r\nthe expected output is : [myna, mry]\r\n\r\n \r\n\r\n    #!/bin/bash\r\n    declare -a OB_I=()\r\n    declare counter1=0\r\n    jq -r &#39;.name&#39; file.json ; while read -r val ; do\r\n      if [[ ! $val ]]\r\n        then\r\n         OB_I[$counter]=$val ;\r\n         counter=$((counter+1));\r\n        fi\r\n      done;\r\n    $ printf &#39;%s\\n&#39; &quot;${OB_I[@]}&quot;",
        "link": "https://stackoverflow.com/questions/53252798/why-i-get-this-error-jq-error-cannot-index-array-with-string-from-json-file",
        "title": "why i get this error jq: error Cannot index array with string from json file?"
    },
    {
        "tags": [
            "json",
            "stream",
            "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": 1542006455,
                "post_id": 53256388,
                "comment_id": 93399094,
                "content_license": "CC BY-SA 4.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": 1542007897,
                "post_id": 53256388,
                "comment_id": 93399640,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 13802838,
                    "reputation": 166,
                    "user_id": 9962475,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/ac5a40aa730ce3bffd68177fc328148d?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "vikash",
                    "link": "https://stackoverflow.com/users/9962475/vikash"
                },
                "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": 1542014678,
                "post_id": 53256388,
                "comment_id": 93402693,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 13802838,
                    "reputation": 166,
                    "user_id": 9962475,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/ac5a40aa730ce3bffd68177fc328148d?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "vikash",
                    "link": "https://stackoverflow.com/users/9962475/vikash"
                },
                "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": 1542014887,
                "post_id": 53256388,
                "comment_id": 93402802,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1542011420,
                "creation_date": 1542011420,
                "answer_id": 53258322,
                "question_id": 53256388,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If the indexes of the arrays are fixed, you can use this filter:\r\n\r\n    jq &#39;.A[0].B.C[0].D.applicationNumberText.electronicText&#39; file\r\n\r\nand to extract all `electronicText` fields, you can use this:\r\n\r\n    jq &#39;.A[].B.C[].D.applicationNumberText.electronicText&#39; file\r\n\r\nIf you want to use the jq stream fashion (though it&#39;s not clear why), you can use this:\r\n\r\n    jq --stream &#39;select(.[0]|contains([&quot;electronicText&quot;]))|.[1]//empty&#39;\r\n\r\nThis will look in the key path for the string `electronicText` and if found, get its associated value. The `//empty` is to filter out the path array without value.\r\n\r\n\r\n\r\n    ",
                "title": "How to retrieve key and value from JSON file using stream option in jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1542012418,
                "creation_date": 1542012418,
                "answer_id": 53258538,
                "question_id": 53256388,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I belive what you are looking for is:\r\n\r\n    . as $inputs | {} | setpath($inputs[0]; $inputs[1]) | .A[]?.B.C[]?.D.applicationNumberText.electronicText // empty\r\n\r\nThis filter expects `--stream` as a flag (like your first example), generates a temporal obj with a section of the json, runs the filter based on your second example, and then hides the null results.  Note: [This based on a example in the cookbook](https://github.com/stedolan/jq/wiki/Cookbook#processing-huge-json-texts)\r\n\r\nLet me give you an overview of the things at play in case it is confusing:\r\n\r\n\r\n1. [The `--stream` flag will make your receive your data differently](https://stedolan.github.io/jq/manual/v1.5/#Streaming). You filter will now run multiple times with data in the form of `[&lt;path&gt;, &lt;leaf-value&gt;]` which is received as the parser traverses your json file, one node at a time.\r\n\r\n   I believe you refer to this when you mention using indexes, in this case meanining that you are inspecting the `path expression value` that the `--streaming flag` exposes instead of the _actual_ json data.\r\n   \r\n   Please compare the outputs of the following:\r\n   \r\n        jq &#39;.A[].B.C[].D.applicationNumberText.electronicText&#39; file.json # outputs 15570075 \r\n        jq --stream &#39;.A[].B.C[].D.applicationNumberText.electronicText&#39; file.json # multiple failures: cannot index array with string &quot;A&quot;\r\n\r\n\r\n2. [setpath()](https://stedolan.github.io/jq/manual/#setpath(PATHS;VALUE)) receives these path and leaf-value parameters puts it on top of its input object. e.g.\r\n\r\n        {} | setpath([&quot;a&quot;, 0, &quot;b&quot;], &quot;leaf-value&quot;) # returns {&quot;a&quot;:[{&quot;b&quot;:&quot;leaf-value&quot;}]}\r\n\r\n in our case we are generating the following stream of values as the parse visits each node:\r\n\r\n        {&quot;A&quot;:[{&quot;B&quot;:{&quot;C&quot;:[{&quot;D&quot;:{&quot;applicationNumberText&quot;:{&quot;value&quot;:&quot;15570075&quot;}}}]}}]}\r\n        {&quot;A&quot;:[{&quot;B&quot;:{&quot;C&quot;:[{&quot;D&quot;:{&quot;applicationNumberText&quot;:{&quot;electronicText&quot;:&quot;15570075&quot;}}}]}}]}\r\n        {&quot;A&quot;:[{&quot;B&quot;:{&quot;C&quot;:[{&quot;D&quot;:{&quot;applicationNumberText&quot;:{&quot;electronicText&quot;:null}}}]}}]}\r\n        {&quot;A&quot;:[{&quot;B&quot;:{&quot;C&quot;:[{&quot;D&quot;:{&quot;date&quot;:&quot;2018-10-01&quot;}}]}}]}\r\n        {&quot;A&quot;:[{&quot;B&quot;:{&quot;C&quot;:[{&quot;D&quot;:{&quot;app&quot;:&quot;Utility&quot;}}]}}]}\r\n\r\n3. Now that the data has a format similar to the json file we can run a more familiar filter.\r\n\r\n        .A[]?.B.C[]?.D.applicationNumberText.electronicText\r\n\r\n  keep in mind that there are no spaces between. We are also using the `?` operator on both generator `.A[]` and `.C[]` because we are not sure that those fields will be available as arrays at all times\r\n\r\n\r\nAs a final note, you might want to consider building a path array with [`path()`](https://stedolan.github.io/jq/manual/#path(path_expression)) and compare that against the path value that appears in `.[0]` when using the `--stream` jq flag",
                "title": "How to retrieve key and value from JSON file using stream option in jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1542092104,
                "last_edit_date": 1542092104,
                "creation_date": 1542033679,
                "answer_id": 53264498,
                "question_id": 53256388,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "In response to the original question:\r\n\r\n    jq --stream &#39;\r\n      select(length==2 and .[0][-1]==&quot;electronicText&quot;)|.[1]\r\n    &#39; input.json\r\n    &quot;15570075&quot;\r\n\r\nIf you want the `value` as well, then you might wish to consider the following filter:\r\n\r\n    select(length==2 and .[0][-2]==&quot;applicationNumberText&quot;)\r\n    | .[0][-1] as $last\r\n    | select($last == &quot;electronicText&quot; or $last == &quot;value&quot;)\r\n    | {($last): .[1]}\r\n\r\nwhich with your sample JSON produces:\r\n\r\n    {&quot;value&quot;:&quot;15570075&quot;}\r\n    {&quot;electronicText&quot;:&quot;15570075&quot;}\r\n\r\n## Combining key-value pairs into a single JSON object\r\n\r\nOne way to construct a &quot;dictionary&quot; is to use `inputs` in conjunction with the -n command-line option.  Simply wrap the above filter in the structure:\r\n\r\n     [inputs | ....] | add\r\n\r\nwhere here .... stands for the above filter; and invoke jq with *both* the -n and --stream options.\r\n\r\n\r\n",
                "title": "How to retrieve key and value from JSON file using stream option in jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1542063304,
                "last_edit_date": 1542063304,
                "creation_date": 1542057863,
                "answer_id": 53270327,
                "question_id": 53256388,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you know the name of the objects of interest, just search for object paths by name.\r\n\r\n    getpath(paths(objects) | select(.[-1] == &quot;applicationNumberText&quot;))\r\n\r\n---\r\n\r\nStreaming the input in should help with efficiency concerns. Just identify the paths you want to keep and truncate the paths of interest.\r\n\r\n    $ jq -n --stream --arg key &#39;applicationNumberText&#39; &#39;\r\n    fromstream(inputs | truncate_stream2((.[0] | index($key) // empty) + 1))\r\n    &#39; input.json\r\n\r\nThis just checks the path and looks for the `&quot;applicationNumberText&quot;` key then truncates the path to that value so it can be rebuilt from the stream.\r\n\r\nThis uses an inverted version of the [`truncate_stream/1`](https://stedolan.github.io/jq/manual/#truncate_stream(stream_expression)) function which swaps the usual inputs which I find using more intuitive.\r\n\r\n    def truncate_stream2($count): .[0] |= .[$count:];",
                "title": "How to retrieve key and value from JSON file using stream option in jq"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": 3,
        "last_activity_date": 1542092104,
        "creation_date": 1542000677,
        "last_edit_date": 1542062289,
        "question_id": 53256388,
        "body_markdown": "I have a json file with structure like this:\r\n\r\n  \r\n\r\n     {\r\n    \t&quot;A&quot;: [{\r\n    \t\t&quot;B&quot;: {\r\n    \t\t\t&quot;C&quot;: [{\r\n    \t\t\t\t&quot;D&quot;: {\r\n    \t\t\t\t\t&quot;applicationNumberText&quot;: {\r\n    \t\t\t\t\t\t&quot;value&quot;: &quot;15570075&quot;,\r\n    \t\t\t\t\t\t&quot;electronicText&quot;: &quot;15570075&quot;\r\n    \t\t\t\t\t},\r\n    \t\t\t\t\t&quot;date&quot;: &quot;2018-10-01&quot;,\r\n    \t\t\t\t\t&quot;app&quot;: &quot;Utility&quot;\r\n    \t\t\t\t}\r\n    \t\t\t}]\r\n    \t\t}\r\n    \t}]\r\n    }\r\n\r\nNow I want to retrieve `electronicText` value. One way is to use indexes like following\r\n \r\n\r\n    jq --stream &#39;select(.[0][1] == &quot;A&quot; and .[0][2] == &quot;B&quot; and .[0][3] == &quot;C&quot;) | .[1]&#39;\r\n\r\n\r\nbut the structure may differ in some cases so I want to refer by key values instead of indexes. I tried following method but it&#39;s not working\r\n\r\n    cat file.json | jq --stream &#39;select(.A|.[]. B. C|.[]. D.applicationNumberText)&#39;\r\n\r\nSo I want to retrieve `electronicText`  key  without using indexes. \r\n\r\n`Note`: I want to use `stream` option for large JSON file.\r\n\r\n \r\n\r\n",
        "link": "https://stackoverflow.com/questions/53256388/how-to-retrieve-key-and-value-from-json-file-using-stream-option-in-jq",
        "title": "How to retrieve key and value from JSON file using stream option in jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1542008675,
                "creation_date": 1542008675,
                "answer_id": 53257753,
                "question_id": 53257328,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use this jq filter:\r\n\r\n    jq &#39;.+{&quot;Instances&quot;:[{InstanceId}]}|del(.InstanceId)&#39; file\r\n\r\nThis adds the object `Instances` to the current JSON data using the value of `InstanceId`.  \r\nThen it deletes the `InstanceId` on the object root. ",
                "title": "json - how to get json to array"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1542009854,
        "creation_date": 1542006500,
        "last_edit_date": 1542009854,
        "question_id": 53257328,
        "body_markdown": "I ran an `aws` command and the results as below:\r\n\r\n    [root@webserver-02 test]# aws ec2 describe-volumes --volume-ids vol-0be41aaca50a1d4d2 --profile donald 2&gt; /dev/null|\r\n    jq -r &#39;.Volumes[]|{&quot;Tags&quot;:(.Tags | map({(.key//.Key): (.value//.Value)}) | add), VolumeId:.VolumeId,SnapshotId:.SnapshotId, Volumesize:.Size, CreateTime:.CreateTime, State:.State,&quot;Instances&quot;: [.Attachments[0].InstanceId] }&#39;\r\n\r\nand the results as below:\r\n\r\n    {\r\n      &quot;Tags&quot;: {\r\n        &quot;Name&quot;: &quot;4d2&quot;,\r\n        &quot;c&quot;: &quot;c&quot;,\r\n        &quot;a&quot;: &quot;a&quot;,\r\n        &quot;b&quot;: &quot;b&quot;\r\n      },\r\n      &quot;VolumeId&quot;: &quot;vol-0be41aaca50a1d4d2&quot;,\r\n      &quot;SnapshotId&quot;: &quot;snap-0be43cb27ae60c978&quot;,\r\n      &quot;Volumesize&quot;: 8,\r\n      &quot;CreateTime&quot;: &quot;2018-09-20T02:24:21.067Z&quot;,\r\n      &quot;State&quot;: &quot;in-use&quot;,\r\n      &quot;InstanceId&quot;: &quot;i-016c1d0448d6917f6&quot;\r\n    }\r\n\r\nOK. I want to display **InstanceId** json as follows:\r\n\r\n    {\r\n    \t&quot;Tags&quot;: {\r\n    \t\t&quot;Name&quot;: &quot;4d2&quot;,\r\n    \t\t&quot;c&quot;: &quot;c&quot;,\r\n    \t\t&quot;a&quot;: &quot;a&quot;,\r\n    \t\t&quot;b&quot;: &quot;b&quot;\r\n    \t},\r\n    \t&quot;VolumeId&quot;: &quot;vol-0be41aaca50a1d4d2&quot;,\r\n    \t&quot;SnapshotId&quot;: &quot;snap-0be43cb27ae60c978&quot;,\r\n    \t&quot;Volumesize&quot;: 8,\r\n    \t&quot;CreateTime&quot;: &quot;2018-09-20T02:24:21.067Z&quot;,\r\n    \t&quot;State&quot;: &quot;in-use&quot;,\r\n    \t&quot;Instances&quot;: [{\r\n    \t\t&quot;InstanceId&quot;: &quot;i-016c1d0448d6917f6&quot;\r\n    \t}]\r\n    }\r\n\r\nI am using `jq` in the `bash` shell.\r\n",
        "link": "https://stackoverflow.com/questions/53257328/json-how-to-get-json-to-array",
        "title": "json - how to get json to array"
    },
    {
        "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": 1,
                "creation_date": 1542034078,
                "post_id": 53261746,
                "comment_id": 93413274,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1542024881,
                "last_edit_date": 1542024881,
                "creation_date": 1542024549,
                "answer_id": 53261900,
                "question_id": 53261746,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you have the index number in `$0`, just let the shell insert it by using appropriate quotes:\r\n\r\n    echo $rulebase | jq &quot;.rulebase[$0].to&quot;\r\n(this being strange, having a number in `$0`, which normally is the program name).",
                "title": "jq: error: Cannot index array with string"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1542025179,
                "creation_date": 1542025179,
                "answer_id": 53262064,
                "question_id": 53261746,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You need to pass numbers as JSON args. Here\r\n\r\n    echo &quot;$rulebase&quot; | jq --argjson n &quot;$my_variable&quot; &#39;.rulebase[$n].to&#39;",
                "title": "jq: error: Cannot index array with string"
            },
            {
                "up_vote_count": 5,
                "is_accepted": false,
                "score": 5,
                "last_activity_date": 1542025560,
                "creation_date": 1542025560,
                "answer_id": 53262179,
                "question_id": 53261746,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you want to pass in a numeric value, use\r\n\r\n    —-argjson\r\n\r\ninstead of `—-arg`, which is for JSON string values.  \r\n\r\nIf your jq does not support —argjson, then now would be an excellent time to upgrade if possible; otherwise, you could use `tonumber`.",
                "title": "jq: error: Cannot index array with string"
            },
            {
                "up_vote_count": 8,
                "is_accepted": true,
                "score": 8,
                "last_activity_date": 1542025612,
                "creation_date": 1542025612,
                "answer_id": 53262192,
                "question_id": 53261746,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You need to convert the string that you give to your script to a _number_. \r\n\r\n    echo &quot;$rulebase&quot; | jq --arg n &quot;$1&quot; &#39;.rulebase[$n|tonumber].to&#39;\r\n\r\n",
                "title": "jq: error: Cannot index array with string"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": 5,
        "last_activity_date": 1542025612,
        "creation_date": 1542024029,
        "last_edit_date": 1542024161,
        "question_id": 53261746,
        "body_markdown": "I`m trying to do a bash script for a checkpoint management server api and I am experiencing some problems. \r\nI want to get the value in a json dictionary and for that I have to use variables. I am entering this command:\r\n\r\n    echo $rulebase | jq --arg n &quot;$0&quot; &#39;.rulebase[$n].to&#39;\r\n\r\nand I get the next error:\r\n\r\n&gt;jq: error: Cannot index array with string\r\n\r\nHowever, If i use : \r\n\r\n    echo $rulebase | jq  &#39;.rulebase[0].to&#39;\r\n\r\nI get the result that I need. I dont know how to use the variables when they are a number, can anyone help me?",
        "link": "https://stackoverflow.com/questions/53261746/jq-error-cannot-index-array-with-string",
        "title": "jq: error: Cannot index array with string"
    },
    {
        "tags": [
            "json",
            "key",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2550933,
                    "reputation": 13299,
                    "user_id": 2214695,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/dee2ef257601e05c5659f04de9cb7c67?s=256&d=identicon&r=PG",
                    "display_name": "oliv",
                    "link": "https://stackoverflow.com/users/2214695/oliv"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1542036404,
                "post_id": 53265018,
                "comment_id": 93414579,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 7757377,
                    "reputation": 829,
                    "user_id": 5871199,
                    "user_type": "registered",
                    "accept_rate": 44,
                    "profile_image": "https://www.gravatar.com/avatar/8c1f5fa3db4d1eb04c5ce93e33aef008?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "noob_coder",
                    "link": "https://stackoverflow.com/users/5871199/noob-coder"
                },
                "reply_to_user": {
                    "account_id": 2550933,
                    "reputation": 13299,
                    "user_id": 2214695,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/dee2ef257601e05c5659f04de9cb7c67?s=256&d=identicon&r=PG",
                    "display_name": "oliv",
                    "link": "https://stackoverflow.com/users/2214695/oliv"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1542036906,
                "post_id": 53265018,
                "comment_id": 93414843,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1542067314,
                "last_edit_date": 1542067314,
                "creation_date": 1542037202,
                "answer_id": 53265469,
                "question_id": 53265018,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use this `jq` filter:\r\n\r\n    jq -r &#39;.credentials|to_entries|.[]|.key&#39; file\r\n\r\nThe function `to_entries` allows to get both key and value that can then be filtered with `key` keyword.\r\n\r\n\r\n",
                "title": "get a field value from a jenkins JSON API"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1542067314,
        "creation_date": 1542035521,
        "last_edit_date": 1542048741,
        "question_id": 53265018,
        "body_markdown": "i have a jenkins JSON API that gives me an output stored in a variable `data`\r\n\r\n    {&quot;credentials&quot;:{&quot;xxxxxxxxxxxxxx111&quot;:{},&quot;xxxxxxxxxxxx2222&quot;:{}},&quot;description&quot;:&quot;All credentials that are not bound to a specific domain.&quot;,&quot;displayName&quot;:&quot;Global credentials&quot;,&quot;fullDisplayName&quot;:&quot;Credentials &#187; Global credentials&quot;,&quot;fullName&quot;:&quot;credential-store/_&quot;,&quot;global&quot;:true,&quot;urlName&quot;:&quot;_&quot;}\r\n\r\ni want only the values of the credentials field xxxxxxxxxxxxxx111 and xxxxxxxxxxxx2222\r\n\r\nthe things that i have tried so far is \r\n\r\n    echo $data | grep &quot;credentials&quot;\r\n    echo $data | jq -e &#39;.credentials[]|{}&#39; -c\r\n\r\nwhich does not work\r\ncan somebody please suggest something that works.\r\n",
        "link": "https://stackoverflow.com/questions/53265018/get-a-field-value-from-a-jenkins-json-api",
        "title": "get a field value from a jenkins JSON API"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1542098812,
                "post_id": 53276988,
                "comment_id": 93436059,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3228812,
                    "reputation": 43,
                    "user_id": 2724530,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b9c1fbfefd8be219894e2eea166112f1?s=256&d=identicon&r=PG",
                    "display_name": "tyke",
                    "link": "https://stackoverflow.com/users/2724530/tyke"
                },
                "reply_to_user": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1542105035,
                "post_id": 53276988,
                "comment_id": 93439765,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 59238,
                    "reputation": 10185,
                    "user_id": 177275,
                    "user_type": "registered",
                    "accept_rate": 64,
                    "profile_image": "https://i.sstatic.net/jBMYN.jpg?s=256",
                    "display_name": "Yuri Astrakhan",
                    "link": "https://stackoverflow.com/users/177275/yuri-astrakhan"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1587862617,
                "post_id": 53276988,
                "comment_id": 108676316,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1542119845,
                "creation_date": 1542119845,
                "answer_id": 53283380,
                "question_id": 53276988,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The first argument of `INDEX/2` should be a stream of the items to be indexed; here, `.[]` is exactly what we want:\r\n\r\n    INDEX(.[]; .a + &quot;:&quot; + .b) ",
                "title": "INDEX builtin with input"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1587863466,
                "creation_date": 1587863466,
                "answer_id": 61434621,
                "question_id": 53276988,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "For jq version 1.5 or older, `INDEX` does not seem to be working (does not exist?), but this works instead:\r\n\r\n```\r\njq &#39;map({key: (.a + &quot;:&quot; + .b), value: .}) | from_entries&#39; data.json\r\n```",
                "title": "INDEX builtin with input"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1587863466,
        "creation_date": 1542098657,
        "last_edit_date": 1542104202,
        "question_id": 53276988,
        "body_markdown": "I&#39;m trying to build an INDEX from a json file which contains a list of flat objects.\r\n\r\nIf I use the construct\r\n\r\n    jq &#39;INDEX(.a + &quot;:&quot; + .b)&#39; &lt; data.json \r\n\r\nI get what i want. But if I use \r\n\r\n    jq &#39;INDEX(input; .a + &quot;:&quot; + .b) data.json\r\n\r\nthen I get the error\r\n\r\n    jq: error (at data.json:&lt;last-line&gt;): break\r\n\r\nThe reason I need to use the second form is that I will then need to JOIN another `input` to the index of the first, and I don&#39;t see how to do that from STDIN.\r\n\r\nAny ideas how I can get around this?\r\n\r\n(Currently running jq-1.6 on MacOS 10.13.6)\r\n\r\nAdding input (data.json): \r\n\r\n    [\r\n    \t{\r\n    \t\t&quot;a&quot;: &quot;a1&quot;,\r\n    \t\t&quot;b&quot;: &quot;b1&quot;,\r\n    \t\t&quot;c&quot;: &quot;c1&quot;,\r\n    \t\t&quot;d&quot;: &quot;d1&quot;\r\n    \t},\r\n    \t{\r\n    \t\t&quot;a&quot;: &quot;a2&quot;,\r\n    \t\t&quot;b&quot;: &quot;b2&quot;,\r\n    \t\t&quot;c&quot;: &quot;c2&quot;,\r\n    \t\t&quot;d&quot;: &quot;d2&quot;\r\n    \t},\r\n    \t{\r\n    \t\t&quot;a&quot;: &quot;a3&quot;,\r\n    \t\t&quot;b&quot;: &quot;b3&quot;,\r\n    \t\t&quot;c&quot;: &quot;c3&quot;,\r\n    \t\t&quot;d&quot;: &quot;d3&quot;\r\n    \t}\r\n    ]\r\n\r\nAnd expected output\r\n\r\n    {\r\n      &quot;a1:b1&quot;: {\r\n        &quot;a&quot;: &quot;a1&quot;,\r\n        &quot;b&quot;: &quot;b1&quot;,\r\n        &quot;c&quot;: &quot;c1&quot;,\r\n        &quot;d&quot;: &quot;d1&quot;\r\n      },\r\n      &quot;a2:b2&quot;: {\r\n        &quot;a&quot;: &quot;a2&quot;,\r\n        &quot;b&quot;: &quot;b2&quot;,\r\n        &quot;c&quot;: &quot;c2&quot;,\r\n        &quot;d&quot;: &quot;d2&quot;\r\n      },\r\n      &quot;a3:b3&quot;: {\r\n        &quot;a&quot;: &quot;a3&quot;,\r\n        &quot;b&quot;: &quot;b3&quot;,\r\n        &quot;c&quot;: &quot;c3&quot;,\r\n        &quot;d&quot;: &quot;d3&quot;\r\n      }\r\n    }",
        "link": "https://stackoverflow.com/questions/53276988/index-builtin-with-input",
        "title": "INDEX builtin with input"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 15,
                "is_accepted": true,
                "score": 15,
                "last_activity_date": 1731261910,
                "last_edit_date": 1731261910,
                "creation_date": 1542109269,
                "answer_id": 53280264,
                "question_id": 53280090,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Carefully check your script against the one you posted in the question. If they match then the answer is very easy.\r\n\r\nThere is no `&quot;total&quot; : 126` in the string you pass to `jq` because you pass it the output of `echo rulebase_list` that is `rulebase_list`.\r\n\r\nWhat you probably wanted is to send to `jq` the content of the `rulebase_list` file and the tool for this is `cat`:\r\n\r\n    n_rules=$(cat rulebase_list | jq &#39;.total&#39;)\r\n\r\nAlternatively (and faster) is to redirect the input of `jq` from the file:\r\n\r\n    n_rules=$(jq &#39;.total&#39; &lt; rulebase_list)\r\n\r\nOr to specify the input file name as the last argument in the command line of `jq`:\r\n\r\n    n_rules=$(jq &#39;.total&#39; rulebase_list)\r\n\r\nRead more about `jq`: https://jqlang.github.io/jq/manual/",
                "title": "parse error: Invalid numeric literal at line 2, column 0"
            },
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1628324607,
                "creation_date": 1628324607,
                "answer_id": 68690621,
                "question_id": 53280090,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You forgot to include `$` in your script. Add it and it&#39;ll be fixed.\r\n```\r\nn_rules=$(echo $rulebase_list | jq &#39;.total&#39;)\r\n```",
                "title": "parse error: Invalid numeric literal at line 2, column 0"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 14,
        "last_activity_date": 1731261910,
        "creation_date": 1542108649,
        "last_edit_date": 1562151704,
        "question_id": 53280090,
        "body_markdown": "i am trying to read for a big json data structure and I get the message: \r\n\r\n&gt; parse error: Invalid numeric literal at line 2, column 0\r\n\r\nThe command that I&#39;m using is the next one: \r\n\r\n    n_rules=$(echo rulebase_list | jq &#39;.total&#39;)\r\n\r\nand the file has in the first hierarchy level a variable which is \r\n\r\n    &quot;total&quot; : 126\r\n\r\nDo you know why im experiencing problems with that?\r\nI suppose that the problem is that 126 is a numeric value but what can I do?",
        "link": "https://stackoverflow.com/questions/53280090/parse-error-invalid-numeric-literal-at-line-2-column-0",
        "title": "parse error: Invalid numeric literal at line 2, column 0"
    },
    {
        "tags": [
            "json",
            "select",
            "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": 1542111725,
                "post_id": 53280221,
                "comment_id": 93443451,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2550933,
                    "reputation": 13299,
                    "user_id": 2214695,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/dee2ef257601e05c5659f04de9cb7c67?s=256&d=identicon&r=PG",
                    "display_name": "oliv",
                    "link": "https://stackoverflow.com/users/2214695/oliv"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1542114356,
                "post_id": 53280221,
                "comment_id": 93444920,
                "content_license": "CC BY-SA 4.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"
                },
                "reply_to_user": {
                    "account_id": 2550933,
                    "reputation": 13299,
                    "user_id": 2214695,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/dee2ef257601e05c5659f04de9cb7c67?s=256&d=identicon&r=PG",
                    "display_name": "oliv",
                    "link": "https://stackoverflow.com/users/2214695/oliv"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1542115296,
                "post_id": 53280221,
                "comment_id": 93445432,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5434973,
                    "reputation": 206,
                    "user_id": 4324724,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/6fadd639902a9a31373df7645eea807d?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "James Liu",
                    "link": "https://stackoverflow.com/users/4324724/james-liu"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1542119383,
                "post_id": 53280221,
                "comment_id": 93448044,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1542114858,
                "creation_date": 1542114858,
                "answer_id": 53281810,
                "question_id": 53280221,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can try these filters: \r\n\r\nFor the first output:\r\n\r\n    jq &#39;[\r\n          tostream|\r\n          select(.[1]==&quot;static&quot; and (.[0]|.[-1] == &quot;dynamic&quot;))|\r\n          {(.[0]|.[0]):{(.[0]|.[2]):{(.[0]|.[3]):.[1]}}}\r\n        ]|add&#39; file\r\n\r\nAnd the 2nd one:\r\n\r\n    jq &#39;[\r\n          tostream|\r\n          select(.[1]==&quot;static&quot; and (.[0]|.[-1] == &quot;dynamic&quot;))|\r\n          {(.[0]|.[0]):[(.[0]|.[2])]}\r\n        ]|add&#39; file\r\n\r\nBoth filter relies on `tostream` function (requires at least jq version 1.5) which give the content of the input into array in a form `[path[],value]`.\r\n\r\nThe `select` function get all paths ending with `dynamic` and `static`.\r\n\r\nThe 3rd part of the filter forge the new object according to the expected output by looking up the array path.\r\n",
                "title": "how to i select multiple keys using JQ"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1542120582,
                "creation_date": 1542120582,
                "answer_id": 53283620,
                "question_id": 53280221,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To obtain the output in the first form:\r\n\r\n\r\n    map_values( .mappings\r\n                | with_entries( select( .value.dynamic == &quot;static&quot; )) )\r\n\r\nWe use `map_values` as the input is a JSON object, and we want to retain its keys; we use `with_entries` as that makes it easy to select the keys of interest.\r\n\r\nThe above filter could easily be tweaked to yield the output in the second form, but that form is a bit weird and perhaps not-to-be-encouraged, so I won&#39;t.",
                "title": "how to i select multiple keys using JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1542131533,
        "creation_date": 1542109088,
        "last_edit_date": 1542131533,
        "question_id": 53280221,
        "body_markdown": "How can `jq` extract both the `index` key and `doctype` key based on the `dynamic` attribute?:\r\n\r\n    {\r\n    \t&quot;index1&quot;: {\r\n    \t\t&quot;mappings&quot;: {\r\n    \t\t\t&quot;doctype1&quot;: {\r\n    \t\t\t\t&quot;dynamic&quot;: &quot;true&quot;\r\n    \t\t\t},\r\n    \t\t\t&quot;doctype2&quot;: {\r\n    \t\t\t\t&quot;dynamic&quot;: &quot;static&quot;\r\n    \t\t\t}\r\n    \t\t}\r\n    \t},\r\n    \t&quot;index2&quot;: {\r\n    \t\t&quot;mappings&quot;: {\r\n    \t\t\t&quot;doctype3&quot;: {\r\n    \t\t\t\t&quot;dynamic&quot;: &quot;static&quot;\r\n    \t\t\t},\r\n    \t\t\t&quot;doctype4&quot;: {\r\n    \t\t\t\t&quot;dynamic&quot;: &quot;true&quot;\r\n    \t\t\t}\r\n    \t\t}\r\n    \t}\r\n    }\r\n\r\nto give:\r\n\r\n    {\r\n        &quot;index1&quot;: {\r\n            &quot;doctype2&quot;: { &quot;dynamic&quot;: &quot;static&quot; }\r\n        },\r\n        {\r\n        &quot;index2&quot;: {\r\n            &quot;doctype3&quot;: { &quot;dynamic&quot;: &quot;static&quot; }\r\n        }\r\n    }\r\n\r\nor\r\n\r\n    {\r\n        &quot;index1&quot;: &quot;[&#39;doctype2&#39;]&quot;,\r\n        &quot;index2&quot;: &quot;[&#39;doctype3&#39;]&quot;\r\n    }\r\n\r\nI have tried:\r\n\r\n    jq &#39;. | keys as $i | .[].mappings | keys as $d | $i $d&#39;\r\n\r\nbut it&#39;s not even close",
        "link": "https://stackoverflow.com/questions/53280221/how-to-i-select-multiple-keys-using-jq",
        "title": "how to i select multiple keys using JQ"
    },
    {
        "tags": [
            "json",
            "jq",
            "flatten"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1542130298,
                "creation_date": 1542130298,
                "answer_id": 53286574,
                "question_id": 53286133,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can try this filter:\r\n\r\n    jq &#39;map({a,&quot;b&quot;:.b[]|[.]})&#39; file\r\n\r\nIt updates the content of `b` with each value of `c` separately.\r\n",
                "title": "How do I transform this JSON data using JQ to extract each nested array element to the top level in turn?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1542131275,
                "creation_date": 1542131275,
                "answer_id": 53286806,
                "question_id": 53286133,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a straightforward solution that makes no mention of any keys besides &quot;b&quot;:\r\n\r\n    map(. + (.b[] | {b: [.]}))\r\n\r\n",
                "title": "How do I transform this JSON data using JQ to extract each nested array element to the top level in turn?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1542131584,
        "creation_date": 1542128671,
        "last_edit_date": 1542131584,
        "question_id": 53286133,
        "body_markdown": "Given input of the form \r\n\r\n    [\r\n        {&quot;a&quot;: 1, &quot;b&quot;: [{&quot;c&quot;: 1}, {&quot;c&quot;: 2}]}, \r\n        {&quot;a&quot;: 2, &quot;b&quot;: [{&quot;c&quot;: 4}, {&quot;c&quot;: 5}]}\r\n    ]\r\n\r\nI&#39;m trying to transform to look like:\r\n\r\n\r\n    [\r\n        {&quot;a&quot;: 1, &quot;b&quot;: [{&quot;c&quot;: 1}],\r\n        {&quot;a&quot;: 1, &quot;b&quot;: [{&quot;c&quot;: 2}],\r\n        {&quot;a&quot;: 2, &quot;b&quot;: [{&quot;c&quot;: 3}],\r\n        {&quot;a&quot;: 2, &quot;b&quot;: [{&quot;c&quot;: 4}]\r\n    ]\r\n\r\nI have `[map(.b) ] | flatten`, however any further operation using the parent context does not seems to be possible. I&#39;m really stuck and would appreciate any help.\r\n\r\nThanks",
        "link": "https://stackoverflow.com/questions/53286133/how-do-i-transform-this-json-data-using-jq-to-extract-each-nested-array-element",
        "title": "How do I transform this JSON data using JQ to extract each nested array element to the top level in turn?"
    },
    {
        "tags": [
            "json",
            "web-services",
            "jq",
            "json-query"
        ],
        "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": 1542152450,
                "post_id": 53291061,
                "comment_id": 93463817,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 166270,
                    "reputation": 135171,
                    "user_id": 390278,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/84715fec547362389d02f5be0ed12814?s=256&d=identicon&r=PG",
                    "display_name": "Jeff Mercado",
                    "link": "https://stackoverflow.com/users/390278/jeff-mercado"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1542155823,
                "post_id": 53291061,
                "comment_id": 93464630,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 106565,
                    "reputation": 19096,
                    "user_id": 283837,
                    "user_type": "registered",
                    "accept_rate": 70,
                    "profile_image": "https://www.gravatar.com/avatar/b6a1613d264fbc700b317490b59494e0?s=256&d=identicon&r=PG",
                    "display_name": "Simeon Leyzerzon",
                    "link": "https://stackoverflow.com/users/283837/simeon-leyzerzon"
                },
                "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": 1542156993,
                "post_id": 53291061,
                "comment_id": 93464884,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 166270,
                    "reputation": 135171,
                    "user_id": 390278,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/84715fec547362389d02f5be0ed12814?s=256&d=identicon&r=PG",
                    "display_name": "Jeff Mercado",
                    "link": "https://stackoverflow.com/users/390278/jeff-mercado"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1542160871,
                "post_id": 53291061,
                "comment_id": 93465709,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 106565,
                    "reputation": 19096,
                    "user_id": 283837,
                    "user_type": "registered",
                    "accept_rate": 70,
                    "profile_image": "https://www.gravatar.com/avatar/b6a1613d264fbc700b317490b59494e0?s=256&d=identicon&r=PG",
                    "display_name": "Simeon Leyzerzon",
                    "link": "https://stackoverflow.com/users/283837/simeon-leyzerzon"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1542161019,
                "post_id": 53291061,
                "comment_id": 93465736,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 106565,
                    "reputation": 19096,
                    "user_id": 283837,
                    "user_type": "registered",
                    "accept_rate": 70,
                    "profile_image": "https://www.gravatar.com/avatar/b6a1613d264fbc700b317490b59494e0?s=256&d=identicon&r=PG",
                    "display_name": "Simeon Leyzerzon",
                    "link": "https://stackoverflow.com/users/283837/simeon-leyzerzon"
                },
                "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": 1542161771,
                "post_id": 53291061,
                "comment_id": 93465915,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2550933,
                    "reputation": 13299,
                    "user_id": 2214695,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/dee2ef257601e05c5659f04de9cb7c67?s=256&d=identicon&r=PG",
                    "display_name": "oliv",
                    "link": "https://stackoverflow.com/users/2214695/oliv"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1542181084,
                "post_id": 53291061,
                "comment_id": 93471213,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1542163432,
                "creation_date": 1542163432,
                "answer_id": 53292441,
                "question_id": 53291061,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "0. Using jq versions 1.6, 1.5, and 1.4, I&#39;ve tested your jq program using the JSON version of the data, and all is well (on a Mac).\r\n\r\n1. Please read http://stackoverflow.com/help/mcve - if you follow those guidelines, it should make debugging, communication, and/or life in general much easier for all concerned.\r\n\r\n2. I&#39;d suggest putting your jq program into a file and using the -f command-line option, at least while you&#39;re debugging this. ",
                "title": "Filtering JSON curl results with jq selectors"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1542163432,
        "creation_date": 1542152160,
        "last_edit_date": 1542161697,
        "question_id": 53291061,
        "body_markdown": "I have the following multi-record JSON structure coming as a response from a web service:\r\n\r\n  \r\n\r\n      [\r\n        {\r\n        &quot;model&quot;: &quot;analytics.request&quot;,\r\n        &quot;pk&quot;: 89,\r\n        &quot;fields&quot;: {\r\n            &quot;intent&quot;: &quot;GetUserAccountInformation&quot;,\r\n            &quot;sub_intent&quot;: &quot;&quot;,\r\n            &quot;request_text&quot;: &quot;what is my balance&quot;,\r\n            &quot;response_text&quot;: &quot;You have $111,111.11 and owe $111,111. Shall I break that down?&quot;,\r\n            &quot;session_id&quot;: &quot;1v69yiptamgse1niap51zr2o9x154169081480766b2d6b7-d3ce-4166-9292-c4669a3dfc14&quot;,\r\n            &quot;user_id&quot;: &quot;amzn1.ask.account.AHMFB2H7ZXMSCB5TLPYWCPBJGWGHFYQZ6OPPMEPQ7CT2LZXNPAFJMJELXXCCTEZ2JUE5PXRSBJHJTO3AVXT3C63AOEZLIEP3D3HIFBT5M23G4ORENFRT54AAK7I4X2HCORXJAB2UGQAHPE2TC75F2GWWZWSPO2CWEAZJJN7LJYFWEYHEJDLNQ6FSUD5LQWKBUC347K3IF32IV3I&quot;,\r\n            &quot;device_id&quot;: &quot;amzn1.ask.account.AHMFB2H7ZXMSCB5TLPYWCPBJGWGHFYQZ&quot;,\r\n            &quot;device_type&quot;: &quot;alexa&quot;,\r\n            &quot;device_model&quot;: &quot;NA&quot;,\r\n            &quot;device_os&quot;: &quot;alexa&quot;,\r\n            &quot;elapsed_time&quot;: 23286,\r\n            &quot;region&quot;: &quot;NA&quot;,\r\n            &quot;latitude&quot;: 0,\r\n            &quot;longitude&quot;: 0,\r\n            &quot;date&quot;: &quot;2018-11-08T15:31:48.757+0000&quot;,\r\n            &quot;ext_session_id&quot;: &quot;&quot;,\r\n            &quot;ext_user_id&quot;: &quot;&quot;,\r\n            &quot;score&quot;: 1,\r\n            &quot;platform_type&quot;: &quot;alexa&quot;,\r\n            &quot;platform_user_id&quot;: &quot;amzn1.ask.account.AHMFB2H7ZXMSCB5TLPYWCPBJGWGHFYQZ6OPPMEPQ7CT2LZXNPAFJMJELXXCCTEZ2JUE5PXRSBJHJTO3AVXT3C63AOEZLIEP3D3HIFBT5M23G4ORENFRT54AAK7I4X2HCORXJAB2UGQAHPE2TC75F2GWWZWSPO2CWEAZJJN7LJYFWEYHEJDLNQ6FSUD5LQWKBUC347K3IF32IV3I&quot;,\r\n            &quot;platform_conversation_id&quot;: &quot;amzn1.echo-api.session.9122211c-7fa8-43ae-b7e3-e56ebbdacc01&quot;,\r\n            &quot;registered&quot;: false,\r\n            &quot;segment_names&quot;: [\r\n                &quot;Seg0715080610AM&quot;,\r\n                &quot;Seg0715071857AM&quot;,\r\n                &quot;Seg0715070437AM&quot;,\r\n                &quot;Seg0715063307AM&quot;,\r\n                &quot;Seg0715054215AM&quot;,\r\n                &quot;Seg0715054027AM&quot;,\r\n                &quot;Seg0715053845AM&quot;,\r\n                &quot;Seg0715053646AM&quot;,\r\n                &quot;Seg0715053156AM&quot;,\r\n                &quot;Seg0715052407AM&quot;,\r\n                &quot;Seg0715045748AM&quot;,\r\n                &quot;Seg0714145246PM&quot;,\r\n                &quot;Seg0714135150PM&quot;,\r\n                &quot;Seg0714134041PM&quot;,\r\n                &quot;Seg0714012505AM&quot;,\r\n                &quot;Seg0714004152AM&quot;,\r\n                &quot;Seg0714002843AM&quot;,\r\n                &quot;Seg0713235444PM&quot;,\r\n                &quot;Seg0713230241PM&quot;,\r\n                &quot;Seg0713230030PM&quot;,\r\n                &quot;Seg0713225825PM&quot;,\r\n                &quot;Seg0713225548PM&quot;,\r\n                &quot;Seg0713225028PM&quot;,\r\n                &quot;Seg0713224159PM&quot;,\r\n                &quot;Seg0713220356PM&quot;,\r\n                &quot;Seg0711155346PM&quot;,\r\n                &quot;Seg0711154018PM&quot;,\r\n                &quot;Seg0711153432PM&quot;,\r\n                &quot;Seg0711140748PM&quot;,\r\n                &quot;Seg0711135636PM&quot;,\r\n                &quot;Seg0711131412PM&quot;,\r\n                &quot;Seg0711130857PM&quot;,\r\n                &quot;Seg0711130157PM&quot;,\r\n                &quot;Seg0711125338PM&quot;,\r\n                &quot;Seg0711113158AM&quot;,\r\n                &quot;customer&quot;,\r\n                &quot;cmstest7&quot;,\r\n                &quot;cmstest5&quot;,\r\n                &quot;cmstest3&quot;,\r\n                &quot;cmstest2&quot;,\r\n                &quot;gffyrth&quot;,\r\n                &quot;1testQR&quot;,\r\n                &quot;1testgallery&quot;,\r\n                &quot;121212&quot;\r\n            ]\r\n        }\r\n    },\r\n    {\r\n        &quot;model&quot;: &quot;analytics.request&quot;,\r\n        &quot;pk&quot;: 90,\r\n        &quot;fields&quot;: {\r\n            &quot;intent&quot;: &quot;GetUserAccountInformation&quot;,\r\n            &quot;sub_intent&quot;: &quot;&quot;,\r\n            &quot;request_text&quot;: &quot;what is my balance&quot;,\r\n            &quot;response_text&quot;: &quot;You have $111,111.11 and owe $111,111. Shall I break that down?&quot;,\r\n            &quot;session_id&quot;: &quot;1v69yiptamgse1niap51zr2o9x154169081480766b2d6b7-d3ce-4166-9292-c4669a3dfc14&quot;,\r\n            &quot;user_id&quot;: &quot;amzn1.ask.account.AHMFB2H7ZXMSCB5TLPYWCPBJGWGHFYQZ6OPPMEPQ7CT2LZXNPAFJMJELXXCCTEZ2JUE5PXRSBJHJTO3AVXT3C63AOEZLIEP3D3HIFBT5M23G4ORENFRT54AAK7I4X2HCORXJAB2UGQAHPE2TC75F2GWWZWSPO2CWEAZJJN7LJYFWEYHEJDLNQ6FSUD5LQWKBUC347K3IF32IV3I&quot;,\r\n            &quot;device_id&quot;: &quot;amzn1.ask.account.AHMFB2H7ZXMSCB5TLPYWCPBJGWGHFYQZ&quot;,\r\n            &quot;device_type&quot;: &quot;alexa&quot;,\r\n            &quot;device_model&quot;: &quot;NA&quot;,\r\n            &quot;device_os&quot;: &quot;alexa&quot;,\r\n            &quot;elapsed_time&quot;: 2013,\r\n            &quot;region&quot;: &quot;NA&quot;,\r\n            &quot;latitude&quot;: 0,\r\n            &quot;longitude&quot;: 0,\r\n            &quot;date&quot;: &quot;2018-11-08T15:32:40.090+0000&quot;,\r\n            &quot;ext_session_id&quot;: &quot;&quot;,\r\n            &quot;ext_user_id&quot;: &quot;&quot;,\r\n            &quot;score&quot;: 1,\r\n            &quot;platform_type&quot;: &quot;alexa&quot;,\r\n            &quot;platform_user_id&quot;: &quot;amzn1.ask.account.AHMFB2H7ZXMSCB5TLPYWCPBJGWGHFYQZ6OPPMEPQ7CT2LZXNPAFJMJELXXCCTEZ2JUE5PXRSBJHJTO3AVXT3C63AOEZLIEP3D3HIFBT5M23G4ORENFRT54AAK7I4X2HCORXJAB2UGQAHPE2TC75F2GWWZWSPO2CWEAZJJN7LJYFWEYHEJDLNQ6FSUD5LQWKBUC347K3IF32IV3I&quot;,\r\n            &quot;platform_conversation_id&quot;: &quot;amzn1.echo-api.session.8586bff8-21a5-4336-9c9f-1c261362b89d&quot;,\r\n            &quot;registered&quot;: false,\r\n            &quot;segment_names&quot;: [\r\n                &quot;Test_Segment0731174425PM&quot;,\r\n                &quot;Test_Segment0731172344PM&quot;,\r\n                &quot;Test_Segment0731165438PM&quot;,\r\n                &quot;Test_Segment0731164321PM&quot;,\r\n                &quot;Test_Segment0731163349PM&quot;,\r\n                &quot;Test_Segment0731161939PM&quot;,\r\n                &quot;Test_Segment0731160424PM&quot;,\r\n                &quot;Test_Segment0730160925PM&quot;,\r\n                &quot;Test_Segment0730154627PM&quot;,\r\n                &quot;Test_Segment0730152806PM&quot;,\r\n                &quot;Test_Segment0730152328PM&quot;,\r\n                &quot;Test_Segment0730150203PM&quot;,\r\n                &quot;Test_Segment0730141720PM&quot;,\r\n                &quot;Test_Segment0730141304PM&quot;,\r\n                &quot;testseg&quot;,\r\n                &quot;Tester&quot;,\r\n                &quot;Test0730162816PM&quot;,\r\n                &quot;Test0730162304PM&quot;,\r\n                &quot;Test0730161031PM&quot;,\r\n                &quot;Test0730160632PM&quot;,\r\n                &quot;Test0730160502PM&quot;,\r\n                &quot;Seg0730154521PM&quot;,\r\n                &quot;Seg0730154322PM&quot;,\r\n                &quot;Seg0730153811PM&quot;,\r\n                &quot;Seg0730153303PM&quot;,\r\n                &quot;Seg0716231700PM&quot;,\r\n                &quot;Seg0716230741PM&quot;,\r\n                &quot;Seg0715080610AM&quot;,\r\n                &quot;Seg0715071857AM&quot;,\r\n                &quot;Seg0715070437AM&quot;,\r\n                &quot;Seg0715063307AM&quot;,\r\n                &quot;Seg0715054215AM&quot;,\r\n                &quot;Seg0715054027AM&quot;,\r\n                &quot;Seg0715053845AM&quot;,\r\n                &quot;Seg0715053646AM&quot;,\r\n                &quot;Seg0715053156AM&quot;,\r\n                &quot;Seg0715052407AM&quot;,\r\n                &quot;Seg0715045748AM&quot;,\r\n                &quot;Seg0714145246PM&quot;,\r\n                &quot;Seg0714135150PM&quot;,\r\n                &quot;Seg0714134041PM&quot;,\r\n                &quot;Seg0714012505AM&quot;,\r\n                &quot;Seg0714004152AM&quot;,\r\n                &quot;Seg0714002843AM&quot;,\r\n                &quot;Seg0713235444PM&quot;,\r\n                &quot;Seg0713230241PM&quot;,\r\n                &quot;Seg0713230030PM&quot;,\r\n                &quot;Seg0713225825PM&quot;,\r\n                &quot;Seg0713225548PM&quot;,\r\n                &quot;Seg0713225028PM&quot;,\r\n                &quot;Seg0713224159PM&quot;,\r\n                &quot;Seg0713220356PM&quot;,\r\n                &quot;Seg0711155346PM&quot;,\r\n                &quot;Seg0711154018PM&quot;,\r\n                &quot;Seg0711153432PM&quot;,\r\n                &quot;Seg0711140748PM&quot;,\r\n                &quot;Seg0711135636PM&quot;,\r\n                &quot;Seg0711131412PM&quot;,\r\n                &quot;Seg0711130857PM&quot;,\r\n                &quot;Seg0711130157PM&quot;,\r\n                &quot;Seg0711125338PM&quot;,\r\n                &quot;Seg0711113158AM&quot;,\r\n                &quot;customer&quot;,\r\n                &quot;cmstest7&quot;,\r\n                &quot;cmstest5&quot;,\r\n                &quot;cmstest3&quot;,\r\n                &quot;cmstest2&quot;,\r\n                &quot;gffyrth&quot;,\r\n                &quot;1testQR&quot;,\r\n                &quot;1testgallery&quot;,\r\n                &quot;121212&quot;\r\n            ]\r\n        }\r\n    },\r\n    {...},\r\n    {...},\r\n    {...}\r\n    ]\r\n\r\nand would like to extract only certain objects from it (with `jq`) utilizing its selectors.\r\n\r\nSay, return only the records where **.fields.user_id==&quot;abc&quot;**\r\n\r\nOr, return only the records where **.fields.session_id==&quot;1e2d3f&quot;**\r\n\r\n`select` seems to be the way to achieve this, but I&#39;m not sure how to express the above with it given the JSON structure above.\r\n\r\n[![enter image description here][1]][1]\r\n\r\nThe following produces empty result whereas it should return records for that session_id:\r\n\r\n    curl -X GET   &#39;http://localhost:8090/xxx/api/v1/results?dr=last5days&#39;   -H &#39;Cache-Control: no-cache&#39;   -H &#39;Postman-Token: f6b819d0-f4f6-4def-bccb-3967366779c7&#39;   -H &#39;secret: 5a04bfef-39eb-435a-a0d0-b274592790bb&#39; | jq &#39;.[] | select(.fields.session_id==&quot;1v69yiptamgse1niap51zr2o9x154169081480766b2d6b7-d3ce-4166-9292-c4669a3dfc14&quot;)&#39;\r\n      % Total    % Received % Xferd  Average Speed   Time    Time     Time  Current\r\n                                     Dload  Upload   Total   Spent    Left  Speed\r\n    100 21785    0 21785    0     0   272k      0 --:--:-- --:--:-- --:--:--  272k\r\n    $\r\n\r\nTrying different combinations with jq&#39;s `entries` functions which don&#39;t quite work:\r\n\r\n    curl -X GET   &#39;http://localhost:8080/xxx/api/v1/results?dr=last5days&#39;   -H &#39;Cache-Control: no-cache&#39;   -H &#39;Postman-Token: f6b819d0-f4f6-4def-bccb-3967366779c7&#39;   -H &#39;secret: 5a04bf34ef-39eb-435a-a0d0-b278765790bb&#39; | jq  &#39;with_entries(select(.value.pk==98))&#39;\r\n      % Total    % Received % Xferd  Average Speed   Time    Time     Time  Current\r\n                                     Dload  Upload   Total   Spent    Left  Speed\r\n    100 31755    0 31755    0     0   127k      0 --:--:-- --:--:-- --:--:--  127k\r\n    jq: error (at &lt;stdin&gt;:274): Cannot use number (9) as object key\r\n\r\n\r\nCan someone please give me a hand creating a correct `jq` query?  TIA.\r\n\r\n\r\n===\r\n\r\nTrying to implement a suggestion expressed in the comments:\r\n\r\nThis `jq` expression:\r\n\r\n    map(select(.fields.user_id==&quot;amzn1.ask.account.AHMFB2H7ZXMSCB5TLPYWCPBJGWGHFYQZ6OPPMEPQ7CT2LZXNPAFJMJELXXCCTEZ2JUE5PXRSBJHJTO3AVXT3C63AOEZLIEP3D3HIFBT5M23G4ORENFRT54AAK7I4X2HCORXJAB2UGQAHPE2TC75F2GWWZWSPO2CWEAZJJN7LJYFWEYHEJDLNQ6FSUD5LQWKBUC347K3IF32IV3I&quot;)) | length\r\n\r\nseems to work in the JQ Playground (returns the correct count of **3**):\r\n\r\n[![enter image description here][2]][2]\r\n\r\nbut when used on the command line, it returns a wrong result (and empty array of length **0**) :\r\n\r\n    $ curl -X GET   &#39;http://localhost:8080/xxx/api/v1/results?dr=last5days&#39;   -H &#39;Cache-Control: no-cache&#39;   -H &#39;Postman-Token: f6b819d0-f4f6-4def-bccb-3967366779c7&#39;   -H &#39;secret: 5a04bfef-39eb-435a-a0d0-b271392790bb&#39; | jq  &#39;map(select(.fields.user_id==&quot;amzn1.ask.account.AHMFB2H7ZXMSCB5TLPYWCPBJGWGHFYQZ6OPPMEPQ7CT2LZXNPAFJMJELXXCCTEZ2JUE5PXRSBJHJTO3AVXT3C63AOEZLIEP3D3HIFBT5M23G4ORENFRT54AAK7I4X2HCORXJAB2UGQAHPE2TC75F2GWWZWSPO2CWEAZJJN7LJYFWEYHEJDLNQ6FSUD5LQWKBUC347K3IF32IV3I&quot;)) | length&#39;\r\n      % Total    % Received % Xferd  Average Speed   Time    Time     Time  Current\r\n                                     Dload  Upload   Total   Spent    Left  Speed\r\n    100 21785    0 21785    0     0  95630      0 --:--:-- --:--:-- --:--:-- 95969\r\n    0\r\n    $\r\n\r\n\r\nWhat am I still doing wrong?\r\n\r\n======\r\n\r\nAs per suggestions in comments, the following query with debug returns JSON, but still doesn&#39;t produce correct counts:\r\n\r\n    $ curl -X GET   &#39;http://localhost:8080/xxx/api/v1/results?dr=last5days&#39;   -H &#39;Cache-Control: no-cache&#39;   -H &#39;Postman-Token: f6b819d0-f4f6-4def-bccb-3967366779c7&#39;   -H &#39;secret: 5a04bfef-39eb-435a-a0d0-b271392790bb&#39; | jq  &#39; debug | map(select(.fields.session_id==&quot;1v69yiptamgse1niap51zr2o9x154169081480766b2d6b7-d3ce-4166-9292-c4669a3dfc14&quot;)) | length&#39;\r\n\r\n  \r\n\r\n[![enter image description here][3]][3]\r\n\r\n\r\n  [1]: https://i.sstatic.net/i2k4r.png\r\n  [2]: https://i.sstatic.net/fFVoP.png\r\n  [3]: https://i.sstatic.net/YzL2X.png",
        "link": "https://stackoverflow.com/questions/53291061/filtering-json-curl-results-with-jq-selectors",
        "title": "Filtering JSON curl results with jq selectors"
    },
    {
        "tags": [
            "python",
            "json",
            "shell",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1542166482,
                "creation_date": 1542166482,
                "answer_id": 53292825,
                "question_id": 53292674,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "    echo &#39;name=$get_name\r\n    pass=$get_pass\r\n    value=$get_value\r\n    key=$get_key\r\n    port=$get_port\r\n    server_ip=$get_ip&#39; | jq -Rs &#39;\r\n      split(&quot;\\n&quot;)\r\n      | map(capture(&quot;(?&lt;k&gt;^[^=]*)=(?&lt;v&gt;.*)&quot;)  | {(.k): .v} )\r\n      | add&#39;\r\n\r\nproduces output in the format you&#39;ve indicated you want:\r\n\r\n    {\r\n      &quot;name&quot;: &quot;$get_name&quot;,\r\n      &quot;pass&quot;: &quot;$get_pass&quot;,\r\n      &quot;value&quot;: &quot;$get_value&quot;,\r\n      &quot;key&quot;: &quot;$get_key&quot;,\r\n      &quot;port&quot;: &quot;$get_port&quot;,\r\n      &quot;server_ip&quot;: &quot;$get_ip&quot;\r\n    }\r\n\r\nObviously if you wanted $get_name to be evaluated at `echo` time, you&#39;d use double-quotes.\r\n",
                "title": "i have the end result of a shell script in echo and i want to convert it to json object"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1542166716,
        "creation_date": 1542165226,
        "last_edit_date": 1542166716,
        "question_id": 53292674,
        "body_markdown": "i got this end results of a long shell script i want to convert it to a json object is there&#39;s any simple way where i can pipe the echo | in to it \r\n\r\n    echo &quot;name=$get_name\r\n    pass=$get_pass\r\n    value=$get_value\r\n    key=$get_key\r\n    port=$get_port\r\n    server_ip=$get_ip&quot; | jq \r\n\r\ni want to get this results like this json \r\n\r\n         {\r\n          &quot;pass&quot;: &quot;$get_pass&quot;\r\n           &quot;value&quot;: &quot;$get_value&quot;\r\n           &quot;key&quot;: &quot;$get_key&quot;\r\n            &quot;port&quot;: &quot;$get_port&quot;\r\n            &quot;server_ip&quot;: &quot;$get_ip&quot;\r\n           }",
        "link": "https://stackoverflow.com/questions/53292674/i-have-the-end-result-of-a-shell-script-in-echo-and-i-want-to-convert-it-to-json",
        "title": "i have the end result of a shell script in echo and i want to convert it to json object"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2550933,
                    "reputation": 13299,
                    "user_id": 2214695,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/dee2ef257601e05c5659f04de9cb7c67?s=256&d=identicon&r=PG",
                    "display_name": "oliv",
                    "link": "https://stackoverflow.com/users/2214695/oliv"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1542189026,
                "post_id": 53296285,
                "comment_id": 93475386,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1542205376,
                "creation_date": 1542205376,
                "answer_id": 53302408,
                "question_id": 53296285,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Your use of iteration (`.segments[]`) causes multiplicative behavior: in your case, since there are four cases in which `.segments|length` is 2, you get a 2^10 expansion locally, four times.\r\n\r\nIn situations such as this, it would make sense to use a small but well-chosen subset of the data (or maybe more easily, an artificial dataset) to check the code.\r\n\r\nPerhaps what you intended is something more like:\r\n\r\n    [ .legs[] | range(0; .segments|length) as $i | .... ]\r\n\r\n\r\n\r\n\r\n\r\n\r\n",
                "title": "JQ 1.5: Timestamp / date transformation produce huge file"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1542205376,
        "creation_date": 1542185837,
        "question_id": 53296285,
        "body_markdown": "I using jq 1.5 under a Windows 10 powershell enviroment to transform json files and import them to a MS SQL database. The original json file is around 1,1mb. I stored the file here: [Json origin file][1]. I use following jq command to transform the data:\r\n\r\n    [.legs[] | {Legid: .legId, Farecode: .fareBasisCode, Travelduration: .travelDuration, Traveldistance: .totalTravelDistance, Distanceunit: .totalTravelDistanceUnits, Refundable: .isRefundable , Nonstop: .isNonStop, Departure_Airport: .segments[].departureAirportName, Departure_Code: .segments[].departureAirportCode, Arrival_Airport: .segments[].arrivalAirportName, Arrival_Code: .segments[].arrivalAirportCode, Departure_Time: .segments[].departureTimeEpochSeconds, Arrival_Time: .segments[].arrivalTimeEpochSeconds, Airline: .segments[].airlineName, Airline_Code: .segments[].airlineCode, Flight_Number: .segments[].flightNumber, Equipment: .segments[].equipmentDescription}]\r\n\r\nThat command produce following file [transformed file][2]. Now i had to transform the UNIX Timestamps to Dates. So i modified the command:\r\n\r\n    [.legs[] | {Legid: .legId, Farecode: .fareBasisCode, Travelduration: .travelDuration, Traveldistance: .totalTravelDistance, Distanceunit: .totalTravelDistanceUnits, Refundable: .isRefundable , Nonstop: .isNonStop, Departure_Airport: .segments[].departureAirportName, Departure_Code: .segments[].departureAirportCode, Arrival_Airport: .segments[].arrivalAirportName, Arrival_Code: .segments[].arrivalAirportCode, Departure_Time: .segments[].departureTimeEpochSeconds, Arrival_Time: .segments[].arrivalTimeEpochSeconds, Airline: .segments[].airlineName, Airline_Code: .segments[].airlineCode, Flight_Number: .segments[].flightNumber, Equipment: .segments[].equipmentDescription}] | .[].Departure_Time |= todate | .[].Arrival_Time |= todate\r\n\r\nThe transformed file without date Transformation have around 3 mb. After the date Transformation the file have around 40 mb. I think i have a logical error in my command, but cant find it. Tips?\r\n\r\nRegards\r\nTimo\r\n\r\n\r\n  [1]: https://jsonblob.com/fa1e2b57-e7e8-11e8-9007-8176f625eaf6\r\n  [2]: https://jsonblob.com/6ea23d97-e7ea-11e8-9007-09a55fb13d8c",
        "link": "https://stackoverflow.com/questions/53296285/jq-1-5-timestamp-date-transformation-produce-huge-file",
        "title": "JQ 1.5: Timestamp / date transformation produce huge file"
    },
    {
        "tags": [
            "json",
            "google-chrome",
            "jq",
            "bookmarks"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 915477,
                    "reputation": 3829,
                    "user_id": 948359,
                    "user_type": "registered",
                    "accept_rate": 0,
                    "profile_image": "https://i.sstatic.net/f6P38.jpg?s=256",
                    "display_name": "schlebe",
                    "link": "https://stackoverflow.com/users/948359/schlebe"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1542196295,
                "post_id": 53299320,
                "comment_id": 93479754,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5402400,
                    "reputation": 13,
                    "user_id": 4301884,
                    "user_type": "registered",
                    "profile_image": "https://lh6.googleusercontent.com/-edjI9B6KT_o/AAAAAAAAAAI/AAAAAAAAAEY/QfjTwW5VcLk/s256-rj/photo.jpg",
                    "display_name": "Philip Rhoades P",
                    "link": "https://stackoverflow.com/users/4301884/philip-rhoades-p"
                },
                "reply_to_user": {
                    "account_id": 915477,
                    "reputation": 3829,
                    "user_id": 948359,
                    "user_type": "registered",
                    "accept_rate": 0,
                    "profile_image": "https://i.sstatic.net/f6P38.jpg?s=256",
                    "display_name": "schlebe",
                    "link": "https://stackoverflow.com/users/948359/schlebe"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1542200842,
                "post_id": 53299320,
                "comment_id": 93482367,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5402400,
                    "reputation": 13,
                    "user_id": 4301884,
                    "user_type": "registered",
                    "profile_image": "https://lh6.googleusercontent.com/-edjI9B6KT_o/AAAAAAAAAAI/AAAAAAAAAEY/QfjTwW5VcLk/s256-rj/photo.jpg",
                    "display_name": "Philip Rhoades P",
                    "link": "https://stackoverflow.com/users/4301884/philip-rhoades-p"
                },
                "reply_to_user": {
                    "account_id": 915477,
                    "reputation": 3829,
                    "user_id": 948359,
                    "user_type": "registered",
                    "accept_rate": 0,
                    "profile_image": "https://i.sstatic.net/f6P38.jpg?s=256",
                    "display_name": "schlebe",
                    "link": "https://stackoverflow.com/users/948359/schlebe"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1542201466,
                "post_id": 53299320,
                "comment_id": 93482759,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5402400,
                    "reputation": 13,
                    "user_id": 4301884,
                    "user_type": "registered",
                    "profile_image": "https://lh6.googleusercontent.com/-edjI9B6KT_o/AAAAAAAAAAI/AAAAAAAAAEY/QfjTwW5VcLk/s256-rj/photo.jpg",
                    "display_name": "Philip Rhoades P",
                    "link": "https://stackoverflow.com/users/4301884/philip-rhoades-p"
                },
                "reply_to_user": {
                    "account_id": 915477,
                    "reputation": 3829,
                    "user_id": 948359,
                    "user_type": "registered",
                    "accept_rate": 0,
                    "profile_image": "https://i.sstatic.net/f6P38.jpg?s=256",
                    "display_name": "schlebe",
                    "link": "https://stackoverflow.com/users/948359/schlebe"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1542201510,
                "post_id": 53299320,
                "comment_id": 93482796,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5402400,
                    "reputation": 13,
                    "user_id": 4301884,
                    "user_type": "registered",
                    "profile_image": "https://lh6.googleusercontent.com/-edjI9B6KT_o/AAAAAAAAAAI/AAAAAAAAAEY/QfjTwW5VcLk/s256-rj/photo.jpg",
                    "display_name": "Philip Rhoades P",
                    "link": "https://stackoverflow.com/users/4301884/philip-rhoades-p"
                },
                "reply_to_user": {
                    "account_id": 915477,
                    "reputation": 3829,
                    "user_id": 948359,
                    "user_type": "registered",
                    "accept_rate": 0,
                    "profile_image": "https://i.sstatic.net/f6P38.jpg?s=256",
                    "display_name": "schlebe",
                    "link": "https://stackoverflow.com/users/948359/schlebe"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1542201625,
                "post_id": 53299320,
                "comment_id": 93482874,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 915477,
                    "reputation": 3829,
                    "user_id": 948359,
                    "user_type": "registered",
                    "accept_rate": 0,
                    "profile_image": "https://i.sstatic.net/f6P38.jpg?s=256",
                    "display_name": "schlebe",
                    "link": "https://stackoverflow.com/users/948359/schlebe"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1542203732,
                "post_id": 53299320,
                "comment_id": 93484309,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 915477,
                    "reputation": 3829,
                    "user_id": 948359,
                    "user_type": "registered",
                    "accept_rate": 0,
                    "profile_image": "https://i.sstatic.net/f6P38.jpg?s=256",
                    "display_name": "schlebe",
                    "link": "https://stackoverflow.com/users/948359/schlebe"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1542203892,
                "post_id": 53299320,
                "comment_id": 93484413,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 7310558,
                    "reputation": 740,
                    "user_id": 5569925,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/0435bf08963d1ff53d3b01502f5f3767?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Goldfish",
                    "link": "https://stackoverflow.com/users/5569925/goldfish"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1542738385,
                "post_id": 53299320,
                "comment_id": 93673696,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1542738323,
                "creation_date": 1542738323,
                "answer_id": 53399251,
                "question_id": 53299320,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Have you tried to use any free tools like: https://json-csv.com/\r\n\r\nor json2csv: https://www.npmjs.com/package/json2csv\r\n\r\nIf neither of those works, perhaps this approach.\r\n\r\nWhen I need to reconstruct data I write a set of loops that identify each property I want for each line in my CSV. Let&#39;s say my JSON has `Name, Email, Phone` but for some reason all are at different object levels in my JSON.\r\n\r\nFirst right a loop that resolves Name, then a loop for Email, and one for Phone. At the end of the first loop call the second, and from the second call the third. \r\n\r\nThen you can use `jq -n` which allows to create JSON with no input.\r\n\r\n\r\nSo your CSV output would be like `jq -n &#39;{NewName: .[&quot;&#39;$Name&#39;&quot;]}&#39;` \r\n\r\nonce you have a clean JSON with all data points at the same level CSV conversion is smooth. \r\n\r\nHope this helps",
                "title": "Does anyone have a script to convert a Chrome Bookmarks file with [sub]*folders into a CVS file?"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1542738323,
        "creation_date": 1542195352,
        "last_edit_date": 1542207737,
        "question_id": 53299320,
        "body_markdown": "I want to be able to do Vimdiffs and Vimfolds on Bookmarks files that have been converted to CVS files ie with one description and one uri per line.  However, because the Bookmarks file has multiple levels for the folders, the CSV file will also need fields for the different levels of folder names on each line.\r\n\r\nI am new to jq but it seems like it should be able to do this sort of conversion?\r\n\r\nThanks,\r\nPhil.",
        "link": "https://stackoverflow.com/questions/53299320/does-anyone-have-a-script-to-convert-a-chrome-bookmarks-file-with-subfolders",
        "title": "Does anyone have a script to convert a Chrome Bookmarks file with [sub]*folders into a CVS file?"
    },
    {
        "tags": [
            "json",
            "bash",
            "csv",
            "parsing",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1542207405,
                "creation_date": 1542207405,
                "answer_id": 53303049,
                "question_id": 53301111,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I would suggest that you begin by ensuring that .foo.item, .bar.item, and .var.item are always arrays.  This could be done using the following helper function:\r\n\r\n    def w: if type==&quot;array&quot; then . else [.] end;\r\n\r\nYour jq filter would then begin as follows:\r\n\r\n    .data[]\r\n    | .foo.item |= w\r\n    | .bar.item |= w\r\n    | .var.item |= w\r\n\r\nWhat you do next depends on what you want to do with all these arrays, but I have verified that the following produces the result you&#39;ve indicated you want:\r\n\r\n\r\n    .data[]\r\n    | .foo.item |= w\r\n    | .bar.item |= w\r\n    | .var.item |= w\r\n    | range(0; .foo.item | length) as $i\r\n    | select(.foo.item[$i].value != &quot;foo_bad&quot;)\r\n    | select(.bar.item[$i].value)\r\n    | [.id,.bar.item[$i].value,.var.item[$i].value]\r\n    | @csv\r\n\r\n\r\n\r\n",
                "title": "How to parse JSON with an inconsistent data type?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1543263719,
        "creation_date": 1542201284,
        "last_edit_date": 1543263719,
        "question_id": 53301111,
        "body_markdown": "I need to create a `csv` report from a `JSON` file of the following structure (simplified as much as I saw fit):\r\n\r\n    {\r\n      &quot;data&quot;: [\r\n        {\r\n          &quot;id&quot;: &quot;123&quot;,\r\n          &quot;foo&quot;: {\r\n            &quot;item&quot;: {\r\n              &quot;value&quot;: &quot;foo_good&quot;,\r\n              &quot;bar_id&quot;: &quot;1&quot;\r\n            }\r\n          },\r\n          &quot;bar&quot;: {\r\n            &quot;item&quot;: {\r\n              &quot;id&quot;: &quot;1&quot;,\r\n              &quot;value&quot;: &quot;bar_value_1a&quot;\r\n            }\r\n          },\r\n          &quot;var&quot;: {\r\n            &quot;item&quot;: {\r\n              &quot;value&quot;: &quot;var_value_1a&quot;,\r\n              &quot;bar_id&quot;: &quot;1&quot;\r\n            }\r\n          }\r\n        },\r\n        {\r\n          &quot;id&quot;: &quot;456&quot;,\r\n          &quot;foo&quot;: {\r\n            &quot;item&quot;: [\r\n              {\r\n                &quot;value&quot;: &quot;foo_bad&quot;,\r\n                &quot;bar_id&quot;: &quot;1&quot;\r\n              },\r\n              {\r\n                &quot;value&quot;: &quot;foo_good&quot;,\r\n                &quot;bar_id&quot;: &quot;2&quot;\r\n              },\r\n              {\r\n                &quot;value&quot;: &quot;foo_good&quot;,\r\n                &quot;bar_id&quot;: &quot;2&quot;\r\n              },\r\n              {\r\n                &quot;value&quot;: &quot;foo_bad&quot;,\r\n                &quot;bar_id&quot;: &quot;3&quot;\r\n              },\r\n              {\r\n                &quot;value&quot;: &quot;foo_good&quot;,\r\n                &quot;bar_id&quot;: &quot;4&quot;\r\n              }\r\n            ]\r\n          },\r\n          &quot;bar&quot;: {\r\n            &quot;item&quot;: [\r\n              {\r\n                &quot;id&quot;: &quot;1&quot;,\r\n                &quot;value&quot;: &quot;bar_value_2a&quot;\r\n              },\r\n              {\r\n                &quot;id&quot;: &quot;2&quot;,\r\n                &quot;value&quot;: &quot;bar_value_2b&quot;\r\n              },\r\n              {\r\n                &quot;id&quot;: &quot;3&quot;,\r\n                &quot;value&quot;: &quot;bar_value_2c&quot;\r\n              },\r\n              {\r\n                &quot;id&quot;: &quot;4&quot;,\r\n                &quot;value&quot;: &quot;bar_value_2d&quot;\r\n              }\r\n            ]\r\n          },\r\n          &quot;var&quot;: {\r\n            &quot;item&quot;: [\r\n              {\r\n                &quot;value&quot;: &quot;var_value_2a&quot;,\r\n                &quot;bar_id&quot;: &quot;1&quot;\r\n              },\r\n              {\r\n                &quot;value&quot;: &quot;var_value_2b&quot;,\r\n                &quot;bar_id&quot;: &quot;2&quot;\r\n              },\r\n              {\r\n                &quot;value&quot;: &quot;var_value_2c&quot;,\r\n                &quot;bar_id&quot;: &quot;3&quot;\r\n              },\r\n              {\r\n                &quot;value&quot;: &quot;var_value_2d&quot;,\r\n                &quot;bar_id&quot;: &quot;4&quot;\r\n              }\r\n            ]\r\n          }\r\n        }\r\n      ]\r\n    }\r\n\r\n----------\r\n**Data structure:**\r\n\r\n1. `foo.item` and `var.item` are connected to `bar.item` with `bar_id`\r\n1. One or more `foo.item` point to one `bar.item`\r\n1. Multiple `foo.item` pointing to the same `bar.item` will have the same `foo.item.value`\r\n1. Exactly one `var.item` points to one `bar.item`\r\n1. All items are sorted by `bar_id`\r\n1. The format is **inconsistent**. `bar.item` is an object if there is only one item, it&#39;s an array otherwise (applies to `foo.item` and `var.item` as well)\r\n1. I am stuck with this format\r\n\r\n**Output report:**\r\n\r\n1. Process all `data` objects\r\n1. Create report for each `bar.item` that does **not** have any corresponding `foo.item` with a value `foo_bad`\r\n1. The output format: `.id, .bar.item.value, .var.item.value`\r\n\r\n\r\n----------\r\n\r\n**My attempt:**\r\n\r\nThe temporary `jq` script I am currently using discards multiple `bar.item` etc. and creates mere estimation of the real data:\r\n\r\n    .data[]\r\n    | .foo.item |= if type==&quot;array&quot; then .[0] else . end\r\n    | .bar.item |= if type==&quot;array&quot; then .[0] else . end\r\n    | .var.item |= if type==&quot;array&quot; then .[0] else . end\r\n    | select(.foo.item.value != &quot;foo_bad&quot;)\r\n    | [.id,.bar.item.value,.var.item.value]\r\n    | @csv\r\n\r\nWhich outputs the following:\r\n\r\n    &quot;123&quot;,&quot;bar_value_1a&quot;,&quot;var_value_1a&quot;\r\n\r\n\r\n----------\r\n\r\n**Desired output:**\r\n\r\n    &quot;123&quot;,&quot;bar_value_1a&quot;,&quot;var_value_1a&quot;\r\n    &quot;456&quot;,&quot;bar_value_2b&quot;,&quot;var_value_2b&quot;\r\n    &quot;456&quot;,&quot;bar_value_2d&quot;,&quot;var_value_2d&quot;\r\n\r\nI prefer using `jq` although I do not insist on it.\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/53301111/how-to-parse-json-with-an-inconsistent-data-type",
        "title": "How to parse JSON with an inconsistent data type?"
    },
    {
        "tags": [
            "json",
            "filtering",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1542227403,
                "last_edit_date": 1542227403,
                "creation_date": 1542225746,
                "answer_id": 53307950,
                "question_id": 53307740,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Does this seem less of a kludge?\r\n\r\n    [1,2,3,4] as $acceptable\r\n    | .potato as $k\r\n    | select( any($acceptable[];  . == $k) )\r\n\r\nIf your jq has `IN/1`, you could skip the `$k`:\r\n\r\n    [1,2,3,4] as $acceptable\r\n    | select(.potato | IN($acceptable[]))\r\n\r\nThis style makes it easy to pass `$acceptable` in as a command-line parameter, for example.\r\n\r\n## Temptation\r\n\r\nIt is easy to be tempted by the simplicity of a select-only solution such as:\r\n\r\n    [1,2,3,4] as $acceptable\r\n    | select($acceptable[] == .potato)\r\n\r\nThis would be fine under certain circumstances, e.g. if `$acceptable` is short and does not contain duplicates (assuming we want the semantics of `any`). But `any` and `IN` have a short-circuit semantics that may be desirable, e.g. for efficiency.\r\n",
                "title": "How do I filter JSON using jq based on if an attribute value is in an array?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1542227403,
        "creation_date": 1542224833,
        "question_id": 53307740,
        "body_markdown": "I have some JSON that I need to filter based on whether certain attribute values are present in an array.\r\n\r\nI have something that works but if feels like a kludge. Is there a neater way of doing this?\r\n\r\nInput \r\n\r\n    {&quot;potato&quot;:4}\r\n\r\nFilter\r\n\r\n    select(.potato as $k | ([1,2,3,4] | any(. == $k)))\r\n\r\nOutput\r\n\r\n    {\r\n      &quot;potato&quot;: 4\r\n    }\r\n\r\njqplay link\r\nhttps://jqplay.org/s/Ts97jkk21K\r\n\r\n",
        "link": "https://stackoverflow.com/questions/53307740/how-do-i-filter-json-using-jq-based-on-if-an-attribute-value-is-in-an-array",
        "title": "How do I filter JSON using jq based on if an attribute value is in an array?"
    },
    {
        "tags": [
            "json",
            "transformation",
            "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": 1542232564,
                "post_id": 53308984,
                "comment_id": 93499439,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1542232298,
                "creation_date": 1542232298,
                "answer_id": 53309249,
                "question_id": 53308984,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; ... using jq preferably ...\r\n\r\nThat&#39;s the spirit!  And in that spirit, here&#39;s a concise solution:\r\n\r\n    map( {certname, (.name): .value} )\r\n    | group_by(.certname)\r\n    | map(add)\r\n\r\nOf course there are other reasonable solutions.  If the above is at first puzzling, you might like to add a `debug` statement here or there, or you might like to explore the pipeline by executing the first line by itself, etc.\r\n",
                "title": "Collect JSON objects with same attribute value, and create new key/value pairs"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1542232508,
        "creation_date": 1542230879,
        "last_edit_date": 1542232508,
        "question_id": 53308984,
        "body_markdown": "Here is a simplified sample of the JSON data I&#39;m working with:\r\n\r\n    [\r\n      { &quot;certname&quot;: &quot;one.example.com&quot;,\r\n        &quot;name&quot;: &quot;fact1&quot;,\r\n        &quot;value&quot;: &quot;value1&quot;\r\n      },\r\n      { &quot;certname&quot;: &quot;one.example.com&quot;,\r\n        &quot;name&quot;: &quot;fact2&quot;,\r\n        &quot;value&quot;: 42\r\n      },\r\n      { &quot;certname&quot;: &quot;two.example.com&quot;,\r\n        &quot;name&quot;: &quot;fact1&quot;,\r\n        &quot;value&quot;: &quot;value3&quot;\r\n      },\r\n      { &quot;certname&quot;: &quot;two.example.com&quot;,\r\n        &quot;name&quot;: &quot;fact2&quot;,\r\n        &quot;value&quot;: 10000\r\n      },\r\n      { &quot;certname&quot;: &quot;two.example.com&quot;,\r\n        &quot;name&quot;: &quot;fact3&quot;,\r\n        &quot;value&quot;: { &quot;anotherkey&quot;: &quot;anothervalue&quot; }\r\n      }\r\n    ]\r\n\r\nThe result I want to achieve, using `jq` preferably, is the following:\r\n\r\n    [\r\n      {\r\n        &quot;certname&quot;: &quot;one.example.com&quot;,\r\n        &quot;fact1&quot;: &quot;value1&quot;,\r\n        &quot;fact2&quot;: 42\r\n      },\r\n      {\r\n        &quot;certname&quot;: &quot;two.example.com&quot;,\r\n        &quot;fact1&quot;: &quot;value3&quot;,\r\n        &quot;fact2&quot;: 10000,\r\n        &quot;fact3&quot;: { &quot;anotherkey&quot;: &quot;anothervalue&quot; }\r\n      }\r\n    ]\r\n\r\nIts worth pointing out that not all elements have the same name/value pairs, by any means. Also, values are often complex objects in their own right.\r\n\r\nIf I was doing this in Python, it wouldn&#39;t be a big deal (and yes, I can hear the chorus of &quot;do it in Python&quot; ringing in my ears now). I would like to understand how to do this in `jq`, and it&#39;s escaping me at the moment.  ",
        "link": "https://stackoverflow.com/questions/53308984/collect-json-objects-with-same-attribute-value-and-create-new-key-value-pairs",
        "title": "Collect JSON objects with same attribute value, and create new key/value pairs"
    },
    {
        "tags": [
            "parsing",
            "jq",
            "bookmarks",
            "pocket"
        ],
        "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": 1542248887,
                "post_id": 53311375,
                "comment_id": 93503925,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1542248840,
                "creation_date": 1542248840,
                "answer_id": 53311559,
                "question_id": 53311375,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using your sample input after rectification to make it valid JSON:\r\n\r\n    jq -r &#39;.list[] | [.given_url] + (.tags|keys_unsorted) | @csv&#39; input.json\r\n\r\nyields:\r\n\r\n    &quot;https://stackoverflow.com/questions/28164849/using-jq-to-parse-and-display-multiple-fields-in-a-json-serially&quot;,&quot;fields&quot;,&quot;jq&quot;,&quot;multiple&quot;\r\n\r\nThis is valid CSV. If you don&#39;t want all the double quotation marks, you can use string interpolation as in your attempt.",
                "title": "Pocket API JSON parsing"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": -1,
                "last_activity_date": 1551941909,
                "last_edit_date": 1551941909,
                "creation_date": 1542309866,
                "answer_id": 53326605,
                "question_id": 53311375,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I added a ?. This works (even for entries without tags). The access_token and consumer_key are redacted in the curl command.\r\n\r\nNOTE: the consumer_key &amp; the access_token have each been replace with *\r\n\r\n`curl https://getpocket.com/v3/get --insecure -X POST -H &quot;Content-Type: application/json&quot; -H &quot;X-Accept: application/json&quot; -d &quot;{\\&quot;consumer_key\\&quot;:\\&quot;80793-861ab2c92e846c8324b417e8\\&quot;, \\&quot;access_token\\&quot;:\\&quot;b6b55049-fe0a-df88-8f78-eb9ccc\\&quot;, \\&quot;detailType\\&quot;:\\&quot;complete\\&quot;}&quot; | jq -r &#39;.list[] | [.given_url] + (.tags|keys_unsorted?) | @csv&#39; | less\r\n`\r\n\r\n\r\n\r\nFrom the jq manual:\r\n\r\n\t.[]?\r\n\t\t   Like .[], but no errors will be output if . is not an array or object.",
                "title": "Pocket API JSON parsing"
            }
        ],
        "is_answered": false,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1551941909,
        "creation_date": 1542247259,
        "question_id": 53311375,
        "body_markdown": "I am trying to parse the JSON from the Pocket API to keep up with my bookmarks. The JSON recieved after a curl request looks like this:\r\n\r\n\t  &quot;list&quot;: {\r\n\t\t&quot;1548784635&quot;: {\r\n\t\t  &quot;item_id&quot;: &quot;1548784635&quot;,\r\n\t\t  &quot;resolved_id&quot;: &quot;1548784635&quot;,\r\n\t\t  &quot;given_url&quot;: &quot;https://stackoverflow.com/questions/28164849/using-jq-to-par\r\n\tse-and-display-multiple-fields-in-a-json-serially&quot;,\r\n\t\t  &quot;given_title&quot;: &quot;Using jq to parse and display multiple fields in a json se\r\n\trially - Stack Ov&quot;,\r\n\t\t  &quot;favorite&quot;: &quot;0&quot;,\r\n\t\t  &quot;status&quot;: &quot;0&quot;,\r\n\t\t  &quot;time_added&quot;: &quot;1542244328&quot;,\r\n\t\t  &quot;time_updated&quot;: &quot;1542244341&quot;,\r\n\t\t  &quot;time_read&quot;: &quot;0&quot;,\r\n\t\t  &quot;time_favorited&quot;: &quot;0&quot;,\r\n\t\t  &quot;sort_id&quot;: 0,\r\n\t\t  &quot;resolved_title&quot;: &quot;Using jq to parse and display multiple fields in a json\r\n\t serially&quot;,\r\n\t\t  &quot;resolved_url&quot;: &quot;https://stackoverflow.com/questions/28164849/using-jq-to-\r\n\tparse-and-display-multiple-fields-in-a-json-serially&quot;,\r\n\t\t  &quot;excerpt&quot;: &quot;Using jq I&#39;d like to display first and last name serially. Lik\r\n\te so -   You can use addition to concatenate strings.&quot;,\r\n\t\t  &quot;is_article&quot;: &quot;1&quot;,\r\n\t\t  &quot;is_index&quot;: &quot;0&quot;,\r\n\t\t  &quot;has_video&quot;: &quot;0&quot;,\r\n\t\t  &quot;has_image&quot;: &quot;1&quot;,\r\n\t\t  &quot;word_count&quot;: &quot;313&quot;,\r\n\t\t  &quot;lang&quot;: &quot;en&quot;,\r\n\t\t  &quot;top_image_url&quot;: &quot;https://cdn.sstatic.net/Sites/stackoverflow/img/apple-to\r\n\tuch-icon@2.png?v=73d79a89bded&quot;,\r\n\t\t  &quot;tags&quot;: {\r\n\t\t\t&quot;fields&quot;: {\r\n\t\t\t  &quot;item_id&quot;: &quot;1548784635&quot;,\r\n\t\t\t  &quot;tag&quot;: &quot;fields&quot;\r\n\t\t\t},\r\n\t\t\t&quot;jq&quot;: {\r\n\t\t\t  &quot;item_id&quot;: &quot;1548784635&quot;,\r\n\t\t\t  &quot;tag&quot;: &quot;jq&quot;\r\n\t\t\t},\r\n\t\t\t&quot;multiple&quot;: {\r\n\t\t\t  &quot;item_id&quot;: &quot;1548784635&quot;,\r\n\t\t\t  &quot;tag&quot;: &quot;multiple&quot;\r\n\t\t\t}\r\n\t\t  },\r\n\t\t  &quot;authors&quot;: {\r\n\t\t\t&quot;45850780&quot;: {\r\n\t\t\t  &quot;item_id&quot;: &quot;1548784635&quot;,\r\n\t\t\t  &quot;author_id&quot;: &quot;45850780&quot;,\r\n\t\t\t  &quot;name&quot;: &quot;abraham&quot;,\r\n\t\t\t  &quot;url&quot;: &quot;https://stackoverflow.com/users/26406/abraham&quot;\r\n\t\t\t},\r\n\t\t\t&quot;82251593&quot;: {\r\n\t\t\t  &quot;item_id&quot;: &quot;1548784635&quot;,\r\n\t\t\t  &quot;author_id&quot;: &quot;82251593&quot;,\r\n\t\t\t  &quot;name&quot;: &quot;San&quot;,\r\n\t\t\t  &quot;url&quot;: &quot;https://stackoverflow.com/users/3713971/san&quot;\r\n\t\t\t}\r\n\t\t  },\r\n\t\t  &quot;image&quot;: {\r\n\t\t\t&quot;item_id&quot;: &quot;1548784635&quot;,\r\n\t\t\t&quot;src&quot;: &quot;https://i.sstatic.net/rZUli.jpg?s=32&amp;g=1&quot;,\r\n\t\t\t&quot;width&quot;: &quot;32&quot;,\r\n\t\t\t&quot;height&quot;: &quot;32&quot;\r\n\t\t  },\r\n\t\t  &quot;images&quot;: {\r\n\t\t\t&quot;1&quot;: {\r\n\t\t\t  &quot;item_id&quot;: &quot;1548784635&quot;,\r\n\t\t\t  &quot;image_id&quot;: &quot;1&quot;,\r\n\t\t\t  &quot;src&quot;: &quot;https://i.sstatic.net/rZUli.jpg?s=32&amp;g=1&quot;,\r\n\t\t\t  &quot;width&quot;: &quot;32&quot;,\r\n\t\t\t  &quot;height&quot;: &quot;32&quot;,\r\n\t\t\t  &quot;credit&quot;: &quot;&quot;,\r\n\t\t\t  &quot;caption&quot;: &quot;&quot;\r\n\t\t\t}\r\n\t\t  },\r\n\t\t  &quot;domain_metadata&quot;: {\r\n\t\t\t&quot;name&quot;: &quot;Stack Overflow&quot;,\r\n\t\t\t&quot;logo&quot;: &quot;https://logo.clearbit.com/stackoverflow.com?size=800&quot;,\r\n\t\t\t&quot;greyscale_logo&quot;: &quot;https://logo.clearbit.com/stackoverflow.com?size=800&amp;\r\n\tgreyscale=true&quot;\r\n\t\t  },\r\n\t\t  &quot;listen_duration_estimate&quot;: 121\r\n\t\t},\r\n    ...\r\nI am trying to get the output to look like this with the uri over the tags (trying to transform to csv): \r\n\r\n    https://stackoverflow.com/questions/28164849/using-jq-to-parse-and-display-multiple-fields-in-a-json-serially\r\n    fields, jq, multiple\r\n\r\nI tried this but the tags are nested (the consumer_key &amp; access_token are redacted):\r\n\r\n    curl https://getpocket.com/v3/get --insecure -X POST -H &quot;Content-Type: application/json&quot; -H &quot;X-Accept: application/json&quot; -d &quot;{\\&quot;consumer_key\\&quot;:\\&quot;*\\&quot;, \\&quot;access_token\\&quot;:\\&quot;*\\&quot;, \\&quot;detailType\\&quot;:\\&quot;complete\\&quot;}&quot; | jq &#39;.list[] | &quot;\\(.given_url) \\(.tags)&quot;&#39;\r\n\r\n",
        "link": "https://stackoverflow.com/questions/53311375/pocket-api-json-parsing",
        "title": "Pocket API JSON parsing"
    },
    {
        "tags": [
            "json",
            "bash",
            "yaml",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1542273072,
                "post_id": 53315791,
                "comment_id": 93511884,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 950826,
                    "reputation": 16364,
                    "user_id": 977017,
                    "user_type": "registered",
                    "accept_rate": 65,
                    "profile_image": "https://www.gravatar.com/avatar/c04102dbd0a4eabc24fad98983399cf3?s=256&d=identicon&r=PG",
                    "display_name": "Jan",
                    "link": "https://stackoverflow.com/users/977017/jan"
                },
                "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": 1542273512,
                "post_id": 53315791,
                "comment_id": 93512179,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 468289,
                    "reputation": 190915,
                    "user_id": 874188,
                    "user_type": "registered",
                    "accept_rate": 62,
                    "profile_image": "https://www.gravatar.com/avatar/091f411d57db5be8298e057a32e5ad72?s=256&d=identicon&r=PG",
                    "display_name": "tripleee",
                    "link": "https://stackoverflow.com/users/874188/tripleee"
                },
                "edited": false,
                "score": 3,
                "creation_date": 1542276253,
                "post_id": 53315791,
                "comment_id": 93513893,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1542277072,
                "post_id": 53315791,
                "comment_id": 93514341,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 7833471,
                    "reputation": 414,
                    "user_id": 5922531,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/90605b5a0f8d7682fc9d0883e921a5f9?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "AHT",
                    "link": "https://stackoverflow.com/users/5922531/aht"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1542305719,
                "post_id": 53315791,
                "comment_id": 93531678,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 950826,
                    "reputation": 16364,
                    "user_id": 977017,
                    "user_type": "registered",
                    "accept_rate": 65,
                    "profile_image": "https://www.gravatar.com/avatar/c04102dbd0a4eabc24fad98983399cf3?s=256&d=identicon&r=PG",
                    "display_name": "Jan",
                    "link": "https://stackoverflow.com/users/977017/jan"
                },
                "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": 1542309836,
                "post_id": 53315791,
                "comment_id": 93533551,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 75997,
                    "reputation": 9942,
                    "user_id": 217844,
                    "user_type": "registered",
                    "accept_rate": 73,
                    "profile_image": "https://i.sstatic.net/miFAJ.jpg?s=256",
                    "display_name": "ssc",
                    "link": "https://stackoverflow.com/users/217844/ssc"
                },
                "reply_to_user": {
                    "account_id": 7833471,
                    "reputation": 414,
                    "user_id": 5922531,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/90605b5a0f8d7682fc9d0883e921a5f9?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "AHT",
                    "link": "https://stackoverflow.com/users/5922531/aht"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1581941805,
                "post_id": 53315791,
                "comment_id": 106593530,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6009045,
                    "reputation": 14604,
                    "user_id": 4720018,
                    "user_type": "registered",
                    "accept_rate": 75,
                    "profile_image": "https://i.sstatic.net/GC3h8.png?s=256",
                    "display_name": "djvg",
                    "link": "https://stackoverflow.com/users/4720018/djvg"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1632832804,
                "post_id": 53315791,
                "comment_id": 122595567,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 15,
                "is_accepted": false,
                "score": 15,
                "last_activity_date": 1542395840,
                "last_edit_date": 1542395840,
                "creation_date": 1542332165,
                "answer_id": 53330236,
                "question_id": 53315791,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I&#39;m not sure what rules you&#39;re using to get to your expected result. It seems like you&#39;re randomly applying different rules to how the values are being converted.\r\n\r\nAs I understand it, scalar values are just output as is (with potential encoding), objects are output as key/value pairs, and array objects are output with a `-` for every item. The indentation associates what&#39;s part of what.\r\n\r\nSo based on those rules if you&#39;re going to use jq:\r\n\r\n    def yamlify:\r\n        (objects | to_entries[] | (.value | type) as $type |\r\n            if $type == &quot;array&quot; then\r\n                &quot;\\(.key):&quot;, (.value | yamlify)\r\n            elif $type == &quot;object&quot; then\r\n                &quot;\\(.key):&quot;, &quot;    \\(.value | yamlify)&quot;\r\n            else\r\n                &quot;\\(.key):\\t\\(.value)&quot;\r\n            end\r\n        )\r\n        // (arrays | select(length &gt; 0)[] | [yamlify] |\r\n            &quot;  - \\(.[0])&quot;, &quot;    \\(.[1:][])&quot;\r\n        )\r\n        // .\r\n        ;\r\n\r\nThen to use it, add it to your `.jq` file and use it:\r\n\r\n    $ jq -r yamlify input.json\r\n    users:\r\n      - name:       pi\r\n        gecos:      Hypriot Pirate\r\n        sudo:       ALL=(ALL) NOPASSWD:ALL\r\n        shell:      /bin/bash\r\n        groups:     users,docker,video\r\n        plain_text_passwd:  pi\r\n        lock_passwd:        false\r\n        ssh_pwauth: true\r\n        chpasswd:\r\n            expire: false\r\n      - name:       admin\r\n        gecos:      Hypriot Pirate\r\n        sudo:       ALL=(ALL) NOPASSWD:ALL\r\n        shell:      /bin/bash\r\n        primary-group:      users\r\n        groups:     users,docker,adm,dialout,audio,plugdev,netdev,video\r\n        ssh-import-id:      None\r\n        plain_text_passwd:  pi\r\n        lock_passwd:        true\r\n        ssh_pwauth: true\r\n        chpasswd:   {expire: false}\r\n        ssh-authorized-keys:\r\n          - ssh-rsa abcdefg1234567890 YOUR_KEY@YOURHOST.local\r\n\r\n---\r\n\r\nHere&#39;s another variation that aligns the values\r\n\r\n    def yamlify2:\r\n        (objects | to_entries | (map(.key | length) | max + 2) as $w |\r\n            .[] | (.value | type) as $type |\r\n            if $type == &quot;array&quot; then\r\n                &quot;\\(.key):&quot;, (.value | yamlify2)\r\n            elif $type == &quot;object&quot; then\r\n                &quot;\\(.key):&quot;, &quot;    \\(.value | yamlify2)&quot;\r\n            else\r\n                &quot;\\(.key):\\(&quot; &quot; * (.key | $w - length))\\(.value)&quot;\r\n            end\r\n        )\r\n        // (arrays | select(length &gt; 0)[] | [yamlify2] |\r\n            &quot;  - \\(.[0])&quot;, &quot;    \\(.[1:][])&quot;\r\n        )\r\n        // .\r\n        ;\r\n\r\n&lt;!-- --&gt;\r\n\r\n    $ jq -r yamlify2 input.json\r\n    users:\r\n      - name:               pi\r\n        gecos:              Hypriot Pirate\r\n        sudo:               ALL=(ALL) NOPASSWD:ALL\r\n        shell:              /bin/bash\r\n        groups:             users,docker,video\r\n        plain_text_passwd:  pi\r\n        lock_passwd:        false\r\n        ssh_pwauth:         true\r\n        chpasswd:\r\n            expire:  false\r\n      - name:                 admin\r\n        gecos:                Hypriot Pirate\r\n        sudo:                 ALL=(ALL) NOPASSWD:ALL\r\n        shell:                /bin/bash\r\n        primary-group:        users\r\n        groups:               users,docker,adm,dialout,audio,plugdev,netdev,video\r\n        ssh-import-id:        None\r\n        plain_text_passwd:    pi\r\n        lock_passwd:          true\r\n        ssh_pwauth:           true\r\n        chpasswd:             {expire: false}\r\n        ssh-authorized-keys:\r\n          - ssh-rsa abcdefg1234567890 YOUR_KEY@YOURHOST.local\r\n\r\n",
                "title": "How to convert a json response into yaml in bash"
            },
            {
                "up_vote_count": 9,
                "is_accepted": false,
                "score": 9,
                "last_activity_date": 1572255404,
                "creation_date": 1572255404,
                "answer_id": 58588559,
                "question_id": 53315791,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I&#39;ve used ruby to write my json content into yaml.\r\n\r\nAs for your example, it can be achieved like this:\r\n\r\n    cat $DEFAULTS_FILE | jq .users | ruby -ryaml -rjson -e &#39;puts YAML.dump(JSON.parse(STDIN.read))&#39; &gt; my.yml",
                "title": "How to convert a json response into yaml in bash"
            },
            {
                "up_vote_count": 6,
                "is_accepted": false,
                "score": 5,
                "last_activity_date": 1585044040,
                "last_edit_date": 1585044040,
                "creation_date": 1582633835,
                "answer_id": 60394725,
                "question_id": 53315791,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Another oneliner:\r\n\r\n```bash\r\npython -c &#39;import yaml, sys; print(yaml.dump(yaml.load(open(sys.argv[1])), default_flow_style=False))&#39; input.json\r\n```\r\n(exploiting the fact that valid json is also valid yaml)\r\n\r\nAnd yaml to json:\r\n\r\n```bash\r\npython -c &#39;import yaml, json, sys; print(json.dumps(yaml.load(open(sys.argv[1])), indent=2))&#39; input.yaml\r\n```\r\n\r\n",
                "title": "How to convert a json response into yaml in bash"
            },
            {
                "up_vote_count": 51,
                "is_accepted": false,
                "score": 51,
                "last_activity_date": 1583908524,
                "last_edit_date": 1583908524,
                "creation_date": 1583657771,
                "answer_id": 60585911,
                "question_id": 53315791,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```bash\r\nfunction yaml_validate {\r\n  python -c &#39;import sys, yaml, json; yaml.safe_load(sys.stdin.read())&#39;\r\n}\r\n\r\nfunction yaml2json {\r\n  python -c &#39;import sys, yaml, json; print(json.dumps(yaml.safe_load(sys.stdin.read())))&#39;\r\n}\r\n\r\nfunction yaml2json_pretty {\r\n  python -c &#39;import sys, yaml, json; print(json.dumps(yaml.safe_load(sys.stdin.read()), indent=2, sort_keys=False))&#39;\r\n}\r\n\r\nfunction json_validate {\r\n  python -c &#39;import sys, yaml, json; json.loads(sys.stdin.read())&#39;\r\n}\r\n\r\nfunction json2yaml {\r\n  python -c &#39;import sys, yaml, json; print(yaml.dump(json.loads(sys.stdin.read())))&#39;\r\n}\r\n```\r\n\r\nMore Bash tricks at http://github.com/frgomes/bash-scripts\r\n",
                "title": "How to convert a json response into yaml in bash"
            },
            {
                "up_vote_count": 105,
                "is_accepted": false,
                "score": 104,
                "last_activity_date": 1730613712,
                "last_edit_date": 1730613712,
                "creation_date": 1594224027,
                "answer_id": 62798787,
                "question_id": 53315791,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`yq` ([`mikefarah/yq`][a]) a yaml wrapper for `jq` (not to be confused with [`kislyuk/yq`][b])\r\n\r\n##### With yq 4.18.1+\r\n\r\n```sh\r\ncat &quot;$DEFAULTS_FILE&quot; | yq -P    # or yq --prettyPrint\r\n```\r\n\r\nSee: https://mikefarah.gitbook.io/yq/#notice-for-v4.x-versions-prior-to-4.18.1\r\n\r\n**With yq version 4.8.0:**\r\n\r\n`cat $DEFAULTS_FILE | yq e -P -`\r\n\r\n * `e` or `eval` handles file separately. `ea` or `eval-all` will merge files first.\r\n * `-P` or `--prettyPrint` YAML output\r\n* `-` from STDIN\r\n\r\n*Note: you can go the other way (yaml to json) too `yq e -j file.yaml`*\r\n\r\n**With yq version 3.3.2:**\r\n\r\n`cat $DEFAULTS_FILE | yq r -P -`\r\n\r\n* `r` read\r\n* `-P` --prettyPrint\r\n* `-` from STDIN\r\n\r\n[a]: https://github.com/mikefarah/yq\r\n[b]: https://github.com/kislyuk/yq",
                "title": "How to convert a json response into yaml in bash"
            },
            {
                "up_vote_count": 14,
                "is_accepted": false,
                "score": 14,
                "last_activity_date": 1607092293,
                "creation_date": 1607092293,
                "answer_id": 65145425,
                "question_id": 53315791,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I suggest using [`yq`](https://github.com/kislyuk/yq) with `-y` option\r\n\r\n```\r\n$ pip3 install yq # requires jq\r\n\r\n$ cat in.json | yq -y\r\nusers:\r\n  - name: pi\r\n    gecos: Hypriot Pirate\r\n    sudo: ALL=(ALL) NOPASSWD:ALL\r\n    shell: /bin/bash\r\n    groups: users,docker,video\r\n    plain_text_passwd: pi\r\n    lock_passwd: &#39;false&#39;\r\n    ssh_pwauth: &#39;true&#39;\r\n    chpasswd:\r\n      expire: false\r\n  - name: admin\r\n    gecos: Hypriot Pirate\r\n    sudo: ALL=(ALL) NOPASSWD:ALL\r\n    shell: /bin/bash\r\n    primary-group: users\r\n    groups: users,docker,adm,dialout,audio,plugdev,netdev,video\r\n    ssh-import-id: None\r\n    plain_text_passwd: pi\r\n    lock_passwd: &#39;true&#39;\r\n    ssh_pwauth: &#39;true&#39;\r\n    chpasswd: &#39;{expire: false}&#39;\r\n    ssh-authorized-keys:\r\n      - ssh-rsa abcdefg1234567890 YOUR_KEY@YOURHOST.local",
                "title": "How to convert a json response into yaml in bash"
            },
            {
                "up_vote_count": 14,
                "is_accepted": false,
                "score": 14,
                "last_activity_date": 1618514034,
                "last_edit_date": 1618514034,
                "creation_date": 1614484947,
                "answer_id": 66405697,
                "question_id": 53315791,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "### `yq eval -P`\r\n\r\nwith [`mikefarah/yq`](https://github.com/mikefarah/yq) version 4.0 (released December 2020), installable via most Unix-like OS package managers: via Homebrew for macOS (`brew install yq`), Debian with `apt` (`apt install yq`), Alpine with `apk` (`apk add yq`), etc.\r\n\r\n\r\nSee [Working with JSON](https://mikefarah.gitbook.io/yq/usage/convert). \r\n\r\n&gt; To read in json, just pass in a json file instead of yaml, it will just work - as json is a subset of yaml. However, you will probably want to use the Style Operator or `--prettyPrint/-P` flag to make look more like an idiomatic yaml document.",
                "title": "How to convert a json response into yaml in bash"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1624906646,
                "last_edit_date": 1624906646,
                "creation_date": 1624904754,
                "answer_id": 68168384,
                "question_id": 53315791,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Solution in jq (without other tools)\r\n====================================\r\n\r\nBased on the code of @Jeff Mercado in this post I added support for multiline strings and escaping for single quotes.\r\n\r\n\r\n```\r\n# purpose: converts Json to Yaml\r\n# remarks:\r\n#   You can use &#39;yq -y&#39; to convert json to yaml, but ...\r\n#     * this function can be used several times within a single jq program\r\n#     * this function may be faster than using yq\r\n#     * maybe yq is not available in your environment\r\n#\r\n# input: any Json\r\n# output: json converted to yaml\r\ndef toYaml:\r\n   def handleMultilineString($level):\r\n      reduce ([match(&quot;\\n+&quot;; &quot;g&quot;)]                       # find groups of &#39;\\n&#39;\r\n              | sort_by(-.offset))[] as $match\r\n             (.; .[0:$match.offset + $match.length] +\r\n                 &quot;\\n\\(&quot;    &quot; * $level)&quot; +               # add one extra &#39;\\n&#39; for every group of &#39;\\n&#39;s. Add indention for each new line\r\n                 .[$match.offset + $match.length:]);\r\n\r\n   def toYamlString($level):\r\n      if type == &quot;string&quot;\r\n      then handleMultilineString($level)\r\n           | sub(&quot;&#39;&quot;; &quot;&#39;&#39;&quot;; &quot;g&quot;)           # escape single quotes\r\n           | &quot;&#39;\\(.)&#39;&quot;                      # wrap in single quotes\r\n      else .\r\n      end;\r\n\r\n   def _toYaml($level):\r\n      (objects | to_entries[] |\r\n          if (.value | type) == &quot;array&quot; then\r\n              &quot;\\(.key):&quot;, (.value | _toYaml($level))\r\n          elif (.value | type) == &quot;object&quot; then\r\n              &quot;\\(.key):&quot;, &quot;\\(&quot;    &quot;)\\(.value | _toYaml($level))&quot;\r\n          else\r\n              &quot;\\(.key): \\(.value | toYamlString($level))&quot;\r\n          end\r\n      )\r\n      // (arrays | select(length &gt; 0)[] | [_toYaml($level)] |\r\n          &quot;  - \\(.[0])&quot;, &quot;\\(&quot;    &quot;)\\(.[1:][])&quot;\r\n      )\r\n      // .;\r\n\r\n   _toYaml(1);\r\n```\r\n\r\n\r\n\r\nExample usage\r\n-------------\r\n\r\n```File &#39;containsMultilineStrings.json&#39;```\r\n\r\n```\r\n{\r\n  &quot;response&quot;: {\r\n    &quot;code&quot;: 200,\r\n    &quot;message&quot;: &quot;greeting\\nthat&#39;s all folks\\n\\n\\n&quot;\r\n  }\r\n}\r\n```\r\n\r\n```jq -r &#39;toYaml&#39; &lt; containsMultilineStrings.json```\r\n\r\n```\r\nresponse:\r\n    code: 200\r\n    message: &#39;greeting\r\n\r\n    that&#39;&#39;s all folks\r\n\r\n\r\n\r\n    &#39;\r\n```\r\n\r\n```jq -r &#39;toYaml&#39; containsMultilineStrings.json | yq``` (roundtrip)\r\n\r\n```\r\n{\r\n  &quot;response&quot;: {\r\n    &quot;code&quot;: 200,\r\n    &quot;message&quot;: &quot;greeting\\nthat&#39;s all folks\\n\\n\\n&quot;\r\n  }\r\n}\r\n```\r\n\r\n\r\nTest\r\n----\r\nYou can test the correctness of the function ```toYaml``` by converting json to yaml and than back to json using yq.\r\n\r\n```FILE=&#39;containsMultilineStrings.json&#39;; diff &lt;(cat &quot;$FILE&quot;) &lt;(jq -r &#39;toYaml&#39; $FILE | yq)```\r\n\r\n\r\n\r\nPerformance\r\n-----------\r\nA quick benchmark shows a reduced runtime of the function ```toYaml``` compared to the use of yq.\r\nOn my computer, I measured:\r\n\r\n```time for i in {1..100}; do yq -y &gt; /dev/null &lt; containsMultilineStrings.json; done```\r\n\r\n&gt; 8.4 sec\r\n\r\n\r\n```time for i in {1..100}; do jq -r &#39;toYaml&#39; &gt; /dev/null containsMultilineStrings.json; done```\r\n\r\n&gt; 3.4 sec\r\n\r\n",
                "title": "How to convert a json response into yaml in bash"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1638619577,
                "creation_date": 1638619577,
                "answer_id": 70225438,
                "question_id": 53315791,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Another option is to use [gojq][1]. It is a port of jq with support for reading and writing yaml. It can be installed via GitHub releases, homebrew, and zero install. The command for your question would be:\r\n\r\n    cat test.json | gojq --yaml-output &gt; test.yaml\r\n\r\n  [1]: https://github.com/itchyny/gojq",
                "title": "How to convert a json response into yaml in bash"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1659590313,
                "creation_date": 1659590313,
                "answer_id": 73230667,
                "question_id": 53315791,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use the awesome library `yq`\r\n```shell\r\n# install yq on macOS\r\nbrew install yq\r\n```\r\nThen run the following command\r\n```shell\r\ncat file.json | yq -P &gt; file.yml\r\n```\r\nYou can also convert and save a JSON Response into a YAML file, for example:\r\n```shell\r\ncurl https://raw.githubusercontent.com/typicode/demo/master/db.json | yq -P &gt; example.yml\r\n```\r\n",
                "title": "How to convert a json response into yaml in bash"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1735233667,
                "last_edit_date": 1735233667,
                "creation_date": 1731491214,
                "answer_id": 79184288,
                "question_id": 53315791,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "**Echo json to yaml output** with filtering on a Linux/Ubuntu machine:\r\n\r\n    username@host:~$ pip install yq\r\n    # output ommitted for brevity\r\n    username@host:~$ echo &#39;{&quot;this&quot;:{&quot;is&quot;:{&quot;an&quot;:{&quot;example&quot;:{&quot;list1&quot;:[],&quot;list2&quot;:[],&quot;list3&quot;:[]}}}}}&#39; | yq -y .this.is\r\n    an:\r\n      example:\r\n        list1: []\r\n        list2: []\r\n        list3: []\r\n\r\n`echo &#39;your_valid_json&#39; | yq -y .nesting.filter`\r\n\r\n * `-y` to get the yaml representation\r\n * `.nesting.filter` if you want to filter",
                "title": "How to convert a json response into yaml in bash"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1741997536,
                "last_edit_date": 1741997536,
                "creation_date": 1741993366,
                "answer_id": 79510383,
                "question_id": 53315791,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you are on windows or you can&#39;t install the required dependencies but somehow you have docker:\r\n\r\nJust open a shell to the folder with your json files\r\n\r\n```\r\ndocker run --rm -it -v .:/workdir --entrypoint sh  mikefarah/yq\r\n```\r\n\r\nThen convert your json file to yaml with\r\n\r\n```\r\ncat acme.json | yq -P &gt; acme.yaml\r\n```",
                "title": "How to convert a json response into yaml in bash"
            }
        ],
        "is_answered": true,
        "answer_count": 12,
        "score": 71,
        "last_activity_date": 1741997536,
        "creation_date": 1542272758,
        "last_edit_date": 1583908942,
        "question_id": 53315791,
        "body_markdown": "I read data from a json file with jq. I wanna append the results into a yaml file, but I dont get it working. I am quite new to shell programming. My goal is to append that &quot;users&quot; to an existing &quot;users&quot;-Array in a yaml file.\r\n\r\nThis is my json file:\r\n\r\n    #$DEFAULTS_FILE\r\n\r\n    {&quot;users&quot;:\r\n      [\r\n        {&quot;name&quot;:&quot;pi&quot;,\r\n          &quot;gecos&quot;: &quot;Hypriot Pirate&quot;,\r\n          &quot;sudo&quot;:&quot;ALL=(ALL) NOPASSWD:ALL&quot;,\r\n          &quot;shell&quot;: &quot;/bin/bash&quot;,\r\n          &quot;groups&quot;:&quot;users,docker,video&quot;,\r\n          &quot;plain_text_passwd&quot;:&quot;pi&quot;,\r\n          &quot;lock_passwd&quot;:&quot;false&quot;,\r\n          &quot;ssh_pwauth&quot;:&quot;true&quot;,\r\n          &quot;chpasswd&quot;: {&quot;expire&quot;: false}\r\n        },\r\n        {&quot;name&quot;:&quot;admin&quot;,\r\n          &quot;gecos&quot;: &quot;Hypriot Pirate&quot;,\r\n          &quot;sudo&quot;:&quot;ALL=(ALL) NOPASSWD:ALL&quot;,\r\n          &quot;shell&quot;: &quot;/bin/bash&quot;,\r\n          &quot;primary-group&quot;: &quot;users&quot;,\r\n          &quot;groups&quot;:&quot;users,docker,adm,dialout,audio,plugdev,netdev,video&quot;,\r\n          &quot;ssh-import-id&quot;:&quot;None&quot;,\r\n          &quot;plain_text_passwd&quot;:&quot;pi&quot;,\r\n          &quot;lock_passwd&quot;:&quot;true&quot;,\r\n          &quot;ssh_pwauth&quot;:&quot;true&quot;,\r\n          &quot;chpasswd&quot;: &quot;{expire: false}&quot;,\r\n          &quot;ssh-authorized-keys&quot;: [&quot;ssh-rsa abcdefg1234567890 YOUR_KEY@YOURHOST.local&quot;]\r\n        }\r\n      ]\r\n      }\r\n  \r\n\r\nI filter it with that:\r\n\r\n`cat $DEFAULTS_FILE | jq .users`\r\n\r\nI have no clue how to convert that json into a yaml.\r\n\r\nMy expected result should be:\r\n\r\n\r\n    users:\r\n      - name:                pi\r\n        gecos:               &quot;Hypriot Pirate&quot;\r\n        sudo:                ALL=(ALL) NOPASSWD:ALL\r\n        shell:               /bin/bash\r\n        groups:              users,docker,video\r\n        plain_text_passwd:   pi\r\n        lock_passwd:         false\r\n        ssh_pwauth:          true\r\n        chpasswd: { expire:  false }\r\n      - name:                admin\r\n        primary-group:       users\r\n        shell:               /bin/bash\r\n        sudo:                ALL=(ALL) NOPASSWD:ALL\r\n        groups:              users,docker,adm,dialout,audio,plugdev,netdev,video\r\n        ssh-import-id:       None\r\n\r\n\r\nI tried to use a second tool called `yq` which is similar to `jq` and can write yaml files. But I have no positive progress.\r\n\r\n*EDIT*\r\n\r\nI know that I can add content to the yaml with that:\r\n\r\n`yq w -i &quot;my.yml&quot; &quot;users[+]&quot; &quot;some content&quot;`\r\n\r\nBut I dont know how to merge my json into that.\r\n\r\nAny help or hint would be nice, thank you in advance...",
        "link": "https://stackoverflow.com/questions/53315791/how-to-convert-a-json-response-into-yaml-in-bash",
        "title": "How to convert a json response into yaml in bash"
    },
    {
        "tags": [
            "python",
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1542368370,
                "post_id": 53337072,
                "comment_id": 93552968,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1542369055,
                "last_edit_date": 1542369055,
                "creation_date": 1542368625,
                "answer_id": 53337202,
                "question_id": 53337072,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use jq&#39;s `keys` functionality\r\n\r\n    jq &#39;keys&#39; file.json\r\n\r\nIn the future try to improve on which words you use to describe the different parts the json data. You asked about objects in the text, but actually refer to the keys.\r\n\r\nA more fitting title for the question would have been: &quot;How to get all top level keys of json data using jq?&quot; And with this, more correct, wording you find already answered questions like this one: https://stackoverflow.com/questions/23118341/how-to-get-key-names-from-json-using-jq\r\n\r\nAlso provide a complete and valid example structure and the expected result like this:\r\n\r\n    {\r\n      &quot;one_key&quot;: {\r\n        &quot;foo&quot;: &quot;bar&quot;\r\n      },\r\n      &quot;another_one&quot;: {\r\n        &quot;bla&quot;: &quot;bla&quot;\r\n      }\r\n    }\r\n\r\nAnd desired result:\r\n\r\n    [\r\n      &quot;another_one&quot;,\r\n      &quot;one_key&quot;\r\n    ]",
                "title": "How do I get all first objects of my json using jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1542369055,
        "creation_date": 1542368147,
        "question_id": 53337072,
        "body_markdown": "I would like to get first objects (don&#39;t know if it&#39;s the right name) of my json file that is huge (more than 120k lines), so I can&#39;t parse it manually.\r\n\r\nFormat is like this :\r\n\r\n    &quot;datanode&quot;: [\r\n        {\r\n            &quot;isWhitelisted&quot;: true,\r\n            &quot;metricname&quot;: &quot;write_time&quot;,\r\n            &quot;seriesStartTime&quot;: 1542037566944,\r\n            &quot;supportsAggregation&quot;: true\r\n        },\r\n        {\r\n            &quot;isWhitelisted&quot;: true,\r\n            &quot;metricname&quot;: &quot;dfs.datanode.CacheReportsNumOps&quot;,\r\n            &quot;seriesStartTime&quot;: 1542037501137,\r\n            &quot;supportsAggregation&quot;: true,\r\n            &quot;type&quot;: &quot;COUNTER&quot;\r\n        },\r\n        {\r\n            &quot;isWhitelisted&quot;: true,\r\n            &quot;metricname&quot;: &quot;FSDatasetState.org.apache.hadoop.hdfs.server.datanode.fsdataset.impl.FsDatasetImpl.EstimatedCapacityLostTotal&quot;,\r\n            &quot;seriesStartTime&quot;: 1542037495521,\r\n            &quot;supportsAggregation&quot;: true,\r\n            &quot;type&quot;: &quot;GAUGE&quot;\r\n        },\r\n    ],\r\n        &quot;toto&quot;: [\r\n    ....\r\n\r\nAnd what I need is to extract this : datanode, toto, etc. Only the name.\r\n\r\nCan you help me please ?\r\n\r\nI tried using jq without success.",
        "link": "https://stackoverflow.com/questions/53337072/how-do-i-get-all-first-objects-of-my-json-using-jq",
        "title": "How do I get all first objects of my json using jq?"
    },
    {
        "tags": [
            "json",
            "filter",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1542369885,
                "creation_date": 1542369885,
                "answer_id": 53337556,
                "question_id": 53337311,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I think all you need to do is below. The logic is you need to list all array objects, filter on the rating value to get the subset and print the `tradeId` for those objects\r\n\r\n    jq &#39;.auctionInfo[] | select(.itemData.rating == 84).tradeId&#39;",
                "title": "jq filter objects with specific values and get Id of parent object"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1542369885,
        "creation_date": 1542369002,
        "question_id": 53337311,
        "body_markdown": "Hi I&#39;m playing a bit with jq and have a problem. \r\n\r\nThis is my data:\r\n\r\n    {\r\n    \t&quot;auctionInfo&quot;: [{\r\n    \t\t\t&quot;tradeId&quot;: 229143000306,\r\n    \t\t\t&quot;itemData&quot;: {\r\n    \t\t\t\t&quot;id&quot;: 320854114832,\r\n    \t\t\t\t&quot;rating&quot;: 82\r\n    \t\t\t}\r\n    \t\t},\r\n    \t\t{\r\n    \t\t\t&quot;tradeId&quot;: 229143000307,\r\n    \t\t\t&quot;itemData&quot;: {\r\n    \t\t\t\t&quot;id&quot;: 320854114833,\r\n    \t\t\t\t&quot;rating&quot;: 84\r\n    \t\t\t}\r\n    \t\t},\r\n    \t\t{\r\n    \t\t\t&quot;tradeId&quot;: 229143000308,\r\n    \t\t\t&quot;itemData&quot;: {\r\n    \t\t\t\t&quot;id&quot;: 320854114834,\r\n    \t\t\t\t&quot;rating&quot;: 84\r\n    \t\t\t}\r\n    \t\t}\r\n    \t]\r\n    }\r\n\r\nWhat I now want are alle tradeIds where the rating is 84. \r\n\r\nSo I tried it with this filter:\r\n\r\n    | jq -r .auctionInfo[].itemData | select(.rating==84)\r\n\r\nBut with this filter I&#39;m inside the itemData and have no access to the tradeId which I&#39;m interested for. I&#39;m not really familiar with jq so might be a basic question but how can I reach the tradeId from where I&#39;m standing with this filter?",
        "link": "https://stackoverflow.com/questions/53337311/jq-filter-objects-with-specific-values-and-get-id-of-parent-object",
        "title": "jq filter objects with specific values and get Id of parent object"
    },
    {
        "tags": [
            "json",
            "shell",
            "command-line",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1542530567,
                "last_edit_date": 1542530567,
                "creation_date": 1542383116,
                "answer_id": 53341142,
                "question_id": 53339194,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could patch your query using `if ... then ... else ... end` or perhaps `//`, but it would be better to address some other issues as well, e.g. as follows:\r\n\r\n     .items[]\r\n     | select ( .active == true ) \r\n     | .id + &quot; -&gt; [&quot;\r\n       + (.tags | map(select(.name == &quot;foo&quot;) | .value) | join(&quot;;&quot;))\r\n       + &quot;, &quot;\r\n       + (.tags | map(select(.name == &quot;bar&quot;) | .value) | join(&quot;;&quot;))\r\n       + &quot;]&quot;\r\n\r\nWith jq version 1.5 or earlier, you would need to add a call to `tostring`, or to use string interpolation, e.g.\r\n\r\n       .items[]\r\n       | select ( .active == true ) \r\n       | .id \r\n         + &quot; -&gt; [\\(.tags | map(select(.name == &quot;foo&quot;) | &quot;\\(.value)&quot;) | join(&quot;;&quot;) ), &quot;\r\n         +      &quot;\\(.tags | map(select(.name == &quot;bar&quot;) | &quot;\\(.value)&quot; ) | join(&quot;;&quot;))&quot;\r\n         + &quot;]&quot;\r\n\r\n\r\n## Variant using `first` and string interpolation\r\n\r\n    .items[]\r\n    | select ( .active == true )\r\n    | (first(.tags[] | select(.name == &quot;foo&quot;) | .value) // &quot;&quot;)  as $v\r\n    | (first(.tags[] | select(.name == &quot;bar&quot;) | .value) // &quot;&quot;)  as $w\r\n    | &quot;\\(.id) -&gt; [\\($v), \\($w)]&quot;\r\n\r\nUsing string interpolation circumvents the potential need to use `tostring`.\r\n",
                "title": "in jq, can a select be optional (i.e. if nothing found - don&#39;t filter out the element)"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1542530567,
        "creation_date": 1542376311,
        "question_id": 53339194,
        "body_markdown": "I&#39;m using JQ to filter a list of things, and then for each found thing - reformat it to a single string by extracting values from sub-keys.\r\n\r\nThe problem is that is one of the sub-keys is missing, the entire line is omitted.\r\n\r\nConsider the following example document:\r\n\r\n    {\r\n      &quot;items&quot;: [\r\n        {\r\n          &quot;id&quot;: &quot;A&quot;,\r\n          &quot;active&quot;: true,\r\n          &quot;tags&quot;: [\r\n            { &quot;name&quot;: &quot;foo&quot;, &quot;value&quot;: 1 }\r\n          ]\r\n        },\r\n        {\r\n          &quot;id&quot;: &quot;B&quot;,\r\n          &quot;active&quot;: true,\r\n          &quot;tags&quot;: [\r\n            { &quot;name&quot;: &quot;foo&quot;, &quot;value&quot;:1 },\r\n            {&quot;name&quot;: &quot;bar&quot;, &quot;value&quot;:2}\r\n          ]\r\n        },\r\n        {\r\n          &quot;id&quot;: &quot;C&quot;,\r\n          &quot;active&quot;: false,\r\n          &quot;tags&quot;: [\r\n            { &quot;name&quot;: &quot;foo&quot;, &quot;value&quot;:1 },\r\n            { &quot;name&quot;: &quot;baz&quot;, &quot;value&quot;:3 }\r\n          ]\r\n        }\r\n      ]\r\n    }\r\n\r\nNow I want to select all active items, and create for each a single line describing the item&#39;s ID as well as the value of both its `foo` and `bar` tags.\r\n\r\nInitially I&#39;ve done something like this:\r\n\r\n    jq -r &#39;\r\n       .items[] | \r\n       select ( .active == true ) | \r\n       ( .id + &quot; -&gt; [&quot; + \r\n         ( .tags[] | select( .name == &quot;foo&quot; ) | .value | tostring ) +\r\n         &quot;, &quot; +\r\n         ( .tags[] | select( .name == &quot;bar&quot; ) | .value | tostring ) +\r\n         &quot;]&quot;\r\n       )\r\n    &#39;\r\n\r\nBut because `bar` is only included in item `B`, the line for item `A` gets filtered out.\r\n\r\nIs there a way to make the sub-select optional so that if the select fails, I get an empty string or something like that?",
        "link": "https://stackoverflow.com/questions/53339194/in-jq-can-a-select-be-optional-i-e-if-nothing-found-dont-filter-out-the-el",
        "title": "in jq, can a select be optional (i.e. if nothing found - don&#39;t filter out the element)"
    },
    {
        "tags": [
            "json",
            "bash",
            "file",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1542601780,
                "post_id": 53339451,
                "comment_id": 93613110,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1542390925,
                "creation_date": 1542390925,
                "answer_id": 53343072,
                "question_id": 53339451,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "First of all your `JSON` is not valid, you have an extra comma `,` at the end, change it to be:\r\n\r\n    {\r\n    \t&quot;fileMetadata&quot;: {\r\n    \t\t&quot;ref_Version&quot;: &quot;125&quot;\r\n    \t}\r\n    }\r\n\r\nWith your `jq` command you never specify the sub-key to return the value, it should be:\r\n\r\n    jq &#39;.fileMetadata.ref_Version&#39; re.json\r\n\r\n**Output:**\r\n\r\n    &quot;125&quot;",
                "title": "How to read a .json file from a remote server SSH with a shell script"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1542602220,
                "last_edit_date": 1542602220,
                "creation_date": 1542601904,
                "answer_id": 53368352,
                "question_id": 53339451,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Consider running `jq` *locally*, instead of on the other side of SSH:\r\n\r\n    #!/usr/bin/env bash\r\n    set -o pipefail  # consider it a failure if any part of a pipeline fails.\r\n\r\n    getJson() {\r\n      local address filename_q\r\n      address=$1\r\n      printf -v filename_q &#39;%q&#39; &quot;$2&quot;\r\n      ssh \\\r\n        -o UserKnownHostsFile=/dev/null \\\r\n        -o StrictHostKeyChecking=no \\\r\n        -i /home/.ssh/cloud_private_key \\\r\n        &quot;$address&quot; &quot;cat $filename_q&quot;\r\n    }\r\n    \r\n    if databaseName=$(getJson user@address /data/Doc1/re.json \\\r\n                      | jq -r &#39;.fileMetadata.ref_Version&#39;); then\r\n      echo &quot;Hello $databaseName&quot;\r\n    else\r\n      echo &quot;Unable to retrieve or parse JSON&quot; &gt;&amp;2\r\n    fi\r\n\r\nSimilarly, [as noted by l&#39;L&#39;l](https://stackoverflow.com/a/53343072/14122), your JSON needs some fixes to be well-formed. `{ &quot;fileMetadata&quot;: { &quot;ref_Version&quot;: &quot;125&quot; } }` is a valid reformulation.",
                "title": "How to read a .json file from a remote server SSH with a shell script"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1542602220,
        "creation_date": 1542377288,
        "last_edit_date": 1542601595,
        "question_id": 53339451,
        "body_markdown": "I have a json file on a distant server and i want to read data from it using a shell script , i&#39;ve tried the code below but it did not work ; \r\n\r\n    #!/usr/bin/env bash\r\n    #!/usr/bin/sh\r\n\r\n    echo &quot;hey&quot;\r\n   \r\n\r\n    ssh -o UserKnownHostsFile=/dev/null -o StrictHostKeyChecking=no -i \r\n    /home/.ssh/cloud_private_key user@adresse &lt;&lt; EOF\r\n\r\n    script\r\n    cd /data/Doc1/\r\n    databasename=`jq &#39;.ref_Version&#39; re.json`\r\n    echo &quot;hello $databasename&quot;\r\n    EOF\r\n\r\nThe json file contains \r\n\r\n     {\r\n     &quot;fileMetadata&quot; : {\r\n     &quot;ref_Version&quot; : &quot;125&quot;,}\r\n     }\r\n\r\n\r\nI get :\r\n\r\n    hey\r\n    [user@adresse ~]$ [user@adresse data]$ [user@adresse Doc1]$ \r\n     hello \r\n    [user@adresse ~]$ [user@adresse data]$ [user@adresse Doc1]$ hey22\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/53339451/how-to-read-a-json-file-from-a-remote-server-ssh-with-a-shell-script",
        "title": "How to read a .json file from a remote server SSH with a shell script"
    },
    {
        "tags": [
            "json",
            "jq",
            "pretty-print"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1542407043,
                "creation_date": 1542407043,
                "answer_id": 53346207,
                "question_id": 53346007,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This:\r\n\r\n    echo &#39;{&quot;foo&quot;: &quot;bar&quot;}&#39; | jq &#39;{other: .}&#39; | jq -Rs &#39;{json: .}&#39;\r\n\r\nproduces:\r\n\r\n    {\r\n      &quot;json&quot;: &quot;{\\n  \\&quot;other\\&quot;: {\\n    \\&quot;foo\\&quot;: \\&quot;bar\\&quot;\\n  }\\n}\\n&quot;\r\n    }\r\n\r\nOne way to remove the terminating `&quot;\\n&quot;` would be to strip it:\r\n\r\n    echo &#39;{&quot;foo&quot;: &quot;bar&quot;}&#39; | jq &#39;{other: .}&#39; | jq -Rs &#39;{json: .[:-1]}&#39;\r\n\r\n",
                "title": "How to pretty print a JSON inside a string with jq?"
            },
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1542571743,
                "creation_date": 1542571743,
                "answer_id": 53364970,
                "question_id": 53346007,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I ended up writing a simple formatting function:\r\n\r\n    #   9 = \\t\r\n    #  10 = \\n\r\n    #  13 = \\r\r\n    #  32 = (space)\r\n    #  34 = &quot;\r\n    #  44 = ,\r\n    #  58 = :\r\n    #  91 = [\r\n    #  92 = \\\r\n    #  93 = ]\r\n    # 123 = {\r\n    # 125 = }\r\n    \r\n    def pretty:\r\n      explode | reduce .[] as $char (\r\n        {out: [], indent: [], string: false, escape: false};\r\n        if .string == true then\r\n          .out += [$char]\r\n          | if $char == 34 and .escape == false then .string = false else . end\r\n          | if $char == 92 and .escape == false then .escape = true else .escape = false end\r\n        elif $char == 91 or $char == 123 then\r\n          .indent += [32, 32] | .out += [$char, 10] + .indent\r\n        elif $char == 93 or $char == 125 then\r\n          .indent = .indent[2:] | .out += [10] + .indent + [$char]\r\n        elif $char == 34 then\r\n          .out += [$char] | .string = true\r\n        elif $char == 58 then\r\n          .out += [$char, 32]\r\n        elif $char == 44 then\r\n          .out += [$char, 10] + .indent\r\n        elif $char == 9 or $char == 10 or $char == 13 or $char == 32 then\r\n          .\r\n        else\r\n          .out += [$char]\r\n        end\r\n      ) | .out | implode;\r\n\r\nIt adds unnecessary empty lines inside empty objects and arrays, but it&#39;s good enough for my purpose. For example (used on its own):\r\n\r\n    jq -Rr &#39;include &quot;pretty&quot;; pretty&#39; test.json\r\n\r\nwhere the function is saved in `pretty.jq` and `test.json` file is:\r\n\r\n    {&quot;type&quot;:&quot;FeatureCollection&quot;,&quot;features&quot;:[{&quot;type&quot;:&quot;Feature&quot;,&quot;properties&quot;:{&quot;key&quot;:&quot;string with \\&quot;quotes\\&quot; and \\\\&quot;},&quot;geometry&quot;:{&quot;type&quot;:&quot;Polygon&quot;,&quot;coordinates&quot;:[[[24.2578125,55.178867663281984],[22.67578125,50.958426723359935],[28.125,50.62507306341435],[30.322265625000004,53.80065082633023],[24.2578125,55.178867663281984]]]}}]}\r\n\r\ngives:\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;key&quot;: &quot;string with \\&quot;quotes\\&quot; and \\\\&quot;\r\n          },\r\n          &quot;geometry&quot;: {\r\n            &quot;type&quot;: &quot;Polygon&quot;,\r\n            &quot;coordinates&quot;: [\r\n              [\r\n                [\r\n                  24.2578125,\r\n                  55.178867663281984\r\n                ],\r\n                [\r\n                  22.67578125,\r\n                  50.958426723359935\r\n                ],\r\n                [\r\n                  28.125,\r\n                  50.62507306341435\r\n                ],\r\n                [\r\n                  30.322265625000004,\r\n                  53.80065082633023\r\n                ],\r\n                [\r\n                  24.2578125,\r\n                  55.178867663281984\r\n                ]\r\n              ]\r\n            ]\r\n          }\r\n        }\r\n      ]\r\n    }",
                "title": "How to pretty print a JSON inside a string with jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 4,
        "last_activity_date": 1542571743,
        "creation_date": 1542405628,
        "last_edit_date": 1542445440,
        "question_id": 53346007,
        "body_markdown": "I&#39;m writing a more complex transformation with jq, and one of the things I&#39;d like to do is to have a pretty printed JSON inside a string. For example:\r\n\r\n    echo &#39;{&quot;foo&quot;: &quot;bar&quot;}&#39; | jq &#39;{json: {other: .} | tostring}&#39;\r\n\r\ngives\r\n\r\n    {\r\n      &quot;json&quot;: &quot;{\\&quot;other\\&quot;:{\\&quot;foo\\&quot;:\\&quot;bar\\&quot;}}&quot;\r\n    }\r\n\r\nwhile I&#39;d like to get:\r\n\r\n    {\r\n      &quot;json&quot;: &quot;{\\n  \\&quot;other\\&quot;: {\\n    \\&quot;foo\\&quot;: \\&quot;bar\\&quot;\\n  }\\n}&quot;\r\n    }\r\n\r\nI have also tried `tojson` and `@json`, but they give the same result as `tostring`. Is it possible to do with jq or do I have to resort to some other trickery? Note that I need to have multiple such string with formatted JSON in the output, not just one like in the example.",
        "link": "https://stackoverflow.com/questions/53346007/how-to-pretty-print-a-json-inside-a-string-with-jq",
        "title": "How to pretty print a JSON inside a string with jq?"
    },
    {
        "tags": [
            "json",
            "unicode",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1542529804,
                "post_id": 53352558,
                "comment_id": 93595077,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1747662937,
                "last_edit_date": 1747662937,
                "creation_date": 1542494054,
                "answer_id": 53356177,
                "question_id": 53352558,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s verification that `\\u2022` is properly handled by various versions of jq in a Mac environment:\r\n\r\n    $ echo &#39;&quot;\\u2022&quot;&#39; | jq-1.4 .\r\n    &quot;•&quot;\r\n    $ echo &#39;&quot;•&quot;&#39; | jq-1.6 .\r\n    &quot;•&quot;\r\n    $ echo &#39;&quot;•&quot;&#39; | jq-1.5 .\r\n    &quot;•&quot;\r\n    $ echo &#39;&quot;•&quot;&#39; | jq-1.4 .\r\n    &quot;•&quot;\r\n    $ \r\n\r\nPerhaps the problem is related to a bug that was fixed since the release of jq 1.5 (see e.g. https://github.com/stedolan/jq/issues/1311).",
                "title": "JQ can&#39;t parse \\u2022 character"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1747662937,
        "creation_date": 1542467869,
        "last_edit_date": 1542509710,
        "question_id": 53352558,
        "body_markdown": "I&#39;m trying to perform a bulk upload to Elasticsearch (around 1mln documents). In order to do that, I&#39;m using jq to reformat the JSON file extracted from MySQL database and curl to post the data to Elasticsearch:\r\n\r\n    cat dataset.json | jq -r -c &#39;.[] | { &quot;index&quot; : { } }, .&#39; | curl -u login:password -H &quot;Content-Type: application/json&quot; -XPOST &quot;https://.../skills/default/_bulk?pretty&quot; --data-binary @-\r\n\r\n\r\nI get an error:\r\n\r\n&gt; parse error: Invalid string: control characters from U+0000 through U+001F must be escaped at line 276249, column 317\r\n\r\nI found that the character that jq can&#39;t parse is \\u2022. I tried adding &quot;-r&quot; jq command but the error stil occurs. How can I handle this for all occurrences of \\u2022?\r\n",
        "link": "https://stackoverflow.com/questions/53352558/jq-cant-parse-u2022-character",
        "title": "JQ can&#39;t parse \\u2022 character"
    },
    {
        "tags": [
            "shell",
            "unix",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 7681744,
                    "reputation": 34126,
                    "user_id": 5820814,
                    "user_type": "registered",
                    "accept_rate": 43,
                    "profile_image": "https://graph.facebook.com/1240609682619989/picture?type=large",
                    "display_name": "Mayank Porwal",
                    "link": "https://stackoverflow.com/users/5820814/mayank-porwal"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1542607577,
                "post_id": 53369090,
                "comment_id": 93614555,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3892995,
                    "reputation": 242,
                    "user_id": 3222718,
                    "user_type": "registered",
                    "accept_rate": 85,
                    "profile_image": "https://www.gravatar.com/avatar/bb9d1c1fec8c2a0f383c5a0b06174c76?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "user3222718",
                    "link": "https://stackoverflow.com/users/3222718/user3222718"
                },
                "reply_to_user": {
                    "account_id": 7681744,
                    "reputation": 34126,
                    "user_id": 5820814,
                    "user_type": "registered",
                    "accept_rate": 43,
                    "profile_image": "https://graph.facebook.com/1240609682619989/picture?type=large",
                    "display_name": "Mayank Porwal",
                    "link": "https://stackoverflow.com/users/5820814/mayank-porwal"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1542608073,
                "post_id": 53369090,
                "comment_id": 93614697,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 7681744,
                    "reputation": 34126,
                    "user_id": 5820814,
                    "user_type": "registered",
                    "accept_rate": 43,
                    "profile_image": "https://graph.facebook.com/1240609682619989/picture?type=large",
                    "display_name": "Mayank Porwal",
                    "link": "https://stackoverflow.com/users/5820814/mayank-porwal"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1542608741,
                "post_id": 53369090,
                "comment_id": 93614898,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3892995,
                    "reputation": 242,
                    "user_id": 3222718,
                    "user_type": "registered",
                    "accept_rate": 85,
                    "profile_image": "https://www.gravatar.com/avatar/bb9d1c1fec8c2a0f383c5a0b06174c76?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "user3222718",
                    "link": "https://stackoverflow.com/users/3222718/user3222718"
                },
                "reply_to_user": {
                    "account_id": 7681744,
                    "reputation": 34126,
                    "user_id": 5820814,
                    "user_type": "registered",
                    "accept_rate": 43,
                    "profile_image": "https://graph.facebook.com/1240609682619989/picture?type=large",
                    "display_name": "Mayank Porwal",
                    "link": "https://stackoverflow.com/users/5820814/mayank-porwal"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1542609133,
                "post_id": 53369090,
                "comment_id": 93615006,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1542611419,
                "post_id": 53369090,
                "comment_id": 93615717,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1542613565,
                "last_edit_date": 1542613565,
                "creation_date": 1542609647,
                "answer_id": 53369518,
                "question_id": 53369090,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Your json still shows as invalid. Anyhow, I&#39;m attaching a sample json and how to extract it through `jq`. Please see below:\r\n\r\n    ~$ cat n1.json\r\n    [  \r\n       {  \r\n          &quot;name&quot;:&quot;sandboxserver.tar.gz.part-aa&quot;,\r\n          &quot;hash&quot;:&quot;010d126f8ccf199f3cd5f468a90d5ae1&quot;,\r\n          &quot;bytes&quot;:4294967296,\r\n          &quot;last_modified&quot;:&quot;2018-10-10T01:32:00.069000&quot;,\r\n          &quot;content_type&quot;:&quot;binary/octet-stream&quot;\r\n       },\r\n       {  \r\n          &quot;name&quot;:&quot;sandboxserver.tar.gz.part-ab&quot;,\r\n          &quot;hash&quot;:&quot;49a6f22068228f51488559c096aa06ce&quot;,\r\n          &quot;bytes&quot;:397973601,\r\n          &quot;last_modified&quot;:&quot;2018-10-10T01:32:22.395000&quot;,\r\n          &quot;content_type&quot;:&quot;binary/octet-stream&quot;\r\n       },\r\n       {  \r\n          &quot;name&quot;:&quot;sandboxserver.tar.gz.part-ac&quot;,\r\n          &quot;hash&quot;:&quot;2c5e845f46357e203214592332774f4c&quot;,\r\n          &quot;bytes&quot;:5179281858,\r\n          &quot;last_modified&quot;:&quot;2018-10-11T08:20:11.566000&quot;,\r\n          &quot;content_type&quot;:&quot;binary/octet-stream&quot;\r\n       }\r\n    ]\r\n    \r\nAnd then used jq to find the names:\r\n    \r\n    ~$ jq -r &#39;.[].name&#39; n1.json\r\n    sandboxserver.tar.gz.part-aa\r\n    sandboxserver.tar.gz.part-ab\r\n    sandboxserver.tar.gz.part-ac\r\n\r\nLet me know if this helps.",
                "title": "How to use jq to fetch attribute from json"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -3,
        "last_activity_date": 1605205460,
        "creation_date": 1542607262,
        "last_edit_date": 1605205460,
        "question_id": 53369090,
        "body_markdown": "I have written a bash file to fetch an attribute value from a json. But it says data not shown. Not sure how to make jq work in my linux box. Can some one please help. \r\n\r\n   \r\n\r\n     curl -v -H &quot;Content-Type: application/json&quot;  -X GET  &#39;URL&#39;  &gt; myFile.json\r\n     \r\n        cat myFile.json | jq &#39;.offerVerticalMap[&quot;GROCERIES.offerPublishStatus&quot;]&#39;\r\n\r\nin myFile.json the json is getting created but am unable to pull the attribute value.\r\n\r\nplease can someone look into this at the earliest?\r\n\r\nThanks ",
        "link": "https://stackoverflow.com/questions/53369090/how-to-use-jq-to-fetch-attribute-from-json",
        "title": "How to use jq to fetch attribute from json"
    },
    {
        "tags": [
            "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": 1542658500,
                "post_id": 53381867,
                "comment_id": 93639777,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1542661699,
                "creation_date": 1542661699,
                "answer_id": 53382649,
                "question_id": 53381867,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "As noted in a comment, jq&#39;s treatment of `.[] |= empty` has varied over time.  One might expect that for every array, A, `A | (.[] |= empty)` would yield `[]` on the theory that the expression should result in every item in A being replaced by `empty`.\r\n\r\nIn any case, the current (jq 1.6) implementation is clearly wrong, as is particularly noticeable in this example:\r\n\r\n    jq-1.6 -n  &#39;[0,1,2,3] | (.[] |= if . == 2 then empty else . end)&#39;\r\n    [\r\n      0,\r\n      1,\r\n      3,\r\n      null\r\n    ]\r\n\r\nBug reports can be submitted to https://github.com/stedolan/jq/issues",
                "title": "puzzling behavior of `.[]|=empty`"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1542661699,
        "creation_date": 1542657931,
        "question_id": 53381867,
        "body_markdown": "As far as I understand, the use of `empty` in update-assignment `|=` deletes the entry, similar to `del(path)`, and `del(path)` also works in arrays.\r\n\r\nI tried to selectively delete and modify array entries, and got strange results. While trying to understand the problem, I minimized the code to this:\r\n\r\n**Filter**: `.[]|=empty`   \r\n**Input**: `[0,1,2,3,4,5]`   \r\n**Output**:   \r\n`[\r\n  1,\r\n  3,\r\n  5\r\n]`\r\n\r\nTry it online [here][1]\r\n\r\nApparently, only even array indexes are deleted. Why?\r\n\r\n\r\n  [1]: https://jqplay.org/s/rBMHdN4H0w",
        "link": "https://stackoverflow.com/questions/53381867/puzzling-behavior-of-empty",
        "title": "puzzling behavior of `.[]|=empty`"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1542684864,
                "last_edit_date": 1542684864,
                "creation_date": 1542666125,
                "answer_id": 53383499,
                "question_id": 53383105,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "According to what&#39;s posted, the output of the curl command is so weird that it would require special processing.  Chances are the output is not as weird as shown, and the `sed` command shown as part of the solution below might need tweaking.\r\n\r\nIn any case, with the input as shown:\r\n\r\n    sed &#39;s/\\\\&quot;/&quot;/;1s/\\\\n/,/&#39; input.txt | jq &#39;\r\n      .[0] as $h\r\n      | .[1] \r\n      | . as $in\r\n      | reduce range(0;length) as $i\r\n          ({}; .[$h[$i]] = $in[$i])&#39;\r\n \r\nproduces the desired output.\r\n\r\n## One-stop shopping\r\n\r\n    jq -Rs &lt; input.txt &#39;\r\n      split(&quot;\\n&quot;)\r\n      | map(select(length&gt;0))\r\n      | ( .[0] | sub(&quot;[[]\\\\\\\\&quot;; &quot;&quot;) | sub(&quot;\\\\\\\\n&quot;; &quot;&quot;) | fromjson) as $h\r\n      | .[1]\r\n      | sub(&quot;\\\\]\\\\]&quot;; &quot;]&quot;)\r\n      | fromjson\r\n      | . as $in\r\n      | reduce range(0;length) as $i\r\n          ({}; .[$h[$i]] = $in[$i])&#39;\r\n\r\n\r\n",
                "title": "Turning list of headers and list of values into valid json with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1542697248,
        "creation_date": 1542664035,
        "last_edit_date": 1542697248,
        "question_id": 53383105,
        "body_markdown": "I&#39;m working with an endpoint like this:\r\n\r\n    curl -S www.example.com \r\n    [[\\&quot;A&quot;, &quot;B&quot;, &quot;C&quot;, &quot;D&quot;]\\n\r\n    [&quot;1&quot;,&quot;2&quot;,null,&quot;4&quot;]]\r\n\r\nI&#39;d like to use jq to change this response into proper json rather than a list of headers and a row of data corresponding to the items in the list:\r\n\r\n    {&quot;A&quot;: &quot;1&quot;, &quot;B&quot;: &quot;2&quot;, &quot;C&quot; : null, &quot;D&quot;: &quot;4&quot;}\r\n\r\nHowever, what seems like the obvious answer from [here][1]\r\n\r\nof\r\n\r\n    curl -S www.example.com  | jq &#39;{(.[0]) : .[1] }&#39;\r\n\r\nproduces\r\n\r\n    jq: error (at &lt;stdin&gt;:1): Cannot use array ([&quot;A...) as object key\r\n\r\nAnd \r\n\r\n    curl -S www.example.com  | jq &#39;{.[0] : .[1] }&#39;\r\n\r\nproduces\r\n\r\n    jq: error: syntax error, unexpected &#39;.&#39; (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n    {.[0] : .[1] } \r\n    jq: 1 compile error\r\n\r\nWhat&#39;s the right syntax for \r\n\r\n    [[HEADER1,HEADER2,...]\\n\r\n    [DATA1,DATA2]] \r\n\r\nresponses into json?\r\n\r\nAre the unquoted null and the newline the source of my problem?\r\n\r\n  [1]: https://stackoverflow.com/a/43729713/1052117\r\n\r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/53383105/turning-list-of-headers-and-list-of-values-into-valid-json-with-jq",
        "title": "Turning list of headers and list of values into valid json with jq"
    },
    {
        "tags": [
            "windows",
            "cmd",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1542736791,
                "last_edit_date": 1542736791,
                "creation_date": 1542700060,
                "answer_id": 53388391,
                "question_id": 53387811,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "As explained at https://en.wikibooks.org/wiki/Windows_Batch_Scripting\r\n\r\n&gt; &quot;Unlike shells of some other operating systems, the cmd.exe shell does not perform wildcard expansion&quot;\r\n\r\nSo assuming you can&#39;t simply process the files one at a time, you&#39;ll either have to\r\ncreate the list of files explicitly, or use a different shell.\r\n\r\nFor further details and suggestions, see\r\nhttps://superuser.com/questions/460598/is-there-any-way-to-get-the-windows-cmd-shell-to-expand-wildcard-paths\r\n\r\nand if you’re using Windows 10:\r\n\r\nhttps://www.howtogeek.com/249966/how-to-install-and-use-the-linux-bash-shell-on-windows-10/",
                "title": "Using wildcard for files with jq on Windows"
            },
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1542748326,
                "last_edit_date": 1542748326,
                "creation_date": 1542712389,
                "answer_id": 53391756,
                "question_id": 53387811,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This is a curious problem.\r\n\r\nAs alredy [answered by peak](https://stackoverflow.com/a/53388391/2861476), `cmd.exe` does not expand wildcards, leaving this work to the programs. And `jq` does not handle wildcards (from the issues list, more later). \r\n\r\nBut this is not the full reason for this failure.\r\n\r\nAs the question points, source code fails in an assert: `wargc == argc`. When reading the source code, in windows `jq` tries to process the original command line with \r\n\r\n     wchar_t **wargv = CommandLineToArgvW(GetCommandLineW(), &amp;wargc);\r\n\r\ntrying to retrieve the equivalent to `argv[]` and `argc` but handling multibyte arguments.\r\n\r\nAs `cmd` is not expanding the wildcard there will be three arguments (command line in question)\r\n\r\n    jq  .  *.json\r\n    ^^  ^  ^....^  \r\n    0   1  2      \r\n\r\nboth in `argv[]` and `wargv[]`, so `argc` and `wargc` should match. \r\n\r\nThen, why does it fail? Why `argc` is different to `wargc`?\r\n\r\nBecause GCC was used to compile the program.\r\n\r\nAnd no, the problem is not GCC itself. The &quot;problem&quot; is that the argument handling in GCC runtime DOES expand the wildcard (Microsoft compiler runtime does not, but it doesn&#39;t matter as it will also not solve the problem). \r\n\r\nThat means that `argc` and `argv` (determined by GCC code with wildcard expansion) will contain information according to the number of files matching the wildcard while `wargc` and `wargv` (determined by MS code without wildcard expansion) will not.\r\n\r\nA simple way to probe it is to have only one `.json` file when trying the previous command. The assert will not fail but `jq` will fail with `jq: error: Could not open file *.json: Invalid argument` as it does not handle wildcards.\r\n\r\n    jq . test.json       As seen in argv   argc  = 3\r\n    jq . *.json          As seen in wargv  wargc = 3\r\n\r\nSo, how to deal with it? Without modifying the `jq`&#39;s source code your best option is to concatenate the list of files and pass it to `jq`. [References](https://superuser.com/q/460598) in peak&#39;s answer and in your comment should deal with the problem.\r\n\r\nBut remember that in `cmd` and batch files your command lines are limited to 8191 characters. If it is not enough to deal with your problem you can try with something like (yes, a lot of lines, most of them comments and command usage)\r\n\r\n&lt;!-- language: lang-cmd --&gt;\r\n\r\n    @if (@this==@isBatch) @then /* ------------------------------------- batch code\r\n    @echo off\r\n        setlocal enableextensions disabledelayedexpansion\r\n    \r\n        rem This is an hybrid batch/javascript file. The batch part will retrieve\r\n        rem the required information and start the cscript engine to execute the \r\n        rem javascript part of this file.\r\n        \r\n        rem Retrieve a safe reference to current batch file \r\n        call :getCurrentFile thisFile fileName\r\n    \r\n        rem Arguments to current batch file are the command line to execute later\r\n        rem Using an environment variable to avoid losing quotes when using the\r\n        rem internal Wscript argumeng handling routines\r\n        set [commandLine]=%*\r\n        \r\n        if not defined [commandLine] (\r\n            echo(\r\n            echo usage: command1 ^| &quot;%fileName%&quot; command2\r\n            echo(\r\n            echo where:\r\n            echo     command1   is a command generating a set of lines that will be\r\n            echo                concatenated to pass as arguments to command2\r\n            echo(\r\n            echo     command2   is the command to execute with all the lines from \r\n            echo                command1 as command line arguments\r\n            echo(\r\n            echo examples:\r\n            echo(\r\n            echo    dir /b ^| &quot;%fileName%&quot; cmd /c echo\r\n            echo    dir /b *.json ^| &quot;%fileName%&quot; jq . \r\n            echo(\r\n            goto :eof\r\n        )\r\n        \r\n        rem Execute the javascript part of this script\r\n        &quot;%windir%\\system32\\cscript.exe&quot; //nologo //e:JScript &quot;%thisFile%&quot; \r\n        goto :eof\r\n    \r\n        \r\n    :getCurrentFile fullPath fileName\r\n        set &quot;%~1=%~f0&quot;\r\n        set &quot;%~2=%~nx0&quot;\r\n        goto :eof\r\n    \r\n    ------------------------------------------------------------- end of batch code\r\n    */@end //------------------------------------------------------ javascript code\r\n    \r\n    /*\r\n        This script will read all lines from standard input and execute the \r\n        command stored by the batch code above into the [commandLine] environment \r\n        variable, passing as command lien arguments the concatenation of all lines \r\n        present in the standard input.\r\n    */\r\n    \r\n    var shell = WScript.CreateObject(&#39;WScript.Shell&#39;)\r\n      , commandLine = shell.Environment(&quot;PROCESS&quot;).Item(&#39;[commandLine]&#39;)\r\n      , stdIn = WScript.StdIn\r\n      , stdOut = WScript.StdOut\r\n      , stdErr = WScript.StdErr\r\n      , line = &#39;&#39;\r\n      , buffer = []\r\n      ;\r\n        // read the list of arguments from standard input\r\n        while ( !stdIn.AtEndOfStream ){ \r\n            if ( \r\n                line = stdIn.ReadLine().replace(/&quot;/g, &#39;&#39;) \r\n            ) buffer.push( &#39; &quot;&#39; + line + &#39;&quot;&#39; );\r\n        };\r\n        \r\n        // concatenate all arguments \r\n        buffer = buffer.join(&#39;&#39;);\r\n        \r\n        // if we don&#39;t have a command line, output what we have contatenated \r\n        // but if we have a command line, execute it, get its output and show it\r\n        // as it is possible that we are piping it to another process.\r\n        \r\n        if ( commandLine ){\r\n            try {\r\n                stdOut.WriteLine(\r\n                    shell.Exec( commandLine + buffer ).StdOut.ReadAll()\r\n                );\r\n            } catch ( e ){\r\n                stdErr.WriteLine( &#39;ERROR: Command line exec failed when running:&#39; );\r\n                stdErr.WriteLine( &#39;---------------------------------------------&#39; );\r\n                stdErr.WriteLine( commandLine + buffer );\r\n                stdErr.WriteLine( &#39;---------------------------------------------&#39; );\r\n            };\r\n        } else {\r\n            stdOut.WriteLine( buffer );\r\n        };\r\n\r\n\r\nSave it as a `cmd` file (ex. `list2args.cmd`) and use it as suggested\r\n\r\n    dir /b *.json | list2args.cmd jq .\r\n\r\nThe difference is that doing the concatenation inside the script part and starting the process using the `WScript.Shell.Exec` method we can use command lines up to 32KB (the windows limit for command lines).\r\n",
                "title": "Using wildcard for files with jq on Windows"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1668531301,
                "creation_date": 1668531301,
                "answer_id": 74449427,
                "question_id": 53387811,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "[MC ND](https://stackoverflow.com/users/2861476/mc-nd) gave an amazing explanation [why this happens](https://stackoverflow.com/a/53391756/253468).\r\n\r\nHowever if you just want to make it work, I recommend using [Windows Subsystem for Linux (WSL)](https://learn.microsoft.com/en-us/windows/wsl/install), or [Git Bash](https://gitforwindows.org/). Both of these handle wildcard expansion trivially after initial setup.\r\n\r\n_The return on investment is great because any time you have problems with `cmd` you can just hop over to `bash` and continue._",
                "title": "Using wildcard for files with jq on Windows"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 3,
        "last_activity_date": 1668531301,
        "creation_date": 1542697372,
        "question_id": 53387811,
        "body_markdown": "I am using jq 1.6 on Windows 8.1 and facing same issue as reported here\r\nhttps://github.com/stedolan/jq/issues/1644\r\n\r\nCommand as simple as `jq . *.json` is failing with following error:\r\n\r\n&gt; Assertion failed!\r\n\r\n&gt; Program: jq.exe\r\n&gt; File: src/main.c, Line 256\r\n&gt; Expression: wargc == argc\r\n\r\n&gt;This application has requested the Runtime\r\n&gt; to terminate it in an unusual way. Please contact the application&#39;s\r\n&gt; support team for more information.\r\n\r\nDoes anyone have solution to this? What is the correct way to use `jq` with all the files in the folder on windows?",
        "link": "https://stackoverflow.com/questions/53387811/using-wildcard-for-files-with-jq-on-windows",
        "title": "Using wildcard for files with jq on Windows"
    },
    {
        "tags": [
            "json",
            "grep",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1561641849,
                "last_edit_date": 1561641849,
                "creation_date": 1542728994,
                "answer_id": 53396707,
                "question_id": 53396342,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": " You just have one too many dot\r\n\r\n    jq .posts[].message &lt; jq_dat.json",
                "title": "Parsing a set of JSON objects with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1561641849,
        "creation_date": 1542727819,
        "question_id": 53396342,
        "body_markdown": "A have a big block of JSON l&#39;m trying to parse, that looks basically like \r\n\r\n    {\r\n      &quot;order&quot;: [\r\n        &quot;hash1&quot;,\r\n        &quot;hash2&quot;\r\n      ],\r\n      &quot;posts&quot;: {\r\n        &quot;hash4&quot;: {\r\n          &quot;id&quot;: &quot;hash4&quot;,\r\n          &quot;message&quot;: &quot;lorem ipsem&quot;\r\n        },\r\n        &quot;hash5&quot;: {\r\n          &quot;id&quot;: &quot;hash5&quot;,\r\n          &quot;message&quot;: &quot;dolor sit amet&quot;\r\n        },\r\n        &quot;hash6&quot;: {\r\n          &quot;id&quot;: &quot;hash6&quot;,\r\n          &quot;message&quot;: &quot;consectetur adipiscing elit&quot;\r\n        }\r\n      }\r\n    }\r\n\r\nThe way I&#39;ve been handling this so far is to just grep for messages\r\n\r\n    $ grep &#39;message&#39; jq_dat.json \r\n          &quot;message&quot;: &quot;lorem ipsem&quot;\r\n          &quot;message&quot;: &quot;dolor sit amet&quot;\r\n          &quot;message&quot;: &quot;consectetur adipiscing elit&quot;\r\n\r\nThis works for my current purposes, but l&#39;d like to know how to get the same effect with `jq`. I.e.\r\n\r\n    $ jq .posts.&lt;something&gt;.message &lt; jq_dat.json\r\n    &quot;lorem ipsem&quot;\r\n    &quot;dolor sit amet&quot;\r\n    &quot;consectetur adipiscing elit&quot;\r\n\r\nI&#39;ve tried using `[]` and `{}` in place of `something`, but those both spit back compile errors.",
        "link": "https://stackoverflow.com/questions/53396342/parsing-a-set-of-json-objects-with-jq",
        "title": "Parsing a set of JSON objects with jq"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1542738802,
                "creation_date": 1542738802,
                "answer_id": 53399369,
                "question_id": 53399168,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The following filter produces results in the desired format, but the output marked in the Q as &quot;desired&quot; does not exactly match the given input, which I take to be an oversight.  \r\n\r\n    {repos: map( {(.repo_name): del(.repo_name)} )}",
                "title": "jq: output json array of objects to array of keys with objects"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1542738802,
        "creation_date": 1542737972,
        "question_id": 53399168,
        "body_markdown": "Im looking to reformat some json using jq instead of using Python. I have the following json array of objects. I am looking to change this to an array of keys. The values of the keys should be the object.\r\n\r\n    [{\r\n    \t\t&quot;repo_expire&quot;: &quot;21,600 second(s) (last: Tue Nov 20 07:14:05 2018)&quot;,\r\n    \t\t&quot;repo_url&quot;: &quot;http://repos.blah.com/CentOS/dev/6/os/x86_64/&quot;,\r\n    \t\t&quot;repo_tstsync&quot;: 0,\r\n    \t\t&quot;repo_id&quot;: &quot;base&quot;,\r\n    \t\t&quot;repo_pkgs&quot;: &quot;6,713&quot;,\r\n    \t\t&quot;repo_prdsync&quot;: 0,\r\n    \t\t&quot;repo_revision&quot;: 1530286202,\r\n    \t\t&quot;repo_name&quot;: &quot;CentOS-6 - Base&quot;,\r\n    \t\t&quot;repo_size&quot;: &quot;5.5 G&quot;,\r\n    \t\t&quot;repo_updated&quot;: &quot;Fri Jun 29 08:37:23 2018&quot;\r\n    \t},\r\n    \t{\r\n    \t\t&quot;repo_expire&quot;: &quot;21,600 second(s) (last: Tue Nov 20 07:36:50 2018)&quot;,\r\n    \t\t&quot;repo_url&quot;: &quot;http://blah.com/epel/dev/6/x86_64/&quot;,\r\n    \t\t&quot;repo_tstsync&quot;: 0,\r\n    \t\t&quot;repo_id&quot;: &quot;epel&quot;,\r\n    \t\t&quot;repo_pkgs&quot;: &quot;12,448&quot;,\r\n    \t\t&quot;repo_prdsync&quot;: 699,\r\n    \t\t&quot;repo_revision&quot;: 1542329363,\r\n    \t\t&quot;repo_name&quot;: &quot;Extra Packages for Enterprise Linux 6 - x86_64&quot;,\r\n    \t\t&quot;repo_size&quot;: &quot;11 G&quot;,\r\n    \t\t&quot;repo_updated&quot;: &quot;Thu Nov 15 17:50:18 2018&quot;\r\n    \t},\r\n    \t{\r\n    \t\t&quot;repo_expire&quot;: &quot;21,600 second(s) (last: Tue Nov 20 07:44:05 2018)&quot;,\r\n    \t\t&quot;repo_url&quot;: &quot;http://blah.com/CentOS/dev/6/extras/x86_64/&quot;,\r\n    \t\t&quot;repo_tstsync&quot;: &quot;null&quot;,\r\n    \t\t&quot;repo_id&quot;: &quot;extras&quot;,\r\n    \t\t&quot;repo_pkgs&quot;: 33,\r\n    \t\t&quot;repo_prdsync&quot;: &quot;null&quot;,\r\n    \t\t&quot;repo_revision&quot;: 1537445728,\r\n    \t\t&quot;repo_name&quot;: &quot;CentOS-6 - Extras&quot;,\r\n    \t\t&quot;repo_size&quot;: &quot;12 M&quot;,\r\n    \t\t&quot;repo_updated&quot;: &quot;Thu Sep 20 05:15:29 2018&quot;\r\n    \t}\r\n    ]\r\n\r\nThe following is the desired output.\r\n\r\n    {\r\n        &quot;repos&quot;: [{\r\n            &quot;CentOS-6 - Base&quot;: {\r\n                &quot;repo_expire&quot;: &quot;21,600 second(s) (last: Tue Nov 20 01:14:05 2018)&quot;,\r\n                &quot;repo_url&quot;: &quot;http://blah.com/CentOS/dev/6/os/x86_64/&quot;,\r\n                &quot;repo_tstsync&quot;: 0,\r\n                &quot;repo_id&quot;: &quot;base&quot;,\r\n                &quot;repo_pkgs&quot;: &quot;6,713&quot;,\r\n                &quot;repo_prdsync&quot;: 0,\r\n                &quot;repo_revision&quot;: 1530286202,\r\n                &quot;repo_size&quot;: &quot;5.5 G&quot;,\r\n                &quot;repo_updated&quot;: &quot;Fri Jun 29 08:37:23 2018&quot;\r\n            },\r\n            &quot;Extra Packages for Enterprise Linux 6 - x86_64&quot;: {\r\n                &quot;repo_expire&quot;: &quot;21,600 second(s) (last: Tue Nov 20 01:36:50 2018)&quot;,\r\n                &quot;repo_url&quot;: &quot;http://blah.com/epel/dev/6/x86_64/&quot;,\r\n                &quot;repo_tstsync&quot;: 0,\r\n                &quot;repo_id&quot;: &quot;epel&quot;,\r\n                &quot;repo_pkgs&quot;: &quot;12,448&quot;,\r\n                &quot;repo_prdsync&quot;: 699,\r\n                &quot;repo_revision&quot;: 1542329363,\r\n                &quot;repo_size&quot;: &quot;11 G&quot;,\r\n                &quot;repo_updated&quot;: &quot;Thu Nov 15 17:50:18 2018&quot;\r\n            },\r\n            &quot;CentOS-6 - Extras&quot;: {\r\n                &quot;repo_expire&quot;: &quot;21,600 second(s) (last: Tue Nov 20 01:44:05 2018)&quot;,\r\n                &quot;repo_url&quot;: &quot;http://blah.com/CentOS/dev/6/extras/x86_64/&quot;,\r\n                &quot;repo_tstsync&quot;: &quot;null&quot;,\r\n                &quot;repo_id&quot;: &quot;extras&quot;,\r\n                &quot;repo_pkgs&quot;: 33,\r\n                &quot;repo_prdsync&quot;: &quot;null&quot;,\r\n                &quot;repo_revision&quot;: 1537445728,\r\n                &quot;repo_size&quot;: &quot;12 M&quot;,\r\n                &quot;repo_updated&quot;: &quot;Thu Sep 20 05:15:29 2018&quot;\r\n            }\r\n        }]\r\n    }\r\n\r\nI&#39;d need to grab the value of the repo_name key from each object somehow. Is this possible? ",
        "link": "https://stackoverflow.com/questions/53399168/jq-output-json-array-of-objects-to-array-of-keys-with-objects",
        "title": "jq: output json array of objects to array of keys with objects"
    },
    {
        "tags": [
            "json",
            "increment",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1542784443,
                "creation_date": 1542784443,
                "answer_id": 53406957,
                "question_id": 53406879,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "First, the filter to use is:\r\n\r\n    .buildNumber += 1\r\n\r\nSecond, as you evidently realize, it would be unwise to use &gt; to overwrite the file.  One option to consider if it’s admissible would be to use coreutil’s `sponge`. Another would be to rename the input file first.",
                "title": "Increment value and save back to the file"
            },
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": -1,
                "last_activity_date": 1542898629,
                "creation_date": 1542898629,
                "answer_id": 53433597,
                "question_id": 53406879,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I just put the two commands as bellow in two lines and it worked just as I wanted.\r\n\r\n    jq &#39;.buildNumber += 1&#39; &#39;package.json&#39; &gt; &#39;package.json.tmp&#39;\r\n    cp &#39;package.json.tmp&#39; &#39;package.json&#39;",
                "title": "Increment value and save back to the file"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 3,
        "last_activity_date": 1543292034,
        "creation_date": 1542784032,
        "last_edit_date": 1543292034,
        "question_id": 53406879,
        "body_markdown": "I have a simple JSON file like this,\r\n\r\n    {\r\n    \r\n    ...\r\n    &quot;version&quot;: &quot;2.1.0&quot;,\r\n    &quot;buildNumber&quot;: 83\r\n    \r\n    }\r\n\r\nI want to simply increment the buildNumber by one in the file. Rest of the content should remain as is.\r\n\r\nWhat I have come up with so far is bellow.\r\n\r\n    jq -e &#39;.buildNumber + 1&#39; &#39;package.json&#39; &gt; &#39;package.json.tmp&#39; &amp;&amp; cp &#39;package.json.tmp&#39; &#39;package.json&#39;\r\n\r\nBut after running the script I&#39;m only left with the updated value in the package.json file, which is just 84. The rest of the content is gone. How do I fix this?",
        "link": "https://stackoverflow.com/questions/53406879/increment-value-and-save-back-to-the-file",
        "title": "Increment value and save back to the file"
    },
    {
        "tags": [
            "windows",
            "cmd",
            "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": 1542831901,
                "post_id": 53409620,
                "comment_id": 93714179,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6929975,
                    "reputation": 2562,
                    "user_id": 5319738,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/33be75bf8acd83e41411d134106c8811?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Kamal",
                    "link": "https://stackoverflow.com/users/5319738/kamal"
                },
                "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": 1542850662,
                "post_id": 53409620,
                "comment_id": 93719933,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1542854800,
                "post_id": 53409620,
                "comment_id": 93720809,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6929975,
                    "reputation": 2562,
                    "user_id": 5319738,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/33be75bf8acd83e41411d134106c8811?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Kamal",
                    "link": "https://stackoverflow.com/users/5319738/kamal"
                },
                "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": 1542866491,
                "post_id": 53409620,
                "comment_id": 93723661,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1543220978,
                "post_id": 53409620,
                "comment_id": 93824383,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6929975,
                    "reputation": 2562,
                    "user_id": 5319738,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/33be75bf8acd83e41411d134106c8811?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Kamal",
                    "link": "https://stackoverflow.com/users/5319738/kamal"
                },
                "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": 1543222024,
                "post_id": 53409620,
                "comment_id": 93824864,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1543273801,
                "creation_date": 1543273801,
                "answer_id": 53490473,
                "question_id": 53409620,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "First, a &quot;plug-in&quot; implementation of jq&#39;s `mktime/0`:\r\n\r\n\r\n    # [1970,  0,  1,  0,  0,  0] | mktime #=&gt; 0\r\n    # For Jan, use 0 for $m.\r\n    # Emit null if any inputs are judged to be invalid.\r\n    # No attempt to account for leap seconds is made.\r\n    # Can also be used for earlier years.\r\n    #\r\n    # Adapted from\r\n    # https://codereview.stackexchange.com/questions/11614/determine-total-number-of-seconds-since-the-epoch\r\n    def mktime:\r\n      def max: if .[0] &gt; .[1] then .[0] else .[1] end;\r\n      def min: if .[0] &gt; .[1] then .[1] else .[0] end; \r\n      def NDaysInMonth: [ 31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31];\r\n    \r\n      . as [$y,  $m,  $d,  $h,  $mn,  $s]\r\n      | if ($y &lt; 0 or $m &lt; 0 or $d &lt; 1 or $h &lt; 0 or $mn &lt; 0 or $s &lt; 0)\r\n        then null\r\n        else\r\n        1970 as $ye # UNIX epoch 01/01/1970\r\n        | (if $y &gt; $ye then 1 else -1 end) as $sign\r\n        | ([$y, $ye] | max) as $maxY\r\n        | ([$y, $ye] | min) as $minY\r\n        | reduce range($minY; $maxY) as $i ({nleapYears: 0};\r\n            if (($i % 100 != 0 and $i % 4 == 0) or $i % 400 == 0) then .nleapYears += 1 else . end)\r\n        | if ($m &gt; 1) and (($y % 100 != 0 and $y % 4 == 0) or $y % 400 == 0)\r\n          then .nleapYears += $sign\r\n          else .\r\n          end\r\n        | .nleapYears |= ([0, .] | max)\r\n        | reduce range(0;$m) as $i (.monthsNDays = 0;\r\n            .monthsNDays += NDaysInMonth[$i])\r\n        | (($y - $ye) * 365 + $sign * .nleapYears + .monthsNDays + $d - 1) * 86400\r\n            + $h * 3600 + $mn * 60 + $s\r\n        end ;\r\n\r\nNext, to parse date strings of the form `&quot;2018-06-01 12:45:56&quot;`, you can easily use jq&#39;s `capture` (see the [jq manual][1]).  Since SO is not a free programming service, this is left as an exercise, as is putting all the pieces together.\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/",
                "title": "Compare &#39;YYYY-mm-dd HH:MM:SS&#39; format timestamps in windows jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1543273801,
        "creation_date": 1542794824,
        "last_edit_date": 1543221994,
        "question_id": 53409620,
        "body_markdown": "I was using `jq` on Ubuntu, but now I have to port my commands to Windows 8.1. I am using `jq` 1.6.\r\n\r\nBut I get this error while using `strptime` on Windows `jq`.\r\n\r\n&gt; jq: error (at xxxx.json:xxx): strptime/1 not implemented on this platform\r\n\r\nWhat are the other options for `strptime` for Windows?\r\n\r\nEXAMPLE:\r\n\r\nThis works on Ubuntu for me, and need to make it work on Windows(just need the time difference in seconds).\r\n\r\n    jq -n &#39;{&quot;t1&quot;: &quot;2018-06-01 12:45:56&quot;, &quot;t2&quot;: &quot;2018-06-03 22:10:01&quot;} |\r\n           (.t2 | strptime(&quot;%Y-%m-%d %H:%M:%S&quot;) | mktime)-\r\n           (.t1 | strptime(&quot;%Y-%m-%d %H:%M:%S&quot;) | mktime)&#39;\r\n    206645\r\n\r\nUPDATE:\r\n\r\nI just found that even `mktime` generates same error for me on Windows. So I updated the question that I need just some way to compare the datetime of specific format in units of seconds(with or without using `strptime`).",
        "link": "https://stackoverflow.com/questions/53409620/compare-yyyy-mm-dd-hhmmss-format-timestamps-in-windows-jq",
        "title": "Compare &#39;YYYY-mm-dd HH:MM:SS&#39; format timestamps in windows jq"
    },
    {
        "tags": [
            "json",
            "unix",
            "unique",
            "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": 1542806653,
                "post_id": 53409951,
                "comment_id": 93700566,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1542817219,
                "post_id": 53409951,
                "comment_id": 93707069,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5310712,
                    "reputation": 1601,
                    "user_id": 4237152,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/cqE77.png?s=256",
                    "display_name": "deelde",
                    "link": "https://stackoverflow.com/users/4237152/deelde"
                },
                "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": 1542835856,
                "post_id": 53409951,
                "comment_id": 93715838,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5310712,
                    "reputation": 1601,
                    "user_id": 4237152,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/cqE77.png?s=256",
                    "display_name": "deelde",
                    "link": "https://stackoverflow.com/users/4237152/deelde"
                },
                "reply_to_user": {
                    "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": 1542835897,
                "post_id": 53409951,
                "comment_id": 93715853,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "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": 1542836354,
                "post_id": 53409951,
                "comment_id": 93716034,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5310712,
                    "reputation": 1601,
                    "user_id": 4237152,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/cqE77.png?s=256",
                    "display_name": "deelde",
                    "link": "https://stackoverflow.com/users/4237152/deelde"
                },
                "reply_to_user": {
                    "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": 1542836448,
                "post_id": 53409951,
                "comment_id": 93716079,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1542836836,
                "creation_date": 1542836836,
                "answer_id": 53420924,
                "question_id": 53409951,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could simply extend your filter with this:\r\n\r\n    map( .definitions |= unique_by(.search) )",
                "title": "Remove duplicate values from JSON with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1594166643,
        "creation_date": 1542795835,
        "last_edit_date": 1594166643,
        "question_id": 53409951,
        "body_markdown": "i&#39;m merging two json-files with jq\r\n\r\n    (group_by( [.&quot;contraction&quot;, &quot;definitions&quot;]) | map((.[0]|del(.&quot;definitions&quot; [])) + { &quot;definitions&quot;: (map(.&quot;definitions&quot; [])) }))\r\n\r\nwhich leads to the following result:\r\n\r\n      [\r\n      {\r\n        &quot;contraction&quot;: &quot;TEST_1&quot;,\r\n        &quot;definitions&quot;: [\r\n          {\r\n            &quot;search&quot;: &quot;1&quot;,\r\n            &quot;replace&quot;: &quot;12&quot;\r\n          },\r\n          {\r\n            &quot;search&quot;: &quot;3&quot;,\r\n            &quot;replace&quot;: &quot;4&quot;\r\n          },\r\n          {\r\n            &quot;search&quot;: &quot;6&quot;,\r\n            &quot;replace&quot;: &quot;2&quot;\r\n          },\r\n          {\r\n            &quot;search&quot;: &quot;1&quot;,\r\n            &quot;replace&quot;: &quot;1&quot;\r\n          }\r\n        ]\r\n      },\r\n      {\r\n        &quot;contraction&quot;: &quot;TEST_2&quot;,\r\n        &quot;definitions&quot;: [\r\n          {\r\n            &quot;search&quot;: &quot;A&quot;,\r\n            &quot;replace&quot;: &quot;post&quot;\r\n          },\r\n          {\r\n            &quot;search&quot;: &quot;B&quot;,\r\n            &quot;replace&quot;: &quot;prae&quot;\r\n          },\r\n          {\r\n            &quot;search&quot;: &quot;A&quot;,\r\n            &quot;replace&quot;: &quot;&quot;\r\n          }\r\n        ]\r\n      }\r\n    ]\r\n\r\nbut now i want to get rid of the duplicate entries which have the same string in their search-attribute.\r\n\r\nI&#39;ve tried unique and unique_by filters, but it leads to complie errors.\r\n\r\nthe result , should be:\r\n\r\n      [\r\n      {\r\n        &quot;contraction&quot;: &quot;TEST_1&quot;,\r\n        &quot;definitions&quot;: [\r\n          {\r\n            &quot;search&quot;: &quot;1&quot;,\r\n            &quot;replace&quot;: &quot;12&quot;\r\n          },\r\n          {\r\n            &quot;search&quot;: &quot;3&quot;,\r\n            &quot;replace&quot;: &quot;4&quot;\r\n          },\r\n          {\r\n            &quot;search&quot;: &quot;6&quot;,\r\n            &quot;replace&quot;: &quot;2&quot;\r\n          }\r\n        ]\r\n      },\r\n      {\r\n        &quot;contraction&quot;: &quot;TEST_2&quot;,\r\n        &quot;definitions&quot;: [\r\n          {\r\n            &quot;search&quot;: &quot;A&quot;,\r\n            &quot;replace&quot;: &quot;post&quot;\r\n          },\r\n          {\r\n            &quot;search&quot;: &quot;B&quot;,\r\n            &quot;replace&quot;: &quot;prae&quot;\r\n          }\r\n        ]\r\n      }\r\n    ]\r\n\r\nis this possible with jq? because i&#39;m not trying to filter keys but normal values. any ideas?\r\n\r\nThe code on [JQPlay][1]\r\n\r\n\r\n  [1]: https://jqplay.org/s/xIax5gZAnT",
        "link": "https://stackoverflow.com/questions/53409951/remove-duplicate-values-from-json-with-jq",
        "title": "Remove duplicate values from JSON with jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1542805182,
                "creation_date": 1542805182,
                "answer_id": 53412589,
                "question_id": 53412455,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`map` + `join` approach:\r\n\r\n    jq &#39;.rows | map(.childarray |= join(&quot;, &quot;))&#39; input.json\r\n\r\nThe output:\r\n\r\n    [\r\n      {\r\n        &quot;id&quot;: 1,\r\n        &quot;child_id&quot;: 11,\r\n        &quot;childarray&quot;: &quot;value1, value2&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: 2,\r\n        &quot;child_id&quot;: 12,\r\n        &quot;childarray&quot;: &quot;value3, value4&quot;\r\n      }\r\n    ]\r\n\r\n\r\n----------\r\nAnother alternative is:\r\n\r\n    jq &#39;.rows[].childarray |= join(&quot;, &quot;) | .rows&#39;\r\n\r\n",
                "title": "jq transform - json child array to delimited string"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1542805182,
        "creation_date": 1542804708,
        "question_id": 53412455,
        "body_markdown": "i want to transform the following input with jq\r\n\r\n    {\r\n    \t&quot;count&quot;: 1000,\r\n    \t&quot;rows&quot;: [{\r\n    \t\t\t&quot;id&quot;: 1,\r\n    \t\t\t&quot;child_id&quot;: 11,\r\n    \t\t\t&quot;childarray&quot;: [&quot;value1&quot;, &quot;value2&quot;]\r\n    \t\t},\r\n    \t\t{\r\n    \t\t\t&quot;id&quot;: 2,\r\n    \t\t\t&quot;child_id&quot;: 12,\r\n    \t\t\t&quot;childarray&quot;: [&quot;value3&quot;, &quot;value4&quot;]\r\n    \t\t}\r\n    \t]\r\n    }\r\n\r\nOutput should be:\r\n\r\n    [\r\n      {\r\n        &quot;id&quot;: 1,\r\n        &quot;child_id&quot;: 11,\r\n        &quot;childarray&quot;: &quot;value1, value2&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: 2,\r\n        &quot;child_id&quot;: 12,\r\n        &quot;childarray&quot;: &quot;value3, value4&quot;\r\n      }\r\n    ]\r\n\r\nI use this jq filter-&gt; &quot;`[.rows[]]`&quot; but don&#39;t know howto &quot;join&quot; the array  -&gt; `&quot;childarray&quot;: [&quot;value1&quot;, &quot;value2&quot;]` to a comma delimited string -&gt; &quot;`value1, value2`&quot;\r\n\r\nhttps://jqplay.org/s/5TlSDgJnkc\r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/53412455/jq-transform-json-child-array-to-delimited-string",
        "title": "jq transform - json child array to delimited string"
    },
    {
        "tags": [
            "json",
            "jq",
            "flatten"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1542830632,
                "last_edit_date": 1542830632,
                "creation_date": 1542830290,
                "answer_id": 53419644,
                "question_id": 53416372,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Let&#39;s start with a variation of your first attempt:\r\n\r\n    .issues[]\r\n     | {key,\r\n       inward: .fields.issuelinks|map(.inwardIssue.key // empty),\r\n       outward: .fields.issuelinks|map(.outwardIssue.key // empty) }\r\n\r\nWith your example, this produces:\r\n\r\n    {&quot;key&quot;:&quot;TEST-A&quot;,&quot;inward&quot;:[],&quot;outward&quot;:[]}\r\n    {&quot;key&quot;:&quot;TEST-B&quot;,&quot;inward&quot;:[&quot;TEST-1&quot;],&quot;outward&quot;:[&quot;TEST-2&quot;,&quot;TEST-3&quot;]}\r\n\r\nSo two repairs are needed to achieve the stated goal: \r\n\r\n1. Produce an array (e.g., by wrapping the above expression in square brackets)\r\n2. Replace the empty arrays by null.\r\n\r\n(2) is dubious but easy to accomplish, e.g. using the helper function defined below.\r\n\r\n## Solution\r\n\r\n    def extract(f): map(f // empty) | if length ==0 then null else . end;\r\n    \r\n    .issues\r\n    | map(\r\n       {key,\r\n        inward: .fields.issuelinks|extract(.inwardIssue.key),\r\n        outward: .fields.issuelinks|extract(.outwardIssue.key)})\r\n\r\n### Caveat\r\nIf `extract` should retain `null` and `false` values, then its def should be modified accordingly.",
                "title": "Flatten array for properties in nested array of JSON objects using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1542830809,
        "creation_date": 1542817253,
        "last_edit_date": 1542830809,
        "question_id": 53416372,
        "body_markdown": "Having JSON with (simplified) Jira data like:\r\n\r\n    {\r\n    \t&quot;issues&quot;: [\r\n    \t\t{\r\n    \t\t\t&quot;key&quot;: &quot;TEST-A&quot;,\r\n    \t\t\t&quot;fields&quot;: { &quot;issuelinks&quot;: [] }\r\n    \t\t},\r\n    \t\t{\r\n    \t\t\t&quot;key&quot;: &quot;TEST-B&quot;,\r\n    \t\t\t&quot;fields&quot;: {\r\n    \t\t\t\t&quot;issuelinks&quot;: [\r\n    \t\t\t\t\t{ &quot;inwardIssue&quot;: { &quot;key&quot;: &quot;TEST-1&quot; } },\r\n    \t\t\t\t\t{ &quot;outwardIssue&quot;: { &quot;key&quot;: &quot;TEST-2&quot; } },\r\n    \t\t\t\t\t{ &quot;outwardIssue&quot;: { &quot;key&quot;: &quot;TEST-3&quot; } }\r\n    \t\t\t\t]\r\n    \t\t\t}\r\n    \t\t}\r\n    \t]\r\n    }\r\n\r\nWould like to get output like:\r\n\r\n    [\r\n    \t{ &quot;key&quot;: &quot;TEST-A&quot;, &quot;inward&quot;: null, &quot;outward&quot;: null },\r\n    \t{ &quot;key&quot;: &quot;TEST-B&quot;, &quot;inward&quot;: [&quot;TEST-1&quot;], &quot;outward&quot;: [&quot;TEST-2&quot;, &quot;TEST-3&quot;] }\r\n    ]\r\n\r\nTried (ignoring the inward links for now):\r\n\r\n    cat data.json | \\\r\n    jq &#39;.issues[] | {&quot;key&quot;:.key, &quot;outward&quot;:.fields.issuelinks[].outwardIssue.key }&#39;\r\n\r\nBut I get:\r\n\r\n    { &quot;key&quot;: &quot;TEST-B&quot;, &quot;outward&quot;: &quot;TEST-1&quot; }\r\n    { &quot;key&quot;: &quot;TEST-B&quot;, &quot;outward&quot;: &quot;TEST-2&quot; }\r\n    { &quot;key&quot;: &quot;TEST-B&quot;, &quot;outward&quot;: null }\r\n\r\nNote: would expect 1) `TEST-A` for the last one, 2) `TEST-2` and `TEST-3` for the first two and would like to 3) have `TEST-2` and `TEST-3` combined in an array.\r\n\r\nSuggestions?",
        "link": "https://stackoverflow.com/questions/53416372/flatten-array-for-properties-in-nested-array-of-json-objects-using-jq",
        "title": "Flatten array for properties in nested array of JSON objects using jq"
    },
    {
        "tags": [
            "json",
            "jq",
            "reduce"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1542832632,
                "creation_date": 1542832632,
                "answer_id": 53420125,
                "question_id": 53420046,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "There&#39;s always the explicit way:\r\n\r\n    reduce .usage.&quot;os:linux&quot;[] as $item (\r\n      {&quot;credits&quot;: 0, &quot;minutes&quot;: 0 }; \r\n      {\r\n        &quot;credits&quot;: (.credits + $item.credits),\r\n        &quot;minutes&quot;: (.minutes + $item.amount / 60000) \r\n      }\r\n    )",
                "title": "Summarize multiple values with jq reduce"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1542874970,
                "last_edit_date": 1542874970,
                "creation_date": 1542834780,
                "answer_id": 53420543,
                "question_id": 53420046,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Or more succintly:\r\n\r\n    reduce .usage.&quot;os:linux&quot;[] as $item (\r\n      {}; \r\n      .credits += $item.credits\r\n      | .minutes += ($item.amount / 60000) )\r\n\r\n## Or ...\r\n\r\nOr abstracting the reduction into the general-purpose utility function `sigma/1`:\r\n\r\n    def sigma(s): reduce s as $s (null; . + $s);\r\n\r\n    .usage.&quot;os:linux&quot;\r\n    | {credits: sigma(.[].credits),\r\n       minutes: (sigma(.[].amount) / 60000) }\r\n\r\n",
                "title": "Summarize multiple values with jq reduce"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 3,
        "last_activity_date": 1542874970,
        "creation_date": 1542832278,
        "last_edit_date": 1542872563,
        "question_id": 53420046,
        "body_markdown": "How to use jq&#39;s `reduce` function to handle multiple manipulations?\r\n\r\n\r\nGiven a model like:\r\n\r\n    {\r\n      &quot;usage&quot; : {\r\n        &quot;os:linux&quot; : {\r\n          &quot;2018_11_18&quot; : {\r\n            &quot;amount&quot; : 601046342,\r\n            &quot;credits&quot; : 99783\r\n          },\r\n          &quot;2018_10_18&quot; : {\r\n            &quot;amount&quot; : 839785106,\r\n            &quot;credits&quot; : 173121\r\n          }\r\n        }\r\n      }\r\n    }\r\n\r\n\r\nAnd JQ file:\r\n\r\n    reduce .usage.&quot;os:linux&quot;[] as $item (\r\n    {&quot;credits&quot;:0,&quot;minutes&quot;:0}; \r\n    .&quot;credits&quot; += $item.credits\r\n    ) \r\n\r\nI Get:\r\n\r\n    {\r\n      &quot;credits&quot;: 272904,\r\n      &quot;minutes&quot;: 0\r\n    }\r\n\r\nCool, But I want to toal both fields, something like:\r\n\r\n    reduce .usage.&quot;os:linux&quot;[] as $item (\r\n    {&quot;credits&quot;:0,&quot;minutes&quot;:0}; \r\n    .&quot;credits&quot; += $item.credits,\r\n    .&quot;minutes&quot; += $item.amount /1000/60\r\n    ) \r\n\r\nSemi-colons cause errors, commas pass, but just handles the last task, i,e,\r\n\r\n    {\r\n      &quot;credits&quot;: 0,\r\n      &quot;minutes&quot;: 24013.85746666667\r\n    }\r\n\r\n",
        "link": "https://stackoverflow.com/questions/53420046/summarize-multiple-values-with-jq-reduce",
        "title": "Summarize multiple values with jq reduce"
    },
    {
        "tags": [
            "javascript",
            "node.js",
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1542868683,
                "last_edit_date": 1542868683,
                "creation_date": 1542837541,
                "answer_id": 53421048,
                "question_id": 53420766,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If the stream of objects is already in a file, use `inputs` with the -n command-line option. \r\n\r\nThis will avoid the overhead of &quot;slurping&quot; but will still require enough RAM for the entire result to fit into memory.  If that doesn&#39;t work for you, then you will have to resort to desperate measures :-)\r\n\r\nThis might be a useful starting point:\r\n\r\n    jq -n &#39;reduce inputs as $in ({}; . + $in)&#39;",
                "title": "How can I combine a sequence of JSON with jq without using the slurp flag?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1542841249,
                "last_edit_date": 1542841249,
                "creation_date": 1542840716,
                "answer_id": 53421552,
                "question_id": 53420766,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If everything is already in memory, you could modify the `group_by` line as follows:\r\n\r\n    reduce group_by(.day)[] as $in ({}; . + { ($in[0].day): $in }\r\n\r\n## Alternatives to `group_by`\r\n\r\nSince `group_by` entails a sort, it may be unnecessarily inefficient.  You might like to consider using a variant such as the following:\r\n\r\n    # sort-free variant of group_by/1\r\n    # f must always evaluate to an integer or always to a string.\r\n    # Output: an array in the former case, or an object in the latter case\r\n    def GROUP_BY(f): reduce .[] as $x ({}; .[$x|f] += [$x] );\r\n",
                "title": "How can I combine a sequence of JSON with jq without using the slurp flag?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1542868683,
        "creation_date": 1542836012,
        "question_id": 53420766,
        "body_markdown": "I have a ton of records (~4,500) that I&#39;ve processed (using jq) down to a sequence of JSON grouped by hourly UTC time (~680 groups, all unique). \r\n\r\n    {\r\n        &quot;2018-10-09T19:00:00.000Z&quot;: []\r\n    }\r\n    {\r\n        &quot;2018-10-09T20:00:00.000Z&quot;: []\r\n    }\r\n    {\r\n        &quot;2018-10-09T21:00:00.000Z&quot;: []\r\n    }\r\n\r\nI&#39;m pretty sure you can see where this is going, but I want to combine all these into a single JSON object to hand over to another system for more fun.\r\n\r\n    {\r\n        &quot;2018-10-09T19:00:00.000Z&quot;: [],\r\n        &quot;2018-10-09T20:00:00.000Z&quot;: [],\r\n        &quot;2018-10-09T21:00:00.000Z&quot;: []\r\n    }\r\n\r\nThe last two things I&#39;m doing before I get to the sequence of objects is:\r\n\r\n    group_by(.day)[] | { (.[0].day): . }\r\n\r\nWhere `.day` is the ISO Date you see referenced above. \r\n\r\nI&#39;ve tried a few things around `map` and `reduce` functions, but can&#39;t seem to massage the data the way I want. I&#39;ve spent a few hours on this and need to take a break, so any help or direction you can point me would be great!",
        "link": "https://stackoverflow.com/questions/53420766/how-can-i-combine-a-sequence-of-json-with-jq-without-using-the-slurp-flag",
        "title": "How can I combine a sequence of JSON with jq without using the slurp flag?"
    },
    {
        "tags": [
            "json",
            "bash",
            "unicode",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1020072,
                    "reputation": 243994,
                    "user_id": 1030675,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/957956ce51706d03f19a4dc85a767bb1?s=256&d=identicon&r=PG",
                    "display_name": "choroba",
                    "link": "https://stackoverflow.com/users/1030675/choroba"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1542895104,
                "post_id": 53432500,
                "comment_id": 93738826,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1370691,
                    "reputation": 58,
                    "user_id": 1305981,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f5102c7a2b18ca7a59c7b661e77df326?s=256&d=identicon&r=PG",
                    "display_name": "Vineet Chawla",
                    "link": "https://stackoverflow.com/users/1305981/vineet-chawla"
                },
                "reply_to_user": {
                    "account_id": 1020072,
                    "reputation": 243994,
                    "user_id": 1030675,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/957956ce51706d03f19a4dc85a767bb1?s=256&d=identicon&r=PG",
                    "display_name": "choroba",
                    "link": "https://stackoverflow.com/users/1030675/choroba"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1542895978,
                "post_id": 53432500,
                "comment_id": 93739343,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1542896113,
                "creation_date": 1542896113,
                "answer_id": 53432886,
                "question_id": 53432500,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "As @choroba mentioned in the comment, this is colour sequence characters. I removed them by adding a -M flag for JQ that disables colours.",
                "title": "Adding json array via JQ introduces unicode characters in string"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1542896113,
        "creation_date": 1542894768,
        "question_id": 53432500,
        "body_markdown": "I have a JSON file in which I want to append an array element, using bash and latest JQ installed. I am able to append it but the resulting string has unicode characters as can be seen below. The first element in validators array is the original and the second is the appended code. (not the whole json file)\r\n\r\n    &quot;validators&quot;: [\r\n    {\r\n      &quot;address&quot;: &quot;85BAF568E7F89277E47D3FC8E111775A4F6992FA&quot;,\r\n      &quot;pub_key&quot;: {\r\n        &quot;type&quot;: &quot;tendermint/PubKeyEd25519&quot;,\r\n        &quot;value&quot;: &quot;BCzCLcW7rZ9VJgAtEUoDN17qcZw8ZvpYbPsL6eOy3No=&quot;\r\n      },\r\n      &quot;power&quot;: &quot;10&quot;,\r\n      &quot;name&quot;: &quot;&quot;\r\n    },\r\n    {\r\n      &quot;address&quot;: &quot;\\u001b[32m\\&quot;F75E15A3949824B685A3C5BFCDEED7E3DA4277AE\\&quot;\\u001b[0m\\r&quot;,\r\n      &quot;pub_key&quot;: &quot;\\u001b[37m{\\u001b[0m\\u001b[34;1m\\&quot;type\\&quot;\\u001b[0m\\u001b[37m:\\u001b[0m\\u001b[32m\\&quot;tendermint/PubKeyEd25519\\&quot;\\u001b[0m\\u001b[37m,\\u001b[0m\\u001b[34;1m\\&quot;value\\&quot;\\u001b[0m\\u001b[37m:\\u001b[0m\\u001b[32m\\&quot;INeR51z41k6jPAEJ5rV+1TY+4sxnbIykc4bfJFmSCQ8=\\&quot;\\u001b[0m\\u001b[37m\\u001b[37m}\\u001b[0m\\r&quot;,\r\n      &quot;power&quot;: &quot;10&quot;,\r\n      &quot;name&quot;: &quot;node2&quot;\r\n    }\r\n    ]\r\nPrinting the address element separately prints the element without any utf/unicode encoding chars. \r\n\r\n    {\r\n        &quot;type&quot;: &quot;tendermint/PubKeyEd25519&quot;,\r\n        &quot;value&quot;: &quot;BCzCLcW7rZ9VJgAtEUoDN17qcZw8ZvpYbPsL6eOy3No=&quot;\r\n    }\r\nI merge the code using the following code:\r\n\r\n    cat genesis.json.src | jq --arg pub_key $PK --arg name node$i --arg addr $ADDR &#39;.validators+= [{address: $addr, pub_key: $pub_key, power:&quot;10&quot;,name:$name}]&#39; &gt; genesis.json.dest\r\n\r\nI am running macOS. Any help or suggestion would be appreciated.",
        "link": "https://stackoverflow.com/questions/53432500/adding-json-array-via-jq-introduces-unicode-characters-in-string",
        "title": "Adding json array via JQ introduces unicode characters in string"
    },
    {
        "tags": [
            "stream",
            "addition",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 52832,
                    "reputation": 2983,
                    "user_id": 157931,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/986d255e94481d2249bae7911e7845e8?s=256&d=identicon&r=PG",
                    "display_name": "Danilo Cabello",
                    "link": "https://stackoverflow.com/users/157931/danilo-cabello"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1542901019,
                "post_id": 53434228,
                "comment_id": 93742198,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1542901562,
                "creation_date": 1542901562,
                "answer_id": 53434401,
                "question_id": 53434228,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You are mistaken in thinking that the jq filter as shown used to work on the JSON as shown.\r\n\r\nThere are fortunately two simple fixes:\r\n\r\n    [ .data.organization.repositories.nodes[]\r\n      | .pullRequests.totalCount ]\r\n    | add\r\n\r\nor:\r\n\r\n    .data.organization.repositories.nodes\r\n    | map(.pullRequests.totalCount)\r\n    | add\r\n\r\n\r\n## Using sigma/1\r\n\r\nAnother option is to use a stream-oriented summation function:\r\n\r\n    def sigma(s): reduce s as $s (null; .+$s);\r\n\r\n    .data.organization.repositories.nodes\r\n    | sigma(.[].pullRequests.totalCount)\r\n \r\n\r\n",
                "title": "Adding numbers that are not in array format? Or how to filter to array so I can sum up"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1542901797,
        "creation_date": 1542900906,
        "last_edit_date": 1542901797,
        "question_id": 53434228,
        "body_markdown": "In previous versions of jq I was able to run the following:\r\n\r\n    cat pull_requests.json | jq &#39;.data.organization.repositories.nodes[] | .pullRequests.totalCount | add&#39;\r\n\r\nOn this sample data:\r\n\r\n    {\r\n      &quot;data&quot;: {\r\n        &quot;organization&quot;: {\r\n          &quot;repositories&quot;: {\r\n            &quot;nodes&quot;: [{\r\n                &quot;pullRequests&quot;: {\r\n                  &quot;totalCount&quot;: 2\r\n                }\r\n              },\r\n              {\r\n                &quot;pullRequests&quot;: {\r\n                  &quot;totalCount&quot;: 8\r\n                }\r\n              },\r\n              {\r\n                &quot;pullRequests&quot;: {\r\n                  &quot;totalCount&quot;: 23\r\n                }\r\n              }\r\n            ]\r\n          }\r\n        }\r\n      }\r\n    }\r\n\r\nAnd I would get the correct result.\r\n\r\nBut currently on jq-1.6 I am getting the following error:\r\n\r\n    jq: error (at &lt;stdin&gt;:24): Cannot iterate over number (2)\r\n\r\nWhat I noticed from the output without the `add` filter is that is not an array:\r\n\r\n    ➤ cat pull_requests.json | jq &#39;.data.organization.repositories.nodes[] | .pullRequests.totalCount&#39;\r\n    2\r\n    8\r\n    23\r\n\r\nSo my question is how to add these numbers up?\r\n\r\nI also tried casting it to array by using `[.pullRequests.totalCount]` but I was unable to merge, meld, join the arrays to get the final count.",
        "link": "https://stackoverflow.com/questions/53434228/adding-numbers-that-are-not-in-array-format-or-how-to-filter-to-array-so-i-can",
        "title": "Adding numbers that are not in array format? Or how to filter to array so I can sum up"
    },
    {
        "tags": [
            "json",
            "string",
            "jq",
            "backslash"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1542905158,
                "creation_date": 1542905158,
                "answer_id": 53435302,
                "question_id": 53434630,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using the -r option tells jq to &quot;translate&quot; the JSON string into a &quot;raw&quot; string by interpreting the characters that are special to JSON (see e.g. http://json.org).  Thus, following the [\\[mcve\\]][1] guidelines a bit more closely, we could start with:\r\n\r\n    $ jq . &lt;&lt;&lt; &#39;&quot;X\\\\nY&quot;&#39;\r\n    &quot;X\\\\nY&quot;\r\n\r\n    $ jq -r . &lt;&lt;&lt; &#39;&quot;X\\\\nY&quot;&#39;\r\n    X\\nY\r\n\r\nIf you check the json.org specification of strings, you&#39;ll see this is exactly correct.\r\n\r\nSo if for some reason you want each occurrence of  `\\\\` in the JSON string to be replaced by two backslash characters (i.e. JSON: `&quot;\\\\\\\\&quot;`), you could use `sub` or `gsub`.  That&#39;s a bit tricky, because the first argument of these functions is a regex.  Behold:\r\n\r\n    $ jq -r &#39;gsub(&quot;\\\\\\\\&quot;; &quot;\\\\\\\\&quot;)&#39; &lt;&lt;&lt; &#39;&quot;X\\\\nY&quot;&#39;\r\n    X\\\\nY\r\n\r\n\r\n  [1]: http://stackoverflow.com/help/mcve",
                "title": "jq double backslash sometime removed"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1542916257,
                "creation_date": 1542916257,
                "answer_id": 53437307,
                "question_id": 53434630,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You should output the string as json to preserve the escapes. By taking a string and outputting it raw, you&#39;re getting exactly what that string was, a literal backslash followed by an `n`.\r\n\r\n    $ ... | jq -r &#39;.env_vars | to_entries[] | &quot;\\(.key): \\(.value | tojson)&quot;&#39;\r\n\r\nIf any of the values are non-strings, add a `tostring` to the filter.",
                "title": "jq double backslash sometime removed"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1542916257,
        "creation_date": 1542902495,
        "last_edit_date": 1542905265,
        "question_id": 53434630,
        "body_markdown": "I have a first json file like this:\r\n\r\n    {\r\n      &quot;env_vars&quot;: {\r\n        &quot;TERRAFORM_CFG_TLS_CERT&quot;: &quot;-----BEGIN CERTIFICATE----\\\\nMIIIqzCCB5O&quot;\r\n      }\r\n    }\r\n\r\nIf I use the command:\r\n\r\n    echo &lt;file&gt; | jq -r &#39;.env_vars&#39;\r\n\r\nThe result is as expected (the backslash are still there):\r\n\r\n    {\r\n      &quot;TERRAFORM_CFG_TLS_CERT&quot;: &quot;-----BEGIN CERTIFICATE----\\\\nMIIIqzCCB5O&quot;\r\n    }\r\n\r\nBut if i execute this command:\r\n\r\n    cat &lt;file&gt; | jq -r &#39;.env_vars&#39; | jq -r &#39;keys[] as $k | &quot;\\($k)=\\&quot;\\(.[$k])\\&quot;&quot;&#39;\r\n\r\nThe result is:\r\n\r\n    TERRAFORM_CFG_TLS_CERT: &quot;-----BEGIN CERTIFICATE----\\nMIIIqzCCB5O&quot;\r\n\r\n=&gt; One backslash has been removed... why ?\r\nHow to avoid this ?\r\n\r\nThanks.",
        "link": "https://stackoverflow.com/questions/53434630/jq-double-backslash-sometime-removed",
        "title": "jq double backslash sometime removed"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1542940560,
                "creation_date": 1542940560,
                "answer_id": 53440018,
                "question_id": 53439594,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I could not come up with a simple way, but here&#39;s one I got to do this.\r\n\r\n1. Join files and create CSV-like file\r\n=========================================\r\n\r\nIf your machine have `join`, you can create joined records from two files (like `join` command in SQL).\r\nTo do this, make sure your file is sorted.\r\nThe easiest way I think is just numbering each lines. This works as Primary ID in SQL.\r\n\r\n    $ cat a.txt | nl &gt; a.txt.nl\r\n    $ cat b.txt | nl &gt; b.txt.nl\r\n    $ cat c.txt | nl &gt; c.txt.nl\r\n\r\nNow you can `join` sorted files into one. Note that `join` can join only two files at once. This is why I piped output to next `join`.\r\n\r\n    $ join a.txt.nl b.txt.nl | join - c.txt.nl &gt; conc.txt\r\n\r\nnow `conc.txt` is:\r\n\r\n    1 20 19 2\r\n    2 3 4 4\r\n    3 10 5 9\r\n    4 15 8 21\r\n    5 15 8 5\r\n\r\n2. Create json from the CSV-like file\r\n=======================================\r\n\r\nIt seems little complicated.\r\n\r\n    jq -Rsn &#39;\r\n        [inputs\r\n         | . / &quot;\\n&quot;\r\n         | (.[] | select((. | length) &gt; 0) | . / &quot; &quot;) as $input\r\n         | [$input[1], $input[2], $input[3] ] ]\r\n    &#39; &lt;conc.txt\r\n\r\nActually I do not know detailed syntex or usage of `jq`, it seems like doing:\r\n\r\n - split input file by `\\n`\r\n - split a given line by space, then select valid data\r\n - put splitted records in appropriate location by their index\r\n\r\nI used this question as a reference:\r\nhttps://stackoverflow.com/a/44781106/10675437\r\n",
                "title": "How to use Bash to create arrays with values from the same line of many files?"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1542969315,
                "last_edit_date": 1542969315,
                "creation_date": 1542942419,
                "answer_id": 53440194,
                "question_id": 53439594,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here’s one approach:\r\n\r\n    $ jq -c -n &#39;[$a,$b,$c] | transpose&#39;  --slurpfile a a.txt  --slurpfile b b.txt  --slurpfile c c.txt \r\n\r\n## Generalization to an arbitrary number of files\r\n\r\nIn the following, we&#39;ll assume that the files to be processed can be specified by *.txt in the current directory:\r\n\r\n    jq -n -c &#39;\r\n      [reduce inputs as $i ({}; .[input_filename] += [$i]) | .[]]\r\n      | transpose&#39; *.txt\r\n\r\n",
                "title": "How to use Bash to create arrays with values from the same line of many files?"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1542943304,
                "creation_date": 1542943304,
                "answer_id": 53440283,
                "question_id": 53439594,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use `paste` to join the files, then read the input as raw text, splitting on the tabs inserted by `paste`:\r\n\r\n    $ paste a.txt b.txt c.txt | jq -Rc &#39;split(&quot;\\t&quot;) | map(tonumber)&#39;\r\n    [20,19,2]\r\n    [3,4,4]\r\n    [10,5,9]\r\n    [15,8,21]\r\n    [15,8,5]\r\n\r\nIf you want to gather the entire result into a single array, pipe it into another instance of `jq` in slurp mode. (There&#39;s probably a way to do it with a single invocation of `jq`, but this seems simpler.)\r\n\r\n    $ paste a.txt b.txt c.txt | jq -R &#39;split(&quot;\\t&quot;) | map(tonumber)&#39; | jq -sc\r\n    [[20,19,2],[3,4,4],[10,5,9],[15,8,21],[15,8,5]]",
                "title": "How to use Bash to create arrays with values from the same line of many files?"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 3,
        "last_activity_date": 1542969315,
        "creation_date": 1542935446,
        "last_edit_date": 1542966375,
        "question_id": 53439594,
        "body_markdown": "I have a number of files (in the same folder) all with the same number of lines:\r\n\r\n`a.txt`\r\n\r\n    20\r\n    3\r\n    10\r\n    15\r\n    15\r\n\r\n`b.txt`\r\n\r\n    19\r\n    4\r\n    5\r\n    8\r\n    8\r\n\r\n`c.txt`\r\n\r\n    2\r\n    4\r\n    9\r\n    21\r\n    5\r\n\r\nUsing Bash, I&#39;d like to create an array of arrays that contain the value of each line in every file. So, line 1 from `a.txt`, `b.txt`, and `c.txt`. The same for lines 2 to 5, so that in the end it looks like:\r\n\r\n    [\r\n       [20, 19, 2],\r\n       [3, 4, 4],\r\n       ...\r\n       [15, 8, 5]\r\n    ]\r\n\r\nNote: I messed up the formatting and wording. I&#39;ve changed this now.\r\n\r\nI&#39;m actually using `jq` to get these lists in the first place, as they&#39;re originally specific values within a JSON file I download every X minutes. I used `jq` to get the values I needed into different files as I thought that would get me further, but now I&#39;m not sure that was the way to go. If it helps, [here is the original JSON file I download and start with](http://api.citybik.es/v2/networks/valenbisi). \r\n\r\nI&#39;ve looked at various questions that somewhat deal with this:\r\n\r\n- https://stackoverflow.com/questions/30988586/creating-an-array-from-a-text-file-in-bash\r\n- https://stackoverflow.com/questions/36431371/bash-script-to-create-a-json-file\r\n- https://stackoverflow.com/questions/52087737/jq-create-json-array-using-bash\r\n\r\nAmong others. But none of these deal with taking the value of the same line from various files. I don&#39;t know Bash well enough to do this and any help is greatly appreciated.",
        "link": "https://stackoverflow.com/questions/53439594/how-to-use-bash-to-create-arrays-with-values-from-the-same-line-of-many-files",
        "title": "How to use Bash to create arrays with values from the same line of many files?"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3303917,
                    "reputation": 2469,
                    "user_id": 2779323,
                    "user_type": "registered",
                    "accept_rate": 65,
                    "profile_image": "https://www.gravatar.com/avatar/92ad7e2562083fed6db28c166dc009fc?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "mohit",
                    "link": "https://stackoverflow.com/users/2779323/mohit"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1542985393,
                "post_id": 53448845,
                "comment_id": 93770624,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 57200,
                    "reputation": 158728,
                    "user_id": 171318,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/ePRKy.jpg?s=256",
                    "display_name": "hek2mgl",
                    "link": "https://stackoverflow.com/users/171318/hek2mgl"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1542986474,
                "post_id": 53448845,
                "comment_id": 93771093,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 18,
                "is_accepted": true,
                "score": 18,
                "last_activity_date": 1542986050,
                "creation_date": 1542986050,
                "answer_id": 53449125,
                "question_id": 53448845,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use the following command:\r\n\r\n    jq &#39;.TagList[]|select(.Key==&quot;Environment&quot; or .Key==&quot;ENVIRONMENT&quot;).Value&#39;",
                "title": "jq select or statement"
            },
            {
                "up_vote_count": 7,
                "is_accepted": false,
                "score": 7,
                "last_activity_date": 1542997251,
                "creation_date": 1542997251,
                "answer_id": 53451410,
                "question_id": 53448845,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Generalizing a bit:\r\n\r\n    .TagList[]\r\n    | select(.Key | ascii_upcase == &quot;ENVIRONMENT&quot;).Value\r\n\r\n",
                "title": "jq select or statement"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 6,
        "last_activity_date": 1542997251,
        "creation_date": 1542984774,
        "last_edit_date": 1542985938,
        "question_id": 53448845,
        "body_markdown": "I have the the following input json:\r\n\r\n    {\r\n      &quot;TagList&quot;: [\r\n        {\r\n          &quot;Key&quot;: &quot;Environment&quot;,\r\n          &quot;Value&quot;: &quot;foo&quot;\r\n        },\r\n        {\r\n          &quot;Key&quot;: &quot;ENVIRONMENT&quot;,\r\n          &quot;Value&quot;: &quot;bar&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\n\r\nI want to get the values of tags with the key ENVIRONMENT using `jq`:\r\n\r\n    jq -r &#39;.TagList[] | select(.Key==&quot;ENVIRONMENT&quot;) | .Value&#39; input.json\r\n\r\nBut as it turned out, the key could be also `Environment`. I try get both using this command:\r\n\r\n    jq -r &#39;.TagList[] | select((.Key==&quot;ENVIRONMENT&quot;) | .Value&#39; or .Key==&quot;Environment&quot; | .Value)\r\n\r\nbut get the following error:\r\n\r\n    jq: error: syntax error, unexpected $end, expecting &#39;;&#39; or &#39;)&#39; (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n    .TagList[] | select((.Key==&quot;ENVIRONMENT&quot;) | .Value\r\n    jq: 1 compile error\r\n\r\nHow to get both of those tags?",
        "link": "https://stackoverflow.com/questions/53448845/jq-select-or-statement",
        "title": "jq select or statement"
    },
    {
        "tags": [
            "json",
            "elasticsearch",
            "export-to-csv",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1542996891,
                "post_id": 53450169,
                "comment_id": 93775141,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1542996617,
                "creation_date": 1542996617,
                "answer_id": 53451279,
                "question_id": 53450169,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Drilling down from the top:\r\n\r\n    .aggregations[].buckets[][&quot;3&quot;].buckets[] | select( .key == &quot;Weather Delay&quot;)\r\n    \r\nyields:\r\n\r\n    {\r\n      &quot;key&quot;: &quot;Weather Delay&quot;,\r\n      &quot;doc_count&quot;: 1\r\n    }\r\n\r\n## Or ...\r\n... if you&#39;re willing to take the risk:\r\n\r\n    .. | select(.key? == &quot;Weather Delay&quot;)\r\n",
                "title": "Elasticsearch - exporting to CSV using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1543071257,
        "creation_date": 1542990630,
        "last_edit_date": 1543071257,
        "question_id": 53450169,
        "body_markdown": "I am exporting data from Elasticsearch to CSV. I have taken my JSON code from the request element of a visualisation, executed it through a curl XGET search and piped it to jq. My question is around how jq is handling this output. \r\nSkipping the jq part for a moment, the output of the search shows the aggs has several layers. E.g.\r\n\r\n    curl -XGET &quot;http://localhost:9200/kibana_sample_data_flights/_search&quot; -H &#39;Content-Type: application/json&#39; -d &#39;{&quot;aggs&quot;: {&quot;2&quot;: {&quot;date_histogram&quot;: {&quot;field&quot;: &quot;timestamp&quot;,&quot;interval&quot;:&quot;30m&quot;,&quot;time_zone&quot;: &quot;Europe/London&quot;,&quot;min_doc_count&quot;: 1},&quot;aggs&quot;: {&quot;3&quot;: {&quot;terms&quot;: {&quot;field&quot;: &quot;FlightDelayType&quot;,&quot;size&quot;: 5,&quot;order&quot;: {&quot;_count&quot;: &quot;desc&quot;}}}}}},&quot;size&quot;:0,&quot;_source&quot;: {&quot;excludes&quot;: []},&quot;stored_fields&quot;: [&quot;*&quot;],&quot;script_fields&quot;: {&quot;hour_of_day&quot;: {&quot;script&quot;: {&quot;inline&quot;: &quot;doc[&#39;timestamp&#39;].value.hourOfDay&quot;,&quot;lang&quot;: &quot;painless&quot;}}},&quot;docvalue_fields&quot;: [{&quot;field&quot;: &quot;timestamp&quot;,&quot;format&quot;: &quot;date_time&quot;}],&quot;query&quot;: {&quot;bool&quot;: {&quot;must&quot;: [{&quot;match_all&quot;: {}},{&quot;match_all&quot;: {}},{&quot;range&quot;: {&quot;timestamp&quot;: {&quot;gte&quot;: 1542804577190,&quot;lte&quot;: 1542890977190,&quot;format&quot;: &quot;epoch_millis&quot;}}}],&quot;filter&quot;: [],&quot;should&quot;: [],&quot;must_not&quot;: []}}}&#39;\r\n\r\nA snippet of the output to highlight my question:\r\n\r\n    &quot;aggregations&quot; : {\r\n    &quot;2&quot; : {\r\n      &quot;buckets&quot; : [\r\n        {\r\n          &quot;key_as_string&quot; : &quot;2018-11-21T12:30:00.000Z&quot;,\r\n          &quot;key&quot; : 1542803400000,\r\n          &quot;doc_count&quot; : 2,\r\n          &quot;3&quot; : {\r\n            &quot;doc_count_error_upper_bound&quot; : 0,\r\n            &quot;sum_other_doc_count&quot; : 0,\r\n            &quot;buckets&quot; : [\r\n              {\r\n                &quot;key&quot; : &quot;No Delay&quot;,\r\n                &quot;doc_count&quot; : 1\r\n              },\r\n              {\r\n                &quot;key&quot; : &quot;Weather Delay&quot;,\r\n                &quot;doc_count&quot; : 1\r\n              }\r\n            ]\r\n          }\r\n        },\r\n\r\nI cannot seem to get my jq code to transverse down to the layer under &quot;3&quot;. What I actually want to send to CSV here is the key Flight Delay Type (e.g. Weather Delay) and the count. (Note I have left out the -r and | @CSV for testing.)\r\nMy jq code so far:\r\n\r\n    jq &#39;.aggregations[].buckets[]&#39;\r\nThat returns:\r\n\r\n        {\r\n      &quot;buckets&quot;: [\r\n        {\r\n          &quot;key_as_string&quot;: &quot;2018-11-21T12:30:00.000Z&quot;,\r\n          &quot;key&quot;: 1542803400000,\r\n          &quot;doc_count&quot;: 2,\r\n          &quot;3&quot;: {\r\n            &quot;doc_count_error_upper_bound&quot;: 0,\r\n            &quot;sum_other_doc_count&quot;: 0,\r\n            &quot;buckets&quot;: [\r\n              {\r\n                &quot;key&quot;: &quot;No Delay&quot;,\r\n                &quot;doc_count&quot;: 1\r\n              },\r\n              {\r\n                &quot;key&quot;: &quot;Weather Delay&quot;,\r\n                &quot;doc_count&quot;: 1\r\n              }\r\n            ]\r\n          }\r\n        },\r\n\r\nHow can I get that next layer down?\r\n\r\nTIA\r\n\r\n",
        "link": "https://stackoverflow.com/questions/53450169/elasticsearch-exporting-to-csv-using-jq",
        "title": "Elasticsearch - exporting to CSV using jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1546012,
                    "reputation": 1180,
                    "user_id": 1439546,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/07b41bc665730b7e9e38c18b0ae89322?s=256&d=identicon&r=PG",
                    "display_name": "james.haggerty",
                    "link": "https://stackoverflow.com/users/1439546/james-haggerty"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1543100381,
                "post_id": 53462496,
                "comment_id": 93797532,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 550278,
                    "reputation": 95,
                    "user_id": 1035862,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/yDREo.png?s=256",
                    "display_name": "Steven Fowler",
                    "link": "https://stackoverflow.com/users/1035862/steven-fowler"
                },
                "reply_to_user": {
                    "account_id": 1546012,
                    "reputation": 1180,
                    "user_id": 1439546,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/07b41bc665730b7e9e38c18b0ae89322?s=256&d=identicon&r=PG",
                    "display_name": "james.haggerty",
                    "link": "https://stackoverflow.com/users/1439546/james-haggerty"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1543102935,
                "post_id": 53462496,
                "comment_id": 93798008,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1543108753,
                "creation_date": 1543108753,
                "answer_id": 53463886,
                "question_id": 53462496,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The answer I was looking for was\r\n\r\n    jq &#39;.[]+{acct:&quot;acct1&quot;}|{acct:.acct,name:.name,type:.type}&quot; r2.json &gt; r.json\r\n\r\nJust had to learn how |&#39;s worked :)",
                "title": "JQ: How to add literal value to output"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1543116234,
                "creation_date": 1543116234,
                "answer_id": 53464371,
                "question_id": 53462496,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "A more economical approach to achieving what I understand you want would be:\r\n\r\n    jq &#39;.[]|{name,type, acct:&quot;acct1&quot;}&#39; r.json\r\n\r\nIncidentally, the first filter in the Q (`.[]|{name:.name,type:.type}`) can be abbreviated to:\r\n\r\n    .[]|{name,type}",
                "title": "JQ: How to add literal value to output"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 6,
        "last_activity_date": 1543116234,
        "creation_date": 1543094759,
        "last_edit_date": 1543102911,
        "question_id": 53462496,
        "body_markdown": "Thank you for looking at this with me.\r\n\r\nI am using [JQ][1] to manipulate JSON files.\r\n\r\nStarted with this that works:\r\n\r\n    jq &quot;.[]|{name:.name,type:.type}&quot; r.json\r\n\r\nNeed to extent to include &quot;acct&quot; and a literal value of &quot;acct1&quot; into the resulting json.\r\n\r\nI know I can do it with **two** lines of code\r\n\r\n    jq &#39;.[]+{acct:&quot;acct1&quot;}&#39; r.json &gt; r2.json\r\n    jq &quot;{acct:.acct,name:.name,type:.type}&quot; r2.json &gt; r.json\r\n\r\nIs there a way to do it inline with **one** line of code - like this which is not working ?\r\n\r\n    jq &#39;.[]|{acct:&quot;acct1&quot;,name:.name,type:.type}&#39; r.json\r\n\r\nThank you for looking at this problem\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/",
        "link": "https://stackoverflow.com/questions/53462496/jq-how-to-add-literal-value-to-output",
        "title": "JQ: How to add literal value to output"
    },
    {
        "tags": [
            "json",
            "timezone",
            "jq",
            "units-of-measurement"
        ],
        "answers": [
            {
                "up_vote_count": 26,
                "is_accepted": true,
                "score": 26,
                "last_activity_date": 1543199699,
                "creation_date": 1543199699,
                "answer_id": 53474079,
                "question_id": 53473584,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With your input,\r\n\r\n    jq -c &#39;{acres: (.lotsize/43560), soldOn: (.dateSold | strftime(&quot;%A %B %d, %Y&quot;)) }&#39;\r\n\r\nproduces:\r\n\r\n    {&quot;acres&quot;:1.5,&quot;soldOn&quot;:&quot;Friday April 11, 2008&quot;}\r\n\r\nRecent versions of jq support the environment variable TZ so you might want to look at `strflocaltime`.",
                "title": "jq and Math functions"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 18,
        "last_activity_date": 1641349663,
        "creation_date": 1543194362,
        "last_edit_date": 1641349663,
        "question_id": 53473584,
        "body_markdown": "I&#39;m retrieving JSON from a real estate database. `jq` makes it easy to pull out the separate properties/values, but some of the values are in inconvenient units. For example, the LotSize variable is in square feet (need to divide by 43560 to get acres, which is more conventional), and dateSold is a Linux timestamp. Here&#39;s a sample:\r\n\r\n    {\r\n    \t&quot;lotsize&quot;: 65340,\r\n    \t&quot;dateSold&quot;: 1207897200\r\n    } \r\n\r\nI&#39;d like to be able to do math on values that jq processes. I&#39;ve read the manual (https://stedolan.github.io/jq/manual/#Math) but it doesn&#39;t give me a sense of how to do it. I&#39;d like to transform the JSON data above into something like this:\r\n\r\n    {\r\n    \t&quot;acres&quot;: 1.5,\r\n    \t&quot;soldOn&quot;: &quot;Friday, April 11, 2008&quot;\r\n    } \r\n\r\nI know I can patch this up Excel, but it&#39;d be cool to have `jq` do it without any further processing. Any thoughts on doing this? Thanks.\r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/53473584/jq-and-math-functions",
        "title": "jq and Math functions"
    },
    {
        "tags": [
            "json",
            "jq",
            "hierarchical-data"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1543268855,
                "creation_date": 1543268855,
                "answer_id": 53489596,
                "question_id": 53487500,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The key to the following solution is to convert the flat array into a hierarchical structure.  We use `setpath` to do this as follows:\r\n\r\n    reduce .[] as $element ({};\r\n      setpath($element | .path | split(&quot;\\/&quot;);\r\n              $element | {NameID, Name}))\r\n\r\nWith your input, this produces the following:\r\n\r\n    {\r\n      &quot;1042&quot;: {\r\n        &quot;NameID&quot;: &quot;200&quot;,\r\n        &quot;Name&quot;: &quot;related&quot;,\r\n        &quot;1561&quot;: {\r\n          &quot;NameID&quot;: &quot;  230&quot;,\r\n          &quot;Name&quot;: &quot;Patr&quot;,\r\n          &quot;1370&quot;: {\r\n            &quot;NameID&quot;: &quot;    230&quot;,\r\n            &quot;Name&quot;: &quot;Dog&quot;\r\n          },\r\n          &quot;1560&quot;: {\r\n            &quot;NameID&quot;: &quot;    230.1&quot;,\r\n            &quot;Name&quot;: &quot;Ort&quot;\r\n          },\r\n          &quot;213&quot;: {\r\n            &quot;NameID&quot;: &quot;    232&quot;,\r\n            &quot;Name&quot;: &quot;Jim&quot;\r\n          }\r\n        }\r\n      }\r\n    }\r\n\r\nNow it&#39;s just a question of munging, which can be done using the following helper function:\r\n\r\n    def promote:\r\n      . as $in\r\n      | (if .NameID then {(.NameID): .Name } else {} end) as $base\r\n      | del(.NameID) | del(.Name)\r\n      | if length == 0 then $base\r\n        else $base + {Children: (reduce keys_unsorted[] as $k ([]; . + [$in[$k] | promote] ))}\r\n        end;\r\n\r\nWith this def, the solution becomes:\r\n\r\n    reduce .[] as $element ({};\r\n      setpath($element | .path | split(&quot;\\/&quot;);\r\n              $element | {NameID, Name}))\r\n    | promote\r\n    | .Children\r\n\r\n## Output\r\n\r\n    [\r\n      {\r\n        &quot;200&quot;: &quot;related&quot;,\r\n        &quot;Children&quot;: [\r\n          {\r\n            &quot;  230&quot;: &quot;Patr&quot;,\r\n            &quot;Children&quot;: [\r\n              {\r\n                &quot;    230&quot;: &quot;Dog&quot;\r\n              },\r\n              {\r\n                &quot;    230.1&quot;: &quot;Ort&quot;\r\n              },\r\n              {\r\n                &quot;    232&quot;: &quot;Jim&quot;\r\n              }\r\n            ]\r\n          }\r\n        ]\r\n      }\r\n    ]\r\n\r\n\r\n\r\n",
                "title": "reformat output of hierarchical data, based on an element"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1543270912,
        "creation_date": 1543259190,
        "last_edit_date": 1543270912,
        "question_id": 53487500,
        "body_markdown": "Given the following json, which contains hierarchical data, i need to convert the following flat structure into a parent child json output format:\r\n\r\n    [{\r\n    \t&quot;ID&quot;: 1042,\r\n    \t&quot;NameID&quot;: &quot;200&quot;,\r\n    \t&quot;Name&quot;: &quot;related&quot;,\r\n    \t&quot;path&quot;: &quot;1042&quot;\r\n    }, {\r\n    \t&quot;ID&quot;: 1561,\r\n    \t&quot;NameID&quot;: &quot;  230&quot;,\r\n    \t&quot;Name&quot;: &quot;Patr&quot;,\r\n    \t&quot;FatherID&quot;: 1042,\r\n    \t&quot;path&quot;: &quot;1042\\/1561&quot;\r\n    }, {\r\n    \t&quot;ID&quot;: 1370,\r\n    \t&quot;NameID&quot;: &quot;    230&quot;,\r\n    \t&quot;Name&quot;: &quot;Dog&quot;,\r\n    \t&quot;FatherID&quot;: 1561,\r\n    \t&quot;path&quot;: &quot;1042\\/1561\\/1370&quot;\r\n    }, {\r\n    \t&quot;ID&quot;: 1560,\r\n    \t&quot;NameID&quot;: &quot;    230.1&quot;,\r\n    \t&quot;Name&quot;: &quot;Ort&quot;,\r\n    \t&quot;FatherID&quot;: 1561,\r\n    \t&quot;path&quot;: &quot;1042\\/1561\\/1560&quot;\r\n    }, {\r\n    \t&quot;ID&quot;: 213,\r\n    \t&quot;NameID&quot;: &quot;    232&quot;,\r\n    \t&quot;Name&quot;: &quot;Jim&quot;,\r\n    \t&quot;FatherID&quot;: 1561,\r\n    \t&quot;path&quot;: &quot;1042\\/1561\\/213&quot;\r\n    }]\r\n\r\nHow i could get an output like below, based on the path hierarchy?:\r\n\r\ni have replaced the first values only, since i need to show that the depth may go on and on...\r\n\r\n    [\r\n      {\r\n        &quot;200&quot;: &quot;related&quot;,\r\n        &quot;Children&quot;: [\r\n          {\r\n            &quot;  230&quot;: &quot;Patr&quot;,\r\n            &quot;Children&quot;: [\r\n              {\r\n                &quot;230.1&quot;: &quot;Ort&quot;,\r\n                &quot;Children&quot;: [\r\n                  {\r\n                    &quot;NameID&quot;: &quot;Name&quot;,\r\n                    &quot;Children&quot;: [\r\n                      {\r\n                        &quot;NameID&quot;: &quot;Name&quot;,\r\n                        &quot;children&quot;: [\r\n                          {\r\n                            &quot;NameID&quot;: &quot;Name&quot;\r\n                          },\r\n                          {\r\n                            &quot;NameID&quot;: &quot;Name&quot;\r\n                          }\r\n                        ]\r\n                      },\r\n                      {\r\n                        &quot;NameID&quot;: &quot;Name&quot;,\r\n                        &quot;children&quot;: [\r\n                          {\r\n                            &quot;NameID&quot;: &quot;Name&quot;\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/53487500/reformat-output-of-hierarchical-data-based-on-an-element",
        "title": "reformat output of hierarchical data, based on an element"
    },
    {
        "tags": [
            "json",
            "jq",
            "data-partitioning"
        ],
        "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": 1543291842,
                "post_id": 53491351,
                "comment_id": 93855016,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 277928,
                    "reputation": 79,
                    "user_id": 572213,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/ba0b18ddcf71fb0f84cb166244f08cef?s=256&d=identicon&r=PG",
                    "display_name": "ramfree17",
                    "link": "https://stackoverflow.com/users/572213/ramfree17"
                },
                "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": 1543296200,
                "post_id": 53491351,
                "comment_id": 93856065,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1543307768,
                "last_edit_date": 1543307768,
                "creation_date": 1543303052,
                "answer_id": 53494535,
                "question_id": 53491351,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is a solution which uses `awk` to write the distinct files.  The solution assumes that the dates for each measure are the same and in the same order, but imposes no limit on the number of distinct dates, or the number of distinct measures.\r\n\r\n    jq -c &#39;range(0; .measures[0].history|length) as $i\r\n      | (.measures[0].history[$i].date|gsub(&quot;[^0-9]&quot;;&quot;&quot;)),  # basis of filename\r\n        reduce range(0; .measures|length) as $j (.;\r\n          .measures[$j].history |= [.[$i]])&#39; input.json |\r\n    awk -F\\\\t &#39;fn {print &gt;&gt; fn; fn=&quot;&quot;;next}{fn=&quot;output-&quot; $1 &quot;.json&quot;}&#39;\r\n\r\n## Comments\r\nThe choice of `awk` here is just for convenience.\r\n\r\nThe disadvantage of this approach is that if each file is to be neatly formatted, an additional run of a pretty-printer (such as jq) would be required for each file.  Thus, if the output in each file is required to be neat, a case could be made for running jq once for each date, thus obviating the need for the post-processing (`awk`) step.\r\n\r\nIf the dates of the measures are not in lock-step, then the same approach as above could still be used, but of course the gathering of the dates and the corresponding measures would have to be done differently.\r\n\r\n## Output\r\nThe first two lines produced by the invocation of jq above are as follows:\r\n\r\n    &quot;201811181237080000&quot;\r\n    {&quot;paging&quot;:{&quot;pageIndex&quot;:1,&quot;pageSize&quot;:100,&quot;total&quot;:3},&quot;measures&quot;:[{&quot;metric&quot;:&quot;coverage&quot;,&quot;history&quot;:[{&quot;date&quot;:&quot;2018-11-18T12:37:08+0000&quot;,&quot;value&quot;:&quot;100.0&quot;}]},{&quot;metric&quot;:&quot;bugs&quot;,&quot;history&quot;:[{&quot;date&quot;:&quot;2018-11-18T12:37:08+0000&quot;,&quot;value&quot;:&quot;0&quot;}]},{&quot;metric&quot;:&quot;vulnerabilities&quot;,&quot;history&quot;:[{&quot;date&quot;:&quot;2018-11-18T12:37:08+0000&quot;,&quot;value&quot;:&quot;0&quot;}]}]}\r\n\r\n\r\n\r\n",
                "title": "Remove matching/non-matching elements of a nested array using jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1543802327,
                "last_edit_date": 1543802327,
                "creation_date": 1543774297,
                "answer_id": 53583161,
                "question_id": 53491351,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "In the comments, the following addendum to the original question appeared:\r\n\r\n&gt; is there a variation wherein the filtering is based on the date value and not the position? It is not guaranteed that the order will be the same or the number of elements in each metric is going to be the same (i.e. some dates may be missing &quot;bugs&quot;, some might have additional metric such as &quot;complexity&quot;).\r\n\r\nThe following will produce a stream of JSON objects, one per date.  This stream can be annotated with the date as per my previous answer, which shows how to use these annotations to create the various files.  For ease of understanding, we use two helper functions:\r\n\r\n    def dates:\r\n      INDEX(.measures[].history[].date; .)\r\n      | keys;\r\n    \r\n    def gather($date): map(select(.date==$date));\r\n    \r\n    dates[] as $date\r\n    | .measures |= map( .history |= gather($date) )\r\n\r\n## INDEX/2\r\n\r\nIf your jq does not have `INDEX/2`, now would be an excellent time to upgrade, but in case that&#39;s not feasible, here is its def:\r\n\r\n    def INDEX(stream; idx_expr):\r\n      reduce stream as $row ({};\r\n        .[$row|idx_expr|\r\n          if type != &quot;string&quot; then tojson\r\n          else .\r\n          end] |= $row);\r\n\r\n\r\n",
                "title": "Remove matching/non-matching elements of a nested array using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 4,
        "last_activity_date": 1543802327,
        "creation_date": 1543280675,
        "last_edit_date": 1543306558,
        "question_id": 53491351,
        "body_markdown": "I need to split the results of a sonarqube analysis history into individual files. Assuming a starting input below,  \r\n\r\n        {\r\n      &quot;paging&quot;: {\r\n        &quot;pageIndex&quot;: 1,\r\n        &quot;pageSize&quot;: 100,\r\n        &quot;total&quot;: 3\r\n      },\r\n      &quot;measures&quot;: [\r\n        {\r\n          &quot;metric&quot;: &quot;coverage&quot;,\r\n          &quot;history&quot;: [\r\n            {\r\n              &quot;date&quot;: &quot;2018-11-18T12:37:08+0000&quot;,\r\n              &quot;value&quot;: &quot;100.0&quot;\r\n            },\r\n            {\r\n              &quot;date&quot;: &quot;2018-11-21T12:22:39+0000&quot;,\r\n              &quot;value&quot;: &quot;100.0&quot;\r\n            },\r\n            {\r\n              &quot;date&quot;: &quot;2018-11-21T13:09:02+0000&quot;,\r\n              &quot;value&quot;: &quot;100.0&quot;\r\n            }\r\n          ]\r\n        },\r\n        {\r\n          &quot;metric&quot;: &quot;bugs&quot;,\r\n          &quot;history&quot;: [\r\n            {\r\n              &quot;date&quot;: &quot;2018-11-18T12:37:08+0000&quot;,\r\n              &quot;value&quot;: &quot;0&quot;\r\n            },\r\n            {\r\n              &quot;date&quot;: &quot;2018-11-21T12:22:39+0000&quot;,\r\n              &quot;value&quot;: &quot;0&quot;\r\n            },\r\n            {\r\n              &quot;date&quot;: &quot;2018-11-21T13:09:02+0000&quot;,\r\n              &quot;value&quot;: &quot;0&quot;\r\n            }\r\n          ]\r\n        },\r\n        {\r\n          &quot;metric&quot;: &quot;vulnerabilities&quot;,\r\n          &quot;history&quot;: [\r\n            {\r\n              &quot;date&quot;: &quot;2018-11-18T12:37:08+0000&quot;,\r\n              &quot;value&quot;: &quot;0&quot;\r\n            },\r\n            {\r\n              &quot;date&quot;: &quot;2018-11-21T12:22:39+0000&quot;,\r\n              &quot;value&quot;: &quot;0&quot;\r\n            },\r\n            {\r\n              &quot;date&quot;: &quot;2018-11-21T13:09:02+0000&quot;,\r\n              &quot;value&quot;: &quot;0&quot;\r\n            }\r\n          ]\r\n        }\r\n      ]\r\n    }\r\n\r\nHow do I use jq to clean the results so it only retains the history array entries for each element? The desired output is something like this (output-20181118123808.json for analysis done on &quot;2018-11-18T12:37:08+0000&quot;):\r\n\r\n    {\r\n      &quot;paging&quot;: {\r\n        &quot;pageIndex&quot;: 1,\r\n        &quot;pageSize&quot;: 100,\r\n        &quot;total&quot;: 3\r\n      },\r\n      &quot;measures&quot;: [\r\n        {\r\n          &quot;metric&quot;: &quot;coverage&quot;,\r\n          &quot;history&quot;: [\r\n            {\r\n              &quot;date&quot;: &quot;2018-11-18T12:37:08+0000&quot;,\r\n              &quot;value&quot;: &quot;100.0&quot;\r\n            }\r\n          ]\r\n        },\r\n        {\r\n          &quot;metric&quot;: &quot;bugs&quot;,\r\n          &quot;history&quot;: [\r\n            {\r\n              &quot;date&quot;: &quot;2018-11-18T12:37:08+0000&quot;,\r\n              &quot;value&quot;: &quot;0&quot;\r\n            }\r\n          ]\r\n        },\r\n        {\r\n          &quot;metric&quot;: &quot;vulnerabilities&quot;,\r\n          &quot;history&quot;: [\r\n            {\r\n              &quot;date&quot;: &quot;2018-11-18T12:37:08+0000&quot;,\r\n              &quot;value&quot;: &quot;0&quot;\r\n            }\r\n          ]\r\n        }\r\n      ]\r\n    }\r\n\r\nI am lost on how to operate only on the sub-elements while leaving the parent structure intact. The naming of the JSON file is going to be handled externally from the jq utility. The sample data provided will be split into 3 files. Some other input can have a variable number of entries, some may be up to 10000. Thanks.\r\n",
        "link": "https://stackoverflow.com/questions/53491351/remove-matching-non-matching-elements-of-a-nested-array-using-jq",
        "title": "Remove matching/non-matching elements of a nested array using jq"
    },
    {
        "tags": [
            "python",
            "json",
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3037415,
                    "reputation": 736,
                    "user_id": 2575155,
                    "user_type": "registered",
                    "accept_rate": 42,
                    "profile_image": "https://www.gravatar.com/avatar/05aff69421d88ba7accab8cb4c062fc6?s=256&d=identicon&r=PG",
                    "display_name": "marjun",
                    "link": "https://stackoverflow.com/users/2575155/marjun"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1543324245,
                "post_id": 53496277,
                "comment_id": 93869986,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3379153,
                    "reputation": 209476,
                    "user_id": 2836621,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/suHg4.jpg?s=256",
                    "display_name": "Mark Setchell",
                    "link": "https://stackoverflow.com/users/2836621/mark-setchell"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1543330935,
                "post_id": 53496277,
                "comment_id": 93874210,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1543387465,
                "last_edit_date": 1543387465,
                "creation_date": 1543331755,
                "answer_id": 53502700,
                "question_id": 53496277,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "First, when setting json_var, you need to quote the string:\r\n\r\n    json_var=&#39;[ { &quot;Key&quot;: &quot;raw/bene/test/nd_OneP4.tgz&quot; }, { &quot;Key&quot;: &quot;raw/bene/test/nd_OneP4.tgz&quot; } ]&#39;\r\n\r\nSecond, there&#39;s no need to use `to_entries`: the string you want to test is accessible via `.Key`:\r\n\r\n    echo $json_var |\r\n      jq -r &#39; .[] | select(.Key | test(&quot;\\\\.tgz$&quot;)).Key&#39;\r\n\r\nNotice also the the argument of `test` must be the JSON representation of a regex.\r\n\r\nThird, in your particular case at least, the above can be simplified to:\r\n\r\n    echo $json_var | \r\n      jq -r &#39; .[][] | select( test(&quot;\\\\.tgz$&quot;))&#39;\r\n",
                "title": "jq parsing value with extension .tgz"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1543387465,
        "creation_date": 1543310312,
        "last_edit_date": 1543324808,
        "question_id": 53496277,
        "body_markdown": "Im trying to get values in with file extension &quot;**.tgz**&quot; with regular expression. But getting the jq error.\r\n\r\n    json_var=[ { &quot;Key&quot;: &quot;raw/bene/test/nd_OneP4.tgz&quot; }, { &quot;Key&quot;: &quot;raw/bene/test/nd_OneP4.tgz&quot; } ]\r\n    \r\n    echo $json_var | jq -r &#39; .[] | to_entries | map(select(.key | test(&quot;*.tgz&quot;)).value)&#39;\r\n\r\nJq error: \r\n\r\n    jq: error (at &lt;stdin&gt;:1): number (0) cannot be matched, as it is not a string\r\n\r\n",
        "link": "https://stackoverflow.com/questions/53496277/jq-parsing-value-with-extension-tgz",
        "title": "jq parsing value with extension .tgz"
    },
    {
        "tags": [
            "json",
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 4616979,
                    "reputation": 8319,
                    "user_id": 3743145,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/680680d82143e4d33dc569913e5ef8c5?s=256&d=identicon&r=PG",
                    "display_name": "kyb",
                    "link": "https://stackoverflow.com/users/3743145/kyb"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1543654470,
                "post_id": 53496484,
                "comment_id": 94003406,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1543387101,
                "last_edit_date": 1543387101,
                "creation_date": 1543342318,
                "answer_id": 53505721,
                "question_id": 53496484,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Slurping should, in general, be avoided if possible.  If your jq has `input`, you could simply write:\r\n\r\n    echo &#39;{&quot;a&quot;:0,&quot;b&quot;:{&quot;c&quot;:&quot;C&quot;}}{&quot;x&quot;:33}{&quot;asd&quot;:889}&#39; |\r\n      jq -n input\r\n\r\nIf your jq does not have `input`, now would be a great time to upgrade to jq 1.6.  If that is not an option, then by all means use the -s option, e.g. `jq -s &#39;.[0]&#39;`",
                "title": "Split multiple input JSONs with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1543387101,
        "creation_date": 1543310998,
        "question_id": 53496484,
        "body_markdown": "Given a JSON line\r\n\r\n    {&quot;a&quot;:0,&quot;b&quot;:{&quot;c&quot;:&quot;C&quot;}}{&quot;x&quot;:33}{&quot;asd&quot;:889}\r\n\r\nof 3 independent JSON objects.\r\n\r\nAnd need to handle then one by one. It would be nice to have something like \r\n\r\n    echo &quot;$json&quot; | jq --first-one\r\n\r\nExpected output:\r\n\r\n    {&quot;a&quot;:0,&quot;b&quot;:{&quot;c&quot;:&quot;C&quot;}}\r\n\r\nI found the only command which can remove first object and output others. [`inputs`](https://stedolan.github.io/jq/manual/#IO)\r\n\r\n    echo &#39;{&quot;a&quot;:0,&quot;b&quot;:{&quot;c&quot;:&quot;C&quot;}}{&quot;x&quot;:33}{&quot;asd&quot;:889}&#39; | jq -c inputs\r\n\r\noutput:\r\n\r\n    {&quot;x&quot;:33}\r\n    {&quot;asd&quot;:889}\r\n\r\n## How to read only first object from input stream and do not touch the rest objects?\r\n\r\n### Workaround\r\nWhile writing this Q I found a workaround, but it looks cumbersome\r\n\r\n    echo &#39;{&quot;a&quot;:0,&quot;b&quot;:{&quot;c&quot;:&quot;C&quot;}}{&quot;x&quot;:33}{&quot;asd&quot;:889}&#39; | jq -c . | head -1\r\n\r\nsimply get first line...",
        "link": "https://stackoverflow.com/questions/53496484/split-multiple-input-jsons-with-jq",
        "title": "Split multiple input JSONs with jq"
    },
    {
        "tags": [
            "json",
            "group-by",
            "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": 1543342107,
                "post_id": 53504045,
                "comment_id": 93880909,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1543341772,
                "creation_date": 1543341772,
                "answer_id": 53505591,
                "question_id": 53504045,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "    def aggregate_by(f; g):\r\n      reduce .[] as $x  ({}; .[$x|f] += [$x|g]);\r\n    \r\n    map( {rc: (.rc|.[&quot;$event&quot;]), org} )\r\n    | aggregate_by(.rc; .org)\r\n    | map_values(unique)\r\n\r\nWith your sample input modified to make it a JSON array, the above jq program produces:\r\n\r\n    {&quot;13&quot;:[&quot;AB KIO&quot;,&quot;TΙ UIH&quot;],&quot;17&quot;:[&quot;GH SVS&quot;]}\r\n\r\nOf course many variations are possible, but there is something to be said for postponing the uniquification.",
                "title": "group by and create a transformed json output"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1543342925,
        "creation_date": 1543336038,
        "last_edit_date": 1543342925,
        "question_id": 53504045,
        "body_markdown": "i have data which look like the following\r\nand i need to transform them.\r\n\r\n    [{&quot;us&quot;:{&quot;$event&quot;:&quot;5bbf4a4f43d8950b5b0cc6d2&quot;},&quot;org&quot;:&quot;TΙ UIH&quot;,&quot;rc&quot;:{&quot;$event&quot;:&quot;13&quot;}},\r\n    {&quot;us&quot;:{&quot;$event&quot;:&quot;5bbf4a4f43d8950b5b0cc6d3&quot;},&quot;org&quot;:&quot;TΙ UIH&quot;,&quot;rc&quot;:{&quot;$event&quot;:&quot;13&quot;}},\r\n    {&quot;us&quot;:{&quot;$event&quot;:&quot;5bbf4a4f43d8950b5b0cc6d4&quot;},&quot;org&quot;:&quot;AB KIO&quot;,&quot;rc&quot;:{&quot;$event&quot;:&quot;13&quot;}},\r\n    {&quot;us&quot;:{&quot;$event&quot;:&quot;5bbf4a4f43d8950b5b0cc6d5&quot;},&quot;org&quot;:&quot;GH SVS&quot;,&quot;rc&quot;:{&quot;$event&quot;:&quot;17&quot;}}]\r\n\r\nwhat i use:\r\n\r\n    `[group_by(.org, .rc.&quot;$event&quot;)[] | [.[0].rc.&quot;$event&quot;, .[0].org, length]] |` sort_by(.[0])[] \r\n\r\noutput i get:\r\n\r\n    [\r\n      &quot;13&quot;,\r\n      &quot;AB KIO&quot;,\r\n      1\r\n    ]\r\n    [\r\n      &quot;17&quot;,\r\n      &quot;GH SVS&quot;,\r\n      1\r\n    ]\r\n    [\r\n      &quot;13&quot;,\r\n      &quot;TΙ UIH&quot;,\r\n      2\r\n    ]\r\n\r\nHow could i get the following format as output?\r\n\r\n    key1: [&quot;&quot;,&quot;&quot;]\r\n    key2: [&quot;&quot;,&quot;&quot;]\r\n\r\nwhere each key us the number of the event, and in the array, we have the unique values of each event&#39;s org.\r\n\r\noutput \r\n13: [&quot;AB KIO&quot;,&quot;TΙ UIH&quot;]\r\n17: [&quot;GH SVS&quot;]\r\n",
        "link": "https://stackoverflow.com/questions/53504045/group-by-and-create-a-transformed-json-output",
        "title": "group by and create a transformed json output"
    },
    {
        "tags": [
            "json",
            "bash",
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1143565,
                    "reputation": 535973,
                    "user_id": 1126841,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa05233b2357f8d11c22ef4cfc7bb85c?s=256&d=identicon&r=PG",
                    "display_name": "chepner",
                    "link": "https://stackoverflow.com/users/1126841/chepner"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1543343583,
                "post_id": 53505949,
                "comment_id": 93881715,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6947494,
                    "reputation": 31,
                    "user_id": 5331366,
                    "user_type": "registered",
                    "profile_image": "https://lh6.googleusercontent.com/-wsNdisd3AJo/AAAAAAAAAAI/AAAAAAAAAAA/WOuDa6Xx64U/s256-rj/photo.jpg",
                    "display_name": "GillesF",
                    "link": "https://stackoverflow.com/users/5331366/gillesf"
                },
                "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": 1543346748,
                "post_id": 53505949,
                "comment_id": 93883263,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1543344510,
                "creation_date": 1543344510,
                "answer_id": 53506266,
                "question_id": 53505949,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Your question doesn&#39;t indicate very precisely what output you want, but hopefully you&#39;ll be able to adapt the following:\r\n\r\n    .value as $dict\r\n    | .status\r\n    | to_entries\r\n    | map( [.key, .value, $dict[.key]] )\r\n    | .[]\r\n    | @csv\r\n\r\nWith your input, and invoking jq with the -r option, this produces:\r\n\r\n    &quot;57&quot;,&quot;b&quot;,57.1",
                "title": "jq: group objects by string"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1543346493,
        "creation_date": 1543343200,
        "last_edit_date": 1543346493,
        "question_id": 53505949,
        "body_markdown": "I have some json from eurostat, which looks like this: \r\n\r\n\r\n    {\r\n      &quot;version&quot;: &quot;2.0&quot;,\r\n      &quot;label&quot;: &quot;Principaux agr&#233;gats des administrations publiques, y compris recettes et d&#233;penses&quot;,\r\n      &quot;href&quot;: &quot;http://ec.europa.eu/eurostat/wdds/rest/data/v2.1/json/fr/gov_10a_main?unit=PC_GDP&amp;na_item=TE&amp;sector=S13&amp;time=2008&amp;time=2009&amp;time=2010&amp;time=2011&amp;time=2012&amp;time=2013&amp;time=2014&amp;time=2015&amp;time=2016&amp;time=2017&amp;geo=DE&amp;geo=AT&amp;geo=BE&amp;geo=BG&amp;geo=CY&amp;geo=HR&amp;geo=FI&quot;,\r\n      &quot;source&quot;: &quot;Eurostat&quot;,\r\n      &quot;updated&quot;: &quot;2018-10-26&quot;,\r\n      &quot;status&quot;: {\r\n        &quot;57&quot;: &quot;b&quot;\r\n      },\r\n      &quot;extension&quot;: {\r\n        &quot;datasetId&quot;: &quot;gov_10a_main&quot;,\r\n        &quot;lang&quot;: &quot;FR&quot;,\r\n        &quot;description&quot;: null,\r\n        &quot;subTitle&quot;: null,\r\n        &quot;status&quot;: {\r\n          &quot;label&quot;: {\r\n            &quot;b&quot;: &quot;rupture de s&#233;rie&quot;\r\n          }\r\n        }\r\n      },\r\n      &quot;class&quot;: &quot;dataset&quot;,\r\n      &quot;value&quot;: {\r\n        &quot;0&quot;: 49.9,\r\n        &quot;1&quot;: 54.1,\r\n        &quot;2&quot;: 52.8,\r\n        &quot;3&quot;: 50.9,\r\n        &quot;4&quot;: 51.2,\r\n        &quot;5&quot;: 51.6,\r\n        &quot;6&quot;: 52.4,\r\n        &quot;7&quot;: 51.1,\r\n        &quot;8&quot;: 50.3,\r\n        &quot;9&quot;: 49.2,\r\n        &quot;10&quot;: 50.3,\r\n        &quot;11&quot;: 54.2,\r\n        &quot;12&quot;: 53.3,\r\n        &quot;13&quot;: 54.5,\r\n        &quot;14&quot;: 55.9,\r\n        &quot;15&quot;: 55.8,\r\n        &quot;16&quot;: 55.3,\r\n        &quot;17&quot;: 53.7,\r\n        &quot;18&quot;: 53,\r\n        &quot;19&quot;: 52.2,\r\n        &quot;20&quot;: 37.1,\r\n        &quot;21&quot;: 39.4,\r\n        &quot;22&quot;: 36.2,\r\n        &quot;23&quot;: 33.8,\r\n        &quot;24&quot;: 34.5,\r\n        &quot;25&quot;: 37.7,\r\n        &quot;26&quot;: 43.1,\r\n        &quot;27&quot;: 40.5,\r\n        &quot;28&quot;: 35.1,\r\n        &quot;29&quot;: 35.1,\r\n        &quot;30&quot;: 38.4,\r\n        &quot;31&quot;: 42.1,\r\n        &quot;32&quot;: 42,\r\n        &quot;33&quot;: 42.3,\r\n        &quot;34&quot;: 41.9,\r\n        &quot;35&quot;: 41.9,\r\n        &quot;36&quot;: 48.8,\r\n        &quot;37&quot;: 40.6,\r\n        &quot;38&quot;: 38,\r\n        &quot;39&quot;: 37.5,\r\n        &quot;40&quot;: 43.6,\r\n        &quot;41&quot;: 47.6,\r\n        &quot;42&quot;: 47.3,\r\n        &quot;43&quot;: 44.7,\r\n        &quot;44&quot;: 44.3,\r\n        &quot;45&quot;: 44.7,\r\n        &quot;46&quot;: 44,\r\n        &quot;47&quot;: 43.7,\r\n        &quot;48&quot;: 43.9,\r\n        &quot;49&quot;: 43.9,\r\n        &quot;50&quot;: 48.3,\r\n        &quot;51&quot;: 54.8,\r\n        &quot;52&quot;: 54.8,\r\n        &quot;53&quot;: 54.4,\r\n        &quot;54&quot;: 56.2,\r\n        &quot;55&quot;: 57.5,\r\n        &quot;56&quot;: 58.1,\r\n        &quot;57&quot;: 57.1,\r\n        &quot;58&quot;: 55.9,\r\n        &quot;59&quot;: 54,\r\n        &quot;60&quot;: 45.3,\r\n        &quot;61&quot;: 48.3,\r\n        &quot;62&quot;: 48,\r\n        &quot;63&quot;: 48.5,\r\n        &quot;64&quot;: 47.8,\r\n        &quot;65&quot;: 47.6,\r\n        &quot;66&quot;: 48.1,\r\n        &quot;67&quot;: 48.3,\r\n        &quot;68&quot;: 46.9,\r\n        &quot;69&quot;: 45\r\n      },\r\n      &quot;dimension&quot;: {\r\n        &quot;unit&quot;: {\r\n          &quot;label&quot;: &quot;unit&quot;,\r\n          &quot;category&quot;: {\r\n            &quot;index&quot;: {\r\n              &quot;PC_GDP&quot;: 0\r\n            },\r\n            &quot;label&quot;: {\r\n              &quot;PC_GDP&quot;: &quot;Pourcentage du produit int&#233;rieur brut (PIB)&quot;\r\n            }\r\n          }\r\n        },\r\n        &quot;sector&quot;: {\r\n          &quot;label&quot;: &quot;sector&quot;,\r\n          &quot;category&quot;: {\r\n            &quot;index&quot;: {\r\n              &quot;S13&quot;: 0\r\n            },\r\n            &quot;label&quot;: {\r\n              &quot;S13&quot;: &quot;Administrations publiques&quot;\r\n            }\r\n          }\r\n        },\r\n        &quot;na_item&quot;: {\r\n          &quot;label&quot;: &quot;na_item&quot;,\r\n          &quot;category&quot;: {\r\n            &quot;index&quot;: {\r\n              &quot;TE&quot;: 0\r\n            },\r\n            &quot;label&quot;: {\r\n              &quot;TE&quot;: &quot;Total des d&#233;penses des administrations publiques&quot;\r\n            }\r\n          }\r\n        },\r\n        &quot;geo&quot;: {\r\n          &quot;label&quot;: &quot;geo&quot;,\r\n          &quot;category&quot;: {\r\n            &quot;index&quot;: {\r\n              &quot;AT&quot;: 0,\r\n              &quot;BE&quot;: 1,\r\n              &quot;BG&quot;: 2,\r\n              &quot;CY&quot;: 3,\r\n              &quot;DE&quot;: 4,\r\n              &quot;FI&quot;: 5,\r\n              &quot;HR&quot;: 6\r\n            },\r\n            &quot;label&quot;: {\r\n              &quot;AT&quot;: &quot;Autriche&quot;,\r\n              &quot;BE&quot;: &quot;Belgique&quot;,\r\n              &quot;BG&quot;: &quot;Bulgarie&quot;,\r\n              &quot;CY&quot;: &quot;Chypre&quot;,\r\n              &quot;DE&quot;: &quot;Allemagne (jusqu&#39;en 1990, ancien territoire de la RFA)&quot;,\r\n              &quot;FI&quot;: &quot;Finlande&quot;,\r\n              &quot;HR&quot;: &quot;Croatie&quot;\r\n            }\r\n          }\r\n        },\r\n        &quot;time&quot;: {\r\n          &quot;label&quot;: &quot;time&quot;,\r\n          &quot;category&quot;: {\r\n            &quot;index&quot;: {\r\n              &quot;2008&quot;: 0,\r\n              &quot;2009&quot;: 1,\r\n              &quot;2010&quot;: 2,\r\n              &quot;2011&quot;: 3,\r\n              &quot;2012&quot;: 4,\r\n              &quot;2013&quot;: 5,\r\n              &quot;2014&quot;: 6,\r\n              &quot;2015&quot;: 7,\r\n              &quot;2016&quot;: 8,\r\n              &quot;2017&quot;: 9\r\n            },\r\n            &quot;label&quot;: {\r\n              &quot;2008&quot;: &quot;2008&quot;,\r\n              &quot;2009&quot;: &quot;2009&quot;,\r\n              &quot;2010&quot;: &quot;2010&quot;,\r\n              &quot;2011&quot;: &quot;2011&quot;,\r\n              &quot;2012&quot;: &quot;2012&quot;,\r\n              &quot;2013&quot;: &quot;2013&quot;,\r\n              &quot;2014&quot;: &quot;2014&quot;,\r\n              &quot;2015&quot;: &quot;2015&quot;,\r\n              &quot;2016&quot;: &quot;2016&quot;,\r\n              &quot;2017&quot;: &quot;2017&quot;\r\n            }\r\n          }\r\n        }\r\n      },\r\n      &quot;id&quot;: [\r\n        &quot;unit&quot;,\r\n        &quot;sector&quot;,\r\n        &quot;na_item&quot;,\r\n        &quot;geo&quot;,\r\n        &quot;time&quot;\r\n      ],\r\n      &quot;size&quot;: [\r\n        1,\r\n        1,\r\n        1,\r\n        7,\r\n        10\r\n      ]\r\n    }\r\n\r\nI would like to produce a csv file.\r\n\r\nFirst, I need to concatenate .status with .value by string (sorry for my poor json knowledge) --&gt; &quot;status&quot;:{&quot;57&quot;: &quot;b&quot;} with &quot;value&quot;:{&quot;57&quot;: 57.1}.\r\n\r\nSecond, I need to produce the same table as the original one (downloaded from eurostat).\r\n\r\nI try many jq commands, like:\r\n\r\n    .status,.value | to_entries\r\n\r\nI&#39;m far from finding a solution.\r\n\r\nAny help? I think map or map_values/group_by command are needed, but I don&#39;t really understand these functions.\r\n\r\n\r\nEDIT :\r\n\r\nI download data from [eurostat](https://ec.europa.eu/eurostat).\r\n\r\nI use their web service [here](https://ec.europa.eu/eurostat/web/json-and-unicode-web-services/about-this-service), where I can download data in json format.\r\n\r\nI would like to reproduce in shell same table as original, with jq. In my exemple, it should look like :\r\n\r\nGEO/TIME,2010,2011,2012,2013,2014,2015,2016,2017\r\nBelgique,&quot;53,3&quot;,&quot;54,5&quot;,&quot;55,9&quot;,&quot;55,8&quot;,&quot;55,3&quot;,&quot;53,7&quot;,&quot;53,0&quot;,&quot;52,2&quot;\r\nBulgarie,&quot;36,2&quot;,&quot;33,8&quot;,&quot;34,5&quot;,&quot;37,7&quot;,&quot;43,1&quot;,&quot;40,5&quot;,&quot;35,1&quot;,&quot;35,1&quot;\r\n&quot;Allemagne (jusqu&#39;en 1990, ancien territoire de la RFA)&quot;,&quot;47,3&quot;,&quot;44,7&quot;,&quot;44,3&quot;,&quot;44,7&quot;,&quot;44,0&quot;,&quot;43,7&quot;,&quot;43,9&quot;,&quot;43,9&quot;\r\nCroatie,&quot;48,0&quot;,&quot;48,5&quot;,&quot;47,8&quot;,&quot;47,6&quot;,&quot;48,1&quot;,&quot;48,3&quot;,&quot;46,9&quot;,&quot;45,0&quot;\r\nChypre,&quot;42,0&quot;,&quot;42,3&quot;,&quot;41,9&quot;,&quot;41,9&quot;,&quot;48,8&quot;,&quot;40,6&quot;,&quot;38,0&quot;,&quot;37,5&quot;\r\nFinlande,&quot;54,8&quot;,&quot;54,4&quot;,&quot;56,2&quot;,&quot;57,5&quot;,&quot;58,1&quot;,&quot;57,1&quot;,&quot;55,9&quot;,&quot;54,0&quot;\r\n\r\nBut json contain metadata, and Finlande must have 57,1b value.\r\n\r\nI hope it&#39;s more clear with this edit.\r\n\r\nAnd many thanks for your help.",
        "link": "https://stackoverflow.com/questions/53505949/jq-group-objects-by-string",
        "title": "jq: group objects by string"
    },
    {
        "tags": [
            "json",
            "bash",
            "shell",
            "sh",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3959308,
                    "reputation": 53394,
                    "user_id": 3266847,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/U0oyt.png?s=256",
                    "display_name": "Benjamin W.",
                    "link": "https://stackoverflow.com/users/3266847/benjamin-w"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1543356482,
                "post_id": 53508885,
                "comment_id": 93887731,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2863665,
                    "reputation": 5700,
                    "user_id": 2458372,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://www.gravatar.com/avatar/2851994e4c578a7caac9e89421522294?s=256&d=identicon&r=PG",
                    "display_name": "JavaDeveloper",
                    "link": "https://stackoverflow.com/users/2458372/javadeveloper"
                },
                "reply_to_user": {
                    "account_id": 3959308,
                    "reputation": 53394,
                    "user_id": 3266847,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/U0oyt.png?s=256",
                    "display_name": "Benjamin W.",
                    "link": "https://stackoverflow.com/users/3266847/benjamin-w"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1543356684,
                "post_id": 53508885,
                "comment_id": 93887806,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3959308,
                    "reputation": 53394,
                    "user_id": 3266847,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/U0oyt.png?s=256",
                    "display_name": "Benjamin W.",
                    "link": "https://stackoverflow.com/users/3266847/benjamin-w"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1543357165,
                "post_id": 53508885,
                "comment_id": 93888022,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1543357243,
                "creation_date": 1543357243,
                "answer_id": 53509111,
                "question_id": 53508885,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use a construction like:\r\n\r\n    read status1 details1 &lt; &lt;(jq -r &#39;.status + &quot; &quot; + .details&#39; &lt;&lt;&lt; &quot;${response}&quot;)\r\n\r\nYou use read to assign the different inputs to two variables (or an array, if you want), and use `jq` to print the data you need separated by whitespace.",
                "title": "How to parse JSON in shell script?"
            },
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1543358776,
                "last_edit_date": 1543358776,
                "creation_date": 1543358009,
                "answer_id": 53509273,
                "question_id": 53508885,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "First, **stop using the `-i` argument to `curl`**. That takes away the need for `awk` (or any other pruning of the header after-the-fact).\r\n\r\nSecond:\r\n\r\n    {\r\n      IFS= read -r -d &#39;&#39; status1\r\n      IFS= read -r -d &#39;&#39; details1\r\n    } &lt; &lt;(jq -r &#39;.status + &quot;\\u0000&quot; + .details + &quot;\\u0000&quot;&#39; &lt;&lt;&lt;&quot;$response&quot;)\r\n\r\nThe advantage of using a NUL as a delimiter is that it&#39;s the sole character that can&#39;t be present in the value of a C-style string (which is how shell variables&#39; values are stored).",
                "title": "How to parse JSON in shell script?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1543358067,
                "creation_date": 1543358067,
                "answer_id": 53509287,
                "question_id": 53508885,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "As Benjamin already suggested, only retrieving the json is a better way to go. Poshi&#39;s solution is solid.\r\n\r\nHowever, if you&#39;re looking for the most compact to do this, no need to save the response as a variable if the only thing your&#39;re going to do with it is extract other variables from it on a one time basis. Just pipe curl directly into:\r\n\r\n    curl &quot;whatever&quot; | jq -r &#39;[.status, .details] |@tsv&#39; \r\n\r\nor \r\n\r\n    curl &quot;whatever&quot; | jq -r &#39;[.status, .details] |join(&quot;\\t&quot;)&#39;\r\n\r\nand you&#39;ll get your values fielded for you.",
                "title": "How to parse JSON in shell script?"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 3,
        "last_activity_date": 1543378872,
        "creation_date": 1543356100,
        "last_edit_date": 1543378872,
        "question_id": 53508885,
        "body_markdown": "I run the curl command `$(curl -i -o - --silent -X GET --cert &quot;${CERT}&quot; --key &quot;${KEY}&quot; &quot;$some_url&quot;)` and save the response in the variable response. ${response} is as shown below\r\n\r\n    HTTP/1.1 200 OK\r\n    Content-Type: application/json; charset=utf-8\r\n    Content-Length: 34\r\n    Connection: keep-alive\r\n    Keep-Alive: timeout=5\r\n    X-XSS-Protection: 1; \r\n    \r\n    {&quot;status&quot;:&quot;running&quot;,&quot;details&quot;:&quot;0&quot;}\r\n\r\n\r\nI want to parse the JSON `{&quot;status&quot;:&quot;running&quot;,&quot;details&quot;:&quot;0&quot;}` and assign &#39;running&#39; and &#39;details&#39; to two different variables where I can print status and details both. Also if the status is equal to error, the script should exit. I am doing the following to achieve the task -\r\n\r\n    status1=$(echo &quot;${response}&quot; | awk &#39;/^{.*}$/&#39; | jq -r &#39;.status&#39;)\r\n    details1=$(echo &quot;${response}&quot; | awk &#39;/^{.*}$/&#39; | jq -r &#39;.details&#39;)\r\n    echo &quot;Status: ${status1}&quot;\r\n    echo &quot;Details: ${details1}&quot;\r\n    if [[ $status1 == &#39;error&#39; ]]; then\r\n        exit 1\r\n    fi\r\n\r\nInstead of parsing the JSON twice, I want to do it only once. Hence I want to combine the following lines but still assign the status and details to two separate variables -\r\n\r\n    status1=$(echo &quot;${response}&quot; | awk &#39;/^{.*}$/&#39; | jq -r &#39;.status&#39;)\r\n    details1=$(echo &quot;${response}&quot; | awk &#39;/^{.*}$/&#39; | jq -r &#39;.details&#39;)",
        "link": "https://stackoverflow.com/questions/53508885/how-to-parse-json-in-shell-script",
        "title": "How to parse JSON in shell script?"
    },
    {
        "tags": [
            "aws-cloudformation",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1543367285,
                "creation_date": 1543367285,
                "answer_id": 53510597,
                "question_id": 53510540,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You&#39;re prematurely closing the string passed to `jq` by not escaping the quotes for &quot;Project&quot; in the equality.\r\n\r\nYou can simplify by enclosing the expression with single quotes, and no escaping is necessary:\r\n\r\n    $ cat config.json | jq &#39;map(if .ParameterKey == &quot;Project&quot; then . + {&quot;ParameterValue&quot;:&quot;test&quot;} else . end)&#39;\r\n    [\r\n      {\r\n        &quot;ParameterKey&quot;: &quot;Project&quot;,\r\n        &quot;ParameterValue&quot;: &quot;test&quot;\r\n      },\r\n      {\r\n        &quot;ParameterKey&quot;: &quot;DockerInstanceType&quot;,\r\n        &quot;ParameterValue&quot;: &quot;m3.medium&quot;\r\n      }\r\n    ]\r\n\r\n",
                "title": "use jq to replace cloud formation parameter value"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1543367285,
        "creation_date": 1543366809,
        "question_id": 53510540,
        "body_markdown": "I am trying to replace project ParameterKey:Project with ParameterValue:test in the below Cloudformation parameters file \r\n\r\n   \r\n\r\n        [{\r\n      &quot;ParameterKey&quot;: &quot;Project&quot;,\r\n      &quot;ParameterValue&quot;: &quot;&lt;changeMe&gt;&quot;\r\n     }, \r\n     {\r\n      &quot;ParameterKey&quot;: &quot;DockerInstanceType&quot;,\r\n      &quot;ParameterValue&quot;: &quot;m3.medium&quot;\r\n    }]\r\n\r\nI am trying to execute below jq command \r\n\r\n    cat config.json |              \r\n      jq &quot;map(if .ParameterKey == &quot;Project&quot;\r\n              then . + {\\&quot;ParameterValue\\&quot;:\\&quot;test\\&quot;}\r\n              else .\r\n              end)&quot; &gt; populated_config.json\r\n\r\nI am getting the below error\r\n\r\n    jq: error: Project/0 is not defined at &lt;top-level&gt;, line 1:\r\n    map(if .ParameterKey == Project                        \r\n    jq: 1 compile error",
        "link": "https://stackoverflow.com/questions/53510540/use-jq-to-replace-cloud-formation-parameter-value",
        "title": "use jq to replace cloud formation parameter value"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 9,
                "is_accepted": true,
                "score": 9,
                "last_activity_date": 1543385722,
                "creation_date": 1543385722,
                "answer_id": 53513222,
                "question_id": 53512985,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This should work:\r\n\r\n    jq &#39;.[] | select(.tags | index(&quot;red&quot;) | not)&#39; fruit.json\r\n\r\nWhen you do `.tags[]`, it will go through all the elements in array `tags` one by one, that&#39;s why you get duplicate results.",
                "title": "jq - filter array does not contain"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 6,
        "last_activity_date": 1543385722,
        "creation_date": 1543384336,
        "question_id": 53512985,
        "body_markdown": "I&#39;m using the application jq to filter json files from the command line.\r\n\r\nhttps://stedolan.github.io/jq/\r\n\r\nHere&#39;s a poor example that represents the problem. How do I filter this set to include all the fruits that are not red, or not round?\r\n\r\nfruit.json:\r\n\r\n    [\r\n      {\r\n        &quot;name&quot;: &quot;banana&quot;,\r\n        &quot;tags&quot;: [\r\n          &quot;yellow&quot;,\r\n          &quot;long&quot;\r\n        ]\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;apple&quot;,\r\n        &quot;tags&quot;: [\r\n          &quot;red&quot;,\r\n          &quot;round&quot;\r\n        ]\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;orange&quot;,\r\n        &quot;tags&quot;: [\r\n          &quot;orange&quot;,\r\n          &quot;round&quot;,\r\n          &quot;colored&quot;\r\n        ]\r\n      }\r\n    ]\r\n\r\nThis finds all the red fruit:\r\n\r\n    jq &#39;.[] | select(.tags[] == &quot;red&quot;)&#39; fruit.json\r\n\r\nHow do I find all the fruit that are not red?\r\n\r\nYes, I know in this example an array of tags for different purposes is not good design. The real world data has an array for good reason. I&#39;m just looking for how to search for the records where the array does not contain a value.\r\n\r\nThis gives odd results, including duplicates which includes &quot;apple&quot; as &quot;round&quot; is not &quot;red&quot; so it matches.\r\n\r\n    jq &#39;.[] | select(.tags[] != &quot;red&quot;)&#39; fruit.json\r\n\r\nSuggestions?",
        "link": "https://stackoverflow.com/questions/53512985/jq-filter-array-does-not-contain",
        "title": "jq - filter array does not contain"
    },
    {
        "tags": [
            "json",
            "amazon-web-services",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1543411758,
                "post_id": 53520227,
                "comment_id": 93909696,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 14236857,
                    "reputation": 721,
                    "user_id": 10284437,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/e4mfN.jpg?s=256",
                    "display_name": "M&#233;vatlav&#233; Kraspek",
                    "link": "https://stackoverflow.com/users/10284437/m%c3%a9vatlav%c3%a9-kraspek"
                },
                "reply_to_user": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1543413143,
                "post_id": 53520227,
                "comment_id": 93910668,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1543429018,
                "last_edit_date": 1543429018,
                "creation_date": 1543425223,
                "answer_id": 53524782,
                "question_id": 53520227,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Given your input, the following variation of your jq program produces the desired output:\r\n\r\n    (.Reservations[].Instances[]) as $root\r\n    | ($root.Tags? | .[] | select(.Key==&quot;Name&quot;) | .Value) + &quot;:&quot; \r\n      + ($root.BlockDeviceMappings? | .[].Ebs.VolumeId) \r\n\r\nThere is actually no need to introduce the `$root` variable -- you could just as well write:\r\n\r\n    (.Reservations[].Instances[])\r\n    | (.Tags? | .[] | select(.Key==&quot;Name&quot;).Value) + &quot;:&quot; \r\n      + (.BlockDeviceMappings? | .[].Ebs.VolumeId) \r\n\r\n## Caveats\r\nThe use of &quot;?&quot; above is, I suspect, only required because your sample JSON is contrived.\r\n\r\nAlso, I am not really sure what the requirements are, so the above may not be what you actually want.  Once you&#39;ve mastered jq&#39;s syntax, you will probably want to capture your requirements more precisely.\r\n\r\n\r\n\r\n",
                "title": "jq, concatenate two values from the same sub object on different levels based on &#39;aws describe-instance&#39;"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1543448034,
        "creation_date": 1543410544,
        "last_edit_date": 1543448034,
        "question_id": 53520227,
        "body_markdown": "I know `as` statement, but can&#39;t figure out how to use it, I think I should do something like : \r\n\r\n    jq &#39;\r\n        Reservations | .[].Instances as root\r\n        $root.Tags | .[] | select(.Key==&quot;Name&quot;) | .Value , \r\n        $root.BlockDeviceMappings | $root.[].Ebs.VolumeId\r\n    &#39; file.json\r\n\r\nThe goals is to iterate over each instances and map the `Tags.Value` (select on `.Key==&quot;Name&quot;`) and the `.Ebs.VolumeId`.\r\n\r\nInput file  sample: \r\n\r\n  \r\n\r\n    {\r\n        &quot;Reservations&quot;: [\r\n            {\r\n                &quot;Instances&quot;: [\r\n                   {\r\n                         &quot;BlockDeviceMappings&quot;: [\r\n                            {\r\n                                &quot;DeviceName&quot;: &quot;/dev/xvda&quot;,\r\n                                &quot;Ebs&quot;: {\r\n                                    &quot;DeleteOnTermination&quot;: true,\r\n                                    &quot;VolumeId&quot;: &quot;vol-fffffffffffff&quot;\r\n                                 }\r\n                              }\r\n                            ],\r\n                            &quot;Tags&quot;: [\r\n                                {\r\n                                    &quot;Value&quot;: &quot;FOO - DEV - BAR - instance-name&quot;,\r\n                                    &quot;Key&quot;: &quot;Name&quot;\r\n                                }\r\n                        ]\r\n                    }\r\n                ],\r\n                &quot;ReservationId&quot;: &quot;r-xxxx&quot;\r\n            },\r\n            {\r\n                  &quot;Instances&quot;: [\r\n                        &quot;another same kind of sub-objects with different values like above repeated&quot;\r\n                    ]\r\n            }\r\n        ]\r\n    }\r\n\r\nThe last sub object :\r\n\r\n    &quot;Instances&quot;: [\r\n         &quot;another same kind of sub-objects with different values like above repeated&quot;\r\n     ]\r\n\r\nis fake, it&#39;s the sub object `Instances` repeated like the fisrt one with different values for real\r\n\r\nExpected output is :\r\n\r\n    FOO - DEV - BAR - instance-name:vol-fffffffffffff\r\n",
        "link": "https://stackoverflow.com/questions/53520227/jq-concatenate-two-values-from-the-same-sub-object-on-different-levels-based-on",
        "title": "jq, concatenate two values from the same sub object on different levels based on &#39;aws describe-instance&#39;"
    },
    {
        "tags": [
            "json",
            "key",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1543475160,
                "creation_date": 1543475160,
                "answer_id": 53533541,
                "question_id": 53533323,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using the basic form for accessing a key&#39;s value, you&#39;d write:\r\n\r\n    jq -r &#39;.[&quot;KEYNAME&quot;]&#39;\r\n\r\nexcept that at a Windows prompt, you&#39;d have to fiddle with the quotation marks (or put the filter in a file).\r\n\r\nIn modern versions of jq, the basic form can be abbreviated to just `.&quot;KEYNAME&quot;`.\r\n\r\nSo, assuming your jq is 1.5 or later, you could write (avoiding `cat`):\r\n\r\n    jq -r &#39;.&quot;aaa-bbb-ccc&quot;&#39; myjson \r\n\r\nFor further details, see the [jq FAQ][1].\r\n\r\n\r\n  [1]: https://github.com/stedolan/jq/wiki/FAQ",
                "title": "jq having issues escaping hypens in top level key"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1543475385,
        "creation_date": 1543474143,
        "last_edit_date": 1543475385,
        "question_id": 53533323,
        "body_markdown": "This is my json that i am trying to just jq to parse:\r\n\r\n    {\r\n        &quot;aaa-bbb-ccc&quot;: {\r\n            &quot;derp&quot;: blah\r\n        }\r\n    }\r\n\r\nGetting error this error:\r\n\r\n    cat myjson | jq -r .&#39;aaa-bbb-ccc&#39; \r\n    \r\n    jq: error: aaa/0 is not defined at &lt;top-level&gt;, line 1:\r\n    .aaa-bbb-ccc    \r\n    jq: error: bbb/0 is not defined at &lt;top-level&gt;, line 1:\r\n    .aaa-bbb-ccc           \r\n    jq: error: ccc/0 is not defined at &lt;top-level&gt;, line 1:\r\n\r\n",
        "link": "https://stackoverflow.com/questions/53533323/jq-having-issues-escaping-hypens-in-top-level-key",
        "title": "jq having issues escaping hypens in top level key"
    },
    {
        "tags": [
            "shell",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 8,
                "is_accepted": true,
                "score": 8,
                "last_activity_date": 1669558680,
                "last_edit_date": 1669558680,
                "creation_date": 1543477228,
                "answer_id": 53534029,
                "question_id": 53533697,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; I&#39;d like to add some data from a file into a feed that was pipe in stdout.\r\n\r\nThere are various ways to do this, depending on the shell and also the version of jq you are using.  \r\n\r\nAssuming your jq supports the --argfile option, you might find that quite congenial:\r\n\r\n    cat /tmp/a1 | jq --argfile a2 /tmp/a2 &#39;. + $a2&#39;\r\n\r\nHere is another variation that suggests some of the other possibilities:\r\n\r\n    jq -n --argfile a1 &lt;(cat /tmp/a1) --argfile a2 &lt;(cat /tmp/a2) &#39;$a1 + $a2&#39;\r\n\r\n\r\nMore interestingly:\r\n\r\n    (cat /tmp/a1 ; cat /tmp/a2) | jq &#39;. + input&#39; \r\n\r\nYou might also wish to consider using the `--slurpfile` option instead of `--argfile`, but note that `--slurpfile` always &quot;slurps&quot; the file.\r\n\r\nAnd finally an approach that should work for every version of jq:\r\n\r\n    jq -s &#39;.[0] + .[1]&#39; &lt;(cat /tmp/a1) /tmp/a2\r\n\r\nIn general, though, it&#39;s best to avoid the `-s` option.\r\n\r\n## A note on slurping\r\n\r\nIf you compare the outputs produced by:\r\n```\r\necho &#39;1 2&#39; |\r\n  jq -s --debug-dump-disasm --debug-trace  &#39;.[0], .[1]&#39;\r\n```\r\nand\r\n```\r\necho &#39;1 2&#39; |\r\n  jq --debug-dump-disasm --debug-trace  &#39;., input&#39;\r\n```\r\nyou&#39;ll notice the former has to PUSHK_UNDER to store the entire array `[1,2]`,\r\nwhereas the latter program just reads the two inputs separately.\r\n\r\nIn the first program, the memory for the array cannot be freed until after\r\nall the pointers into it have been processed, whereas in the second program,\r\nthe memory for . can be freed after the first RET.\r\n",
                "title": "jq with multiple inputs from different sources"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1543477665,
                "last_edit_date": 1543477665,
                "creation_date": 1543477325,
                "answer_id": 53534055,
                "question_id": 53533697,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could do this, where `cat` forwards its `stdin` followed by `a2`:\r\n\r\n    &lt;GENERATE a1&gt; | cat - /tmp/a2 | jq --slurp &#39;.[0] + .[1]&#39; \r\n\r\nOr this, which is a *compound statement* passing the results of two separate commands into a pipe:\r\n\r\n    { &lt;GENERATE a1&gt; ; cat /tmp/a2; } | jq --slurp &#39;.[0] + .[1]&#39; \r\n\r\nTake care to have spaces beside the curly braces and to have a semi-colon before the final one.",
                "title": "jq with multiple inputs from different sources"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1666121623,
                "creation_date": 1666121623,
                "answer_id": 74116545,
                "question_id": 53533697,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Completing peak&#39;s answer, you actually don&#39;t need redirections:\r\n\r\n`jq -n --argfile a1 /tmp/a1 --argfile a2 /tmp/a2 &#39;$a1 + $a2&#39;`\r\n\r\n",
                "title": "jq with multiple inputs from different sources"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 4,
        "last_activity_date": 1669558680,
        "creation_date": 1543475883,
        "question_id": 53533697,
        "body_markdown": "How can we mix different input sources when using jq ?\r\nFor a specific usecase, I&#39;d like to add some data from a file into a feed that was pipe in stdout.\r\n\r\n\r\n    $ echo &#39;[{&quot;a&quot;: 1}]&#39; &gt; /tmp/a1\r\n    $ echo &#39;[{&quot;a&quot;: 2}]&#39; &gt; /tmp/a2\r\n    $ jq --slurp &#39;.[0] + .[1]&#39; /tmp/a1 /tmp/a2\r\n    [\r\n      {\r\n        &quot;a&quot;: 1\r\n      },\r\n      {\r\n        &quot;a&quot;: 2\r\n      }\r\n    ]\r\n    $ cat /tmp/a1 | jq --slurp &#39;.[0] + .[1]&#39; /tmp/a2  # Expecting the same result\r\n    [\r\n      {\r\n        &quot;a&quot;: 2\r\n      }\r\n    ]\r\n\r\nAs you can see, the last command didn&#39;t interpret the piped data.\r\n\r\nRight now, I&#39;m forced to save the output from the first operation into a temporary file, so that I can do the jq merging operation, before sending it back to the network. Having a single stream would be much more efficient",
        "link": "https://stackoverflow.com/questions/53533697/jq-with-multiple-inputs-from-different-sources",
        "title": "jq with multiple inputs from different sources"
    },
    {
        "tags": [
            "amazon-web-services",
            "export-to-csv",
            "jq",
            "aws-cli"
        ],
        "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": 2,
                "creation_date": 1543511464,
                "post_id": 53544042,
                "comment_id": 93955141,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1002989,
                    "reputation": 1385,
                    "user_id": 1017466,
                    "user_type": "registered",
                    "accept_rate": 50,
                    "profile_image": "https://www.gravatar.com/avatar/73d62289ed695b520ad2a3ae80c45277?s=256&d=identicon&r=PG",
                    "display_name": "bluethundr",
                    "link": "https://stackoverflow.com/users/1017466/bluethundr"
                },
                "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": 1543520428,
                "post_id": 53544042,
                "comment_id": 93959367,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1543527033,
                "last_edit_date": 1543527033,
                "creation_date": 1543512539,
                "answer_id": 53544540,
                "question_id": 53544042,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "By default, jq emits JSON, so you will probably want to use the -r option:\r\n\r\n    $ jq -n &#39;&quot;\\&quot;a\\&quot;&quot; | [.] | @csv&#39;  \r\n    &quot;\\&quot;\\&quot;\\&quot;a\\&quot;\\&quot;\\&quot;&quot;\r\n\r\n    $ jq -nr &#39;&quot;\\&quot;a\\&quot;&quot; | [.] | @csv&#39;\r\n    &quot;&quot;&quot;a&quot;&quot;&quot;\r\n\r\nAlso, you might wish to strip the outermost double-quotation marks of any string that includes them.  Consider, for example:\r\n\r\n    $ jq -nr &#39;def s: gsub(&quot;^\\&quot;|\\&quot;$&quot;;&quot;&quot;); &quot;\\&quot;a\\&quot;&quot; | [s] | @csv&#39;\r\n    &quot;a&quot;\r\n\r\n## The whole hog\r\nIf you want to eliminate the quotation marks around strings which do not contain commas, then consider:\r\n\r\n    echo &#39;[&quot;usamzdbd2153&quot;,&quot;i-7e0d8b91&quot;,&quot;10.1.233.153&quot;,&quot;2015-02-19T16:57:57.000Z&quot;,&quot;running&quot;,&quot;tsenti&quot;]&#39; |\r\n    jq -r &#39;\r\n      def s: gsub(&quot;^\\&quot;|\\&quot;$&quot;;&quot;&quot;); \r\n      def t: if test(&quot;,&quot;) then . else s end; \r\n    \r\n      map(t) | join(&quot;\\t&quot;) | gsub(&quot;\\t&quot;;&quot;,&quot;)&#39;\r\n\r\nThe output:\r\n    \r\n    usamzdbd2153,i-7e0d8b91,10.1.233.153,2015-02-19T16:57:57.000Z,running,tsenti\r\n",
                "title": "Use JQ To Convert AWS Output To CSV"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1543527033,
        "creation_date": 1543510688,
        "last_edit_date": 1543517701,
        "question_id": 53544042,
        "body_markdown": "I&#39;m using JQ to parse the output of aws commands to CSV.\r\n\r\n    aws ec2 describe-instances | jq &#39;.Reservations[].Instances[] | [(.Tags[]|select(.Key==&quot;Name&quot;)|.Value), .InstanceId, .PrivateIpAddress, .LaunchTime, .State.Name, (.Tags[]|select(.Key==&quot;Owner&quot;)|.Value)] | @csv&#39;\r\n\r\nIt does work. But the output is putting in extra quotes and slashes that aren&#39;t needed:\r\n\r\n    &quot;\\&quot;USAWS1027-AWS\\&quot;,\\&quot;i-0be1611d\\&quot;,\\&quot;10.48.128.37\\&quot;,\\&quot;2016-11-11T16:08:14.000Z\\&quot;,\\&quot;stopped\\&quot;&quot;\r\n    &quot;\\&quot;usamzdbd2153\\&quot;,\\&quot;i-7e0d8b91\\&quot;,\\&quot;10.1.233.153\\&quot;,\\&quot;2015-02-19T16:57:57.000Z\\&quot;,\\&quot;running\\&quot;,\\&quot;tsenti\\&quot;&quot;\r\n\r\nWhy is it doing this? Is there any way I can direct the @csv option to jq to leave out the quotes and backslashes? And just leave the commas.",
        "link": "https://stackoverflow.com/questions/53544042/use-jq-to-convert-aws-output-to-csv",
        "title": "Use JQ To Convert AWS Output To CSV"
    },
    {
        "tags": [
            "regex",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1401223,
                    "reputation": 426,
                    "user_id": 1329974,
                    "user_type": "registered",
                    "accept_rate": 77,
                    "profile_image": "https://www.gravatar.com/avatar/f0e30723bd9f2047995e3a2da94a4f5d?s=256&d=identicon&r=PG",
                    "display_name": "GBSingh",
                    "link": "https://stackoverflow.com/users/1329974/gbsingh"
                },
                "reply_to_user": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1543574682,
                "post_id": 53544476,
                "comment_id": 93977192,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1543513069,
                "creation_date": 1543513069,
                "answer_id": 53544684,
                "question_id": 53544476,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Do you have GNU `grep`?\r\n\r\n    jq -r &#39;.msg.stdout_lines[2]&#39; /tmp/vaultKeys.json | grep -Po &#39;(?&lt;=: ).+&#39;",
                "title": "Regex Expression with the JQ Tool"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1543513688,
                "creation_date": 1543513688,
                "answer_id": 53544846,
                "question_id": 53544476,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "In the interests of one-stop shopping, you could for example use this invocation:\r\n\r\n\r\n    jq -r &#39;.msg.stdout_lines[2]\r\n           | capture(&quot;: (?&lt;s&gt;.*)&quot;).s&#39;\r\n\r\nOf course there are many other possibilities, depending on your precise requirements.",
                "title": "Regex Expression with the JQ Tool"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1543514419,
                "creation_date": 1543514419,
                "answer_id": 53545014,
                "question_id": 53544476,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "There are many ways, besides the obvious `| grep -Po &#39;(?&lt;=: ).+\\b&#39;` you could even use substr with awk if the string length is fixed:\r\n\r\n    jq .. | awk &#39;{print substr($1, RSTART+14)}&#39;",
                "title": "Regex Expression with the JQ Tool"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1543574733,
                "creation_date": 1543574733,
                "answer_id": 53555950,
                "question_id": 53544476,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "For this particular case you can use split instead of regex. \r\n\r\n    jq -r &#39;.msg.stdout_lines[2]|split(&quot; &quot;)[-1]&#39; file",
                "title": "Regex Expression with the JQ Tool"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": 2,
        "last_activity_date": 1543574733,
        "creation_date": 1543512301,
        "question_id": 53544476,
        "body_markdown": "I have a json file which I am using the JQ tool on to get a some lines out of it. However I now need to get some information out of this line using regex. I stuck on two parts. The first bit is that I can&#39;t figure out the regular expression to get the lines I want and the second issues is that I do now know what the correct syntax is to apply the regex along with the JQ Tool. I have tried the following syntax and get the error of &quot;unterminated regexp&quot;\r\n\r\n    jq &#39;.msg.stdout_lines[2]&#39; /tmp/vaultKeys.json | awk &#39;{gsub(/\\:(.*[\\a-zA-Z0-9]))}1&#39;\r\n\r\nMy json file is as follows:\r\n\r\n    {\r\n    &quot;msg&quot;: {\r\n    &quot;changed&quot;: true,\r\n    &quot;cmd&quot;: [\r\n      &quot;vault&quot;,\r\n      &quot;operator&quot;,\r\n      &quot;init&quot;\r\n    ],\r\n    &quot;delta&quot;: &quot;0:00:00.568974&quot;,\r\n    &quot;end&quot;: &quot;2018-11-29 15:42:00.243019&quot;,\r\n    &quot;failed&quot;: false,\r\n    &quot;rc&quot;: 0,\r\n    &quot;start&quot;: &quot;2018-11-29 15:41:59.674045&quot;,\r\n    &quot;stderr&quot;: &quot;&quot;,\r\n    &quot;stderr_lines&quot;: [],\r\n    &quot;stdout&quot;: &quot;Unseal Key 1: ZA0Gas2GrHtdMlet1g63N6gvEPYf5mzZEfjPhMDRyAeS\\nUnseal Key 2: NY+CLIbgMJIv+e81FuB1OpV0m7rPuqZbIuYT142MrQLl\\nUnseal Key 3: HNWmsrXBsSV9JFuGfqpd+GvPYQzHEsLFlxKBfEyBhCZ6\\nUnseal Key 4: xDwfI+kFHFRSzq2JyxSGArQsGjCrFiNbkGCP897Zfbuz\\nUnseal Key 5: +O8/tTmDNSzaUBMT8QP+2xbvu5uulypf3+xmWzY8fSD3\\n\\nInitial Root Token: 6kO8ijZzyhcG5Nup5QUca0u3\\n\\nVault initialized with 5 key shares and a key threshold of 3. Please securely\\ndistribute the key shares printed above. When the Vault is re-sealed,\\nrestarted, or stopped, you must supply at least 3 of these keys to unseal it\\nbefore it can start servicing requests.\\n\\nVault does not store the generated master key. Without at least 3 key to\\nreconstruct the master key, Vault will remain permanently sealed!\\n\\nIt is possible to generate new unseal keys, provided you have a quorum of\\nexisting unseal keys shares. See \\&quot;vault operator rekey\\&quot; for more information.&quot;,\r\n    &quot;stdout_lines&quot;: [\r\n      &quot;Unseal Key 1: ZA0Gas2GrHtdMlet1g63N6gvEPYf5mzZEfjPhMDRyAeS&quot;,\r\n      &quot;Unseal Key 2: NY+CLIbgMJIv+e81FuB1OpV0m7rPuqZbIuYT142MrQLl&quot;,\r\n      &quot;Unseal Key 3: HNWmsrXBsSV9JFuGfqpd+GvPYQzHEsLFlxKBfEyBhCZ6&quot;,\r\n      &quot;Unseal Key 4: xDwfI+kFHFRSzq2JyxSGArQsGjCrFiNbkGCP897Zfbuz&quot;,\r\n      &quot;Unseal Key 5: +O8/tTmDNSzaUBMT8QP+2xbvu5uulypf3+xmWzY8fSD3&quot;,\r\n      &quot;&quot;,\r\n      &quot;Initial Root Token: 6kO8ijZzyhcG5Nup5QUca0u3&quot;,\r\n      &quot;&quot;,\r\n      &quot;Vault initialized with 5 key shares and a key threshold of 3. Please securely&quot;,\r\n      &quot;distribute the key shares printed above. When the Vault is re-sealed,&quot;,\r\n      &quot;restarted, or stopped, you must supply at least 3 of these keys to unseal it&quot;,\r\n      &quot;before it can start servicing requests.&quot;,\r\n      &quot;&quot;,\r\n      &quot;Vault does not store the generated master key. Without at least 3 key to&quot;,\r\n      &quot;reconstruct the master key, Vault will remain permanently sealed!&quot;,\r\n      &quot;&quot;,\r\n      &quot;It is possible to generate new unseal keys, provided you have a quorum of&quot;,\r\n      &quot;existing unseal keys shares. See \\&quot;vault operator rekey\\&quot; for more information.&quot;\r\n     ]\r\n    }\r\n    }\r\n\r\nOut of the line\r\n\r\n    &quot;Unseal Key 3: HNWmsrXBsSV9JFuGfqpd+GvPYQzHEsLFlxKBfEyBhCZ6&quot;\r\n\r\nI would like just \r\n\r\n    HNWmsrXBsSV9JFuGfqpd+GvPYQzHEsLFlxKBfEyBhCZ6\r\n\r\nCurrently using my regex I get only if I use it without the JQ tool syntax \r\n\r\n    : ZA0Gas2GrHtdMlet1g63N6gvEPYf5mzZEfjPhMDRyAeS\r\n\r\nSo to summarise I need help with \r\n\r\na) getting a correct regular expression and \r\n\r\nb) the correct syntax to use the expression with the JQ Tool.\r\n\r\nThanks",
        "link": "https://stackoverflow.com/questions/53544476/regex-expression-with-the-jq-tool",
        "title": "Regex Expression with the JQ Tool"
    },
    {
        "tags": [
            "json",
            "linux",
            "bash",
            "shell",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1543527983,
                "last_edit_date": 1543527983,
                "creation_date": 1543527878,
                "answer_id": 53548055,
                "question_id": 53547982,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You need to use the full syntax for key access, as the dollar sign preclude you using the shorter form. The error message should provide this suggestion.\r\n\r\n    $ jq --arg date 1543359600 &#39;.$date&#39; tmp.json\r\n    jq: error: syntax error, unexpected &#39;$&#39; (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n    .$date\r\n    jq: error: try .[&quot;field&quot;] instead of .field for unusually named fields at &lt;top-level&gt;, line 1:\r\n    .$date\r\n    jq: 2 compile errors\r\n\r\nNote the error message\r\n&gt; &#39;try .[&quot;field&quot;] instead of .field&#39;. \r\n\r\nYou won&#39;t need the quotes, though, as that would be how you specify a literal key `$date`.\r\n\r\n    $ jq --arg date 1543359600 &#39;.[$date]&#39; tmp.json\r\n    {\r\n      &quot;name&quot;: &quot;Kate&quot;,\r\n      &quot;company&quot;: &quot;bar&quot;\r\n    }",
                "title": "How to dynamically parse a JSON object with shell jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1546784911,
        "creation_date": 1543527468,
        "question_id": 53547982,
        "body_markdown": "I got a question about shell&#39;s jq. So my JSON object is:\r\n\r\n    {&quot;1543446000&quot;: {&quot;name&quot;: &quot;John&quot;, &quot;company&quot;: &quot;foo&quot;}, &quot;1543359600&quot;: {&quot;name&quot;: &quot;Kate&quot;, &quot;company&quot;: &quot;bar&quot;}}\r\n\r\nThe numers `1543446000` and `1543359600` are UNIX timestamps. How can I parse one of the JSON objects by the timestamp with a shell variable?\r\n\r\nMy shell script so far:\r\n\r\n    #!/bin/sh\r\n    URL=&quot;https://pastebin.com/raw/w7awz7kZ&quot;\r\n    export DATE=$(date -d &quot;$today 0&quot; +%s)\r\n    JSON=$(curl -H &quot;Accept: application/json&quot; $API_URL)\r\n    JSON=$(echo $JSON | jq --arg date $DATE &#39;.$date&#39;)\r\n    echo $JSON\r\n\r\nDoesn&#39;t seem to work. My intention is to select the inner JSON object described by one of the timestamps, which are basically midnight of today. So I want to select today&#39;s data set.\r\n\r\nAny suggestions?\r\n\r\n\r\nGreets,\r\nInnoberger",
        "link": "https://stackoverflow.com/questions/53547982/how-to-dynamically-parse-a-json-object-with-shell-jq",
        "title": "How to dynamically parse a JSON object with shell jq"
    },
    {
        "tags": [
            "json",
            "unique",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2787437,
                    "reputation": 3459,
                    "user_id": 2398444,
                    "user_type": "registered",
                    "accept_rate": 38,
                    "profile_image": "https://www.gravatar.com/avatar/3f823172d290247ce6518e12e5568782?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "pouyan",
                    "link": "https://stackoverflow.com/users/2398444/pouyan"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1543566350,
                "post_id": 53553637,
                "comment_id": 93972992,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 13755473,
                    "reputation": 165,
                    "user_id": 9926556,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/HbLhT.png?s=256",
                    "display_name": "Kein",
                    "link": "https://stackoverflow.com/users/9926556/kein"
                },
                "reply_to_user": {
                    "account_id": 2787437,
                    "reputation": 3459,
                    "user_id": 2398444,
                    "user_type": "registered",
                    "accept_rate": 38,
                    "profile_image": "https://www.gravatar.com/avatar/3f823172d290247ce6518e12e5568782?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "pouyan",
                    "link": "https://stackoverflow.com/users/2398444/pouyan"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1543566551,
                "post_id": 53553637,
                "comment_id": 93973061,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1543569947,
                "last_edit_date": 1543569947,
                "creation_date": 1543566651,
                "answer_id": 53553884,
                "question_id": 53553637,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Let&#39;s make this easy by using a generic utility function (suitable perhaps for your standard jq library):\r\n\r\n    # In this formulation, f must either always evaluate to a string or always to an integer\r\n    # it being understood that negative integers might be problematic\r\n    def aggregate_by(f; g):\r\n      reduce .[] as $x  (null; .[$x|f] += [$x|g]);\r\n\r\nUsing the -s (&quot;slurp&quot;) option, the task can now be broken down into the following steps:\r\n  \r\n\r\n    map(split(&quot; &quot;))\r\n    | aggregate_by(.[0]; .[1])\r\n    | with_entries(select(.value|length &gt; 1))\r\n    | to_entries[]\r\n    | .key as $k | .value[] | [$k, .]\r\n    | join(&quot; &quot;)\r\n\r\n## Output (based on original example)\r\n\r\n    &quot;mydomain.com 125.125.125.125&quot;\r\n    &quot;mydomain.com 125.125.125.126&quot;\r\n\r\n## Output (based on revised example)\r\n\r\n    &quot;static.mydomain.com 124.124.124.124&quot;\r\n    &quot;static.mydomain.com 124.124.124.128&quot;\r\n    &quot;mydomain.com 125.125.125.125&quot;\r\n    &quot;mydomain.com 125.125.125.126&quot;\r\n    &quot;mydomain.com 125.125.125.127&quot;\r\n\r\n",
                "title": "How to get only duplicate keys at json via jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1543573502,
        "creation_date": 1543565549,
        "last_edit_date": 1543573502,
        "question_id": 53553637,
        "body_markdown": "I&#39;m read all answers at stackoverflow and jq manual but can&#39;t find and understand what options need to use to solve next task: \r\n\r\n&gt; jq &#39;.result[] | &quot;\\\\(.name) \\\\(.content)&quot;&#39; :\r\n\r\n    &quot;test.mydomain.com 123.123.123.123&quot;\r\n    &quot;static.mydomain.com 124.124.124.124&quot;\r\n    &quot;static.mydomain.com 124.124.124.128&quot;\r\n    &quot;mydomain.com 125.125.125.125&quot;\r\n    &quot;mydomain.com 125.125.125.126&quot;\r\n    &quot;mydomain.com 125.125.125.127&quot;\r\n\r\nNeed to get from this list only duplicates per first value:\r\n\r\n    &quot;mydomain.com 125.125.125.125&quot;\r\n    &quot;mydomain.com 125.125.125.126&quot;\r\n    &quot;mydomain.com 125.125.125.127&quot;\r\n    &quot;static.mydomain.com 124.124.124.124&quot;\r\n    &quot;static.mydomain.com 124.124.124.128&quot;\r\nSorry about Your time \r\n\r\nBest regards\r\n",
        "link": "https://stackoverflow.com/questions/53553637/how-to-get-only-duplicate-keys-at-json-via-jq",
        "title": "How to get only duplicate keys at json via jq?"
    },
    {
        "tags": [
            "json",
            "null",
            "iteration",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1555014498,
                "last_edit_date": 1555014498,
                "creation_date": 1543568179,
                "answer_id": 53554222,
                "question_id": 53553689,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using an if/else statement may help.\r\n\r\n    jq &#39;.results[] | {\r\n        headword,\r\n        definition: .senses[0].definition[0],\r\n        examples: (if .senses[0].examples then .senses[0].examples[0].text else null end)\r\n    }&#39; data.json",
                "title": "how to not skip array containing null using jq?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1543569145,
                "creation_date": 1543569145,
                "answer_id": 53554445,
                "question_id": 53553689,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "As @oguzismail has implicitly pointed out,\r\nassuming that the senses array has only one element\r\nis risky, especially as the choice of name suggests\r\nit was anticipated that each headword might have more than one sense.\r\nA similar observation could be made about .examples, but \r\nthe Q does not make it clear what should be done if .examples has more than one element.\r\n\r\nIn the following I shall therefore opt for a safe approach,\r\nsince it can easily be adjusted to meet more specific requirements.\r\n\r\n    .results[]\r\n    | { headword }\r\n      + (.senses[]\r\n         | { definition: .definition[0],\r\n             examples: (if has(&quot;examples&quot;)\r\n                        then [.examples[].text]\r\n                        else null end) } )\r\n\r\n",
                "title": "how to not skip array containing null using jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1666590519,
        "creation_date": 1543565730,
        "last_edit_date": 1666590519,
        "question_id": 53553689,
        "body_markdown": "I want to process this data \r\n\r\n    {\r\n      &quot;results&quot;: [\r\n        {\r\n          &quot;headword&quot;: &quot;binding&quot;,\r\n          &quot;senses&quot;: [\r\n            {\r\n              &quot;definition&quot;: [\r\n                &quot;a promise, agreement etc that must be obeyed&quot;\r\n              ]\r\n            }\r\n          ]\r\n        },\r\n        {\r\n          &quot;headword&quot;: &quot;non-binding&quot;,\r\n          &quot;senses&quot;: [\r\n            {\r\n              &quot;definition&quot;: [\r\n                &quot;a non-binding agreement or decision does not have to be obeyed&quot;\r\n              ],\r\n              &quot;examples&quot;: [\r\n                {\r\n                  &quot;text&quot;: &quot;The industry has signed a non-binding agreement to reduce pollution.&quot;\r\n                }\r\n              ]\r\n            }\r\n          ]\r\n        }\r\n      ]\r\n    }\r\n\r\ninto this\r\n\r\n    {\r\n      &quot;headword&quot;: &quot;binding&quot;,\r\n      &quot;definition&quot;: &quot;a promise, agreement etc that must be obeyed&quot;,\r\n      &quot;examples&quot;: null\r\n    }\r\n    {\r\n      &quot;headword&quot;: &quot;non-binding&quot;,\r\n      &quot;definition&quot;: &quot;a non-binding agreement or decision does not have to be obeyed&quot;,\r\n      &quot;examples&quot;: &quot;The industry has signed a non-binding agreement to reduce pollution.&quot;\r\n    }\r\n\r\nthis command \r\n\r\n    cat data.json | jq &#39;.results[] | {headword: .headword, definition: .senses[].definition[], examples: .senses[].examples[].text}&#39;\r\n\r\nerrors out with &#39;Cannot iterate over null&#39;\r\n\r\nto overcome that, this command using &#39;.[]?&#39; filter\r\n\r\n    cat data.json | jq &#39;.results[] | {headword: .headword, definition: .senses[].definition[], examples: .senses[].examples[]?.text}&#39;\r\n\r\nbut this outputs only\r\n\r\n    {\r\n      &quot;headword&quot;: &quot;non-binding&quot;,\r\n      &quot;definition&quot;: &quot;a non-binding agreement or decision does not have to be obeyed&quot;,\r\n      &quot;examples&quot;: &quot;The industry has signed a non-binding agreement to reduce pollution.&quot;\r\n    }\r\n\r\nso, How do you iterate over null and not skip array?\r\n",
        "link": "https://stackoverflow.com/questions/53553689/how-to-not-skip-array-containing-null-using-jq",
        "title": "how to not skip array containing null using jq?"
    },
    {
        "tags": [
            "json",
            "hadoop",
            "hadoop-yarn",
            "jq",
            "metrics"
        ],
        "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": 1543612201,
                "post_id": 53557983,
                "comment_id": 93995694,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1543584806,
                "last_edit_date": 1543584806,
                "creation_date": 1543583403,
                "answer_id": 53558238,
                "question_id": 53557983,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": " its pretty simple just fetch elment which is having an array of values.\r\n\r\n   \r\n\r\n&lt;!-- begin snippet: js hide: false console: true babel: false --&gt;\r\n\r\n&lt;!-- language: lang-js --&gt;\r\n\r\n     var JSONOBJ={\r\n          &quot;apps&quot;: {\r\n            &quot;app&quot;: [\r\n              {\r\n                &quot;id&quot;: &quot;application_1540378900448_18838&quot;,\r\n                &quot;user&quot;: &quot;hive&quot;,\r\n                &quot;name&quot;: &quot;insert overwrite tabl...summary_view_stg_etl(Stage-2)&quot;,\r\n                &quot;queue&quot;: &quot;Data_Ingestion&quot;,\r\n                &quot;state&quot;: &quot;FINISHED&quot;,\r\n                &quot;finalStatus&quot;: &quot;SUCCEEDED&quot;,\r\n                &quot;progress&quot;: 100\r\n               }, \r\n               {\r\n                &quot;id&quot;: &quot;application_1540378900448_18833&quot;,\r\n                &quot;user&quot;: &quot;hive&quot;,\r\n                &quot;name&quot;: &quot;insert into SNOW_WORK...metric_definitions&#39;)(Stage-13)&quot;,\r\n                &quot;queue&quot;: &quot;Data_Ingestion&quot;,\r\n                &quot;state&quot;: &quot;FINISHED&quot;,\r\n                &quot;finalStatus&quot;: &quot;SUCCEEDED&quot;,\r\n                &quot;progress&quot;: 100                                                         \r\n                }\r\n              ]\r\n          }\r\n        \r\n        }\r\n        \r\n        JSONOBJ.apps.app.forEach(function(o){console.log(o.id);console.log(o.user);console.log(o.name);})\r\n\r\n&lt;!-- end snippet --&gt;\r\n\r\n",
                "title": "Using jq to return specific information in JSON object"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1543614688,
                "last_edit_date": 1543614688,
                "creation_date": 1543613987,
                "answer_id": 53565266,
                "question_id": 53557983,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You&#39;re better off converting the data to a format easily consumed by a database processor, like csv, then do something about it.\r\n\r\n    $ jq -r &#39;(.apps.app[0] | keys_unsorted) as $k\r\n        | $k, (.apps.app[] | [.[$k[]]])\r\n        | @csv\r\n    &#39; input.json",
                "title": "Using jq to return specific information in JSON object"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1543614688,
        "creation_date": 1543582348,
        "last_edit_date": 1543611963,
        "question_id": 53557983,
        "body_markdown": "I wish to parse individual elements of inner JSON object to build / load in the database. \r\n\r\nThe following is the JSON object. How can I parse elements like id, name queue etc? I will iterate it in loop and work and build the insert query.\r\n\r\n    {\r\n      &quot;apps&quot;: {\r\n        &quot;app&quot;: [\r\n          {\r\n            &quot;id&quot;: &quot;application_1540378900448_18838&quot;,\r\n            &quot;user&quot;: &quot;hive&quot;,\r\n            &quot;name&quot;: &quot;insert overwrite tabl...summary_view_stg_etl(Stage-2)&quot;,\r\n            &quot;queue&quot;: &quot;Data_Ingestion&quot;,\r\n            &quot;state&quot;: &quot;FINISHED&quot;,\r\n            &quot;finalStatus&quot;: &quot;SUCCEEDED&quot;,\r\n            &quot;progress&quot;: 100\r\n           }, \r\n           {\r\n            &quot;id&quot;: &quot;application_1540378900448_18833&quot;,\r\n            &quot;user&quot;: &quot;hive&quot;,\r\n            &quot;name&quot;: &quot;insert into SNOW_WORK...metric_definitions&#39;)(Stage-13)&quot;,\r\n            &quot;queue&quot;: &quot;Data_Ingestion&quot;,\r\n            &quot;state&quot;: &quot;FINISHED&quot;,\r\n            &quot;finalStatus&quot;: &quot;SUCCEEDED&quot;,\r\n            &quot;progress&quot;: 100                                                         \r\n            }\r\n          ]\r\n      }\r\n     \r\n      }",
        "link": "https://stackoverflow.com/questions/53557983/using-jq-to-return-specific-information-in-json-object",
        "title": "Using jq to return specific information in JSON object"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1543601413,
                "creation_date": 1543601413,
                "answer_id": 53562752,
                "question_id": 53561470,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "    (paths | select(.[-2] == &quot;Aliases&quot;)) as $p\r\n    | select( &quot;dos&quot; == getpath($p))\r\n    | $p[:-2][]\r\n\r\nNotice that there&#39;s no need for an additional variable (`. as $in`).\r\n\r\n",
                "title": "Accessing ancestors of array with given value"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1543601413,
        "creation_date": 1543595597,
        "question_id": 53561470,
        "body_markdown": "I can&#39;t seem to find the secret sauce to make jq do what I want.\r\n\r\nGiven the following contrived input:\r\n\r\n    {\r\n        &quot;node1&quot;: {\r\n            &quot;1&quot;: {\r\n                &quot;Aliases&quot;: [&quot;one&quot;, &quot;uno&quot;]\r\n            },\r\n            &quot;2&quot;: {\r\n                &quot;Aliases&quot;: [&quot;two&quot;, &quot;dos&quot;]\r\n            }\r\n        },\r\n        &quot;node2&quot;: {\r\n            &quot;a&quot;: {\r\n                &quot;Aliases&quot;: [&quot;alpha&quot;]\r\n            },\r\n            &quot;b&quot;: {\r\n                &quot;Aliases&quot;: [&quot;bravo&quot;]\r\n            }\r\n        }\r\n    }\r\n\r\nI want to return the keys of the ancestors of `Aliases` when `Aliases` contains a particular value.\r\n\r\nFor example, given the search key `dos`, I want to return `node1` and `2`.\r\n\r\nYou can play with this data [in jqplay](https://jqplay.org/s/gatqyHXh4I).  Any help would be appreciated.",
        "link": "https://stackoverflow.com/questions/53561470/accessing-ancestors-of-array-with-given-value",
        "title": "Accessing ancestors of array with given value"
    },
    {
        "tags": [
            "iteration",
            "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": 1543607639,
                "post_id": 53563511,
                "comment_id": 93993828,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1002989,
                    "reputation": 1385,
                    "user_id": 1017466,
                    "user_type": "registered",
                    "accept_rate": 50,
                    "profile_image": "https://www.gravatar.com/avatar/73d62289ed695b520ad2a3ae80c45277?s=256&d=identicon&r=PG",
                    "display_name": "bluethundr",
                    "link": "https://stackoverflow.com/users/1017466/bluethundr"
                },
                "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": 1543636239,
                "post_id": 53563511,
                "comment_id": 94000729,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1002989,
                    "reputation": 1385,
                    "user_id": 1017466,
                    "user_type": "registered",
                    "accept_rate": 50,
                    "profile_image": "https://www.gravatar.com/avatar/73d62289ed695b520ad2a3ae80c45277?s=256&d=identicon&r=PG",
                    "display_name": "bluethundr",
                    "link": "https://stackoverflow.com/users/1017466/bluethundr"
                },
                "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": 1543850221,
                "post_id": 53563511,
                "comment_id": 94055792,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1544007046,
                "last_edit_date": 1544007046,
                "creation_date": 1543613989,
                "answer_id": 53565267,
                "question_id": 53563511,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; How can I make the error more verbose so I can find out what&#39;s going on?\r\n\r\nYou could use `debug`.\r\n\r\n&gt; why does adding the name tag to the query dramatically reduce the number of results?\r\n\r\nBecause your jq program is at variance with your expectations; specifically, you have overlooked what happens when .Tags evaluates to null.  To understand the mismatch, consider:\r\n\r\n    $ jq -n &#39;{} | .Tags[]|select(.Key==&quot;Name&quot;)|.Value&#39;\r\n \r\nAnother issue is the handling of empty arrays. You might like to handle the case of empty arrays along the lines suggested by the following:\r\n\r\n    $ jq -n &#39;{Tags: []} | (.Tags[] | select(.Key==&quot;Name&quot;)|.Value) // null&#39;\r\n    $ null\r\n\r\n## One solution\r\nIf you want `null` to appear whenever there isn&#39;t a tag:\r\n\r\n    .Reservations[].Instances[]\r\n    | [ ((.Tags // [])[] | select(.Key==&quot;Name&quot;) | .Value) // null,\r\n        .InstanceId  ] \r\n \r\nGiven your input, the first two lines of the output would be:\r\n\r\n    [null,&quot;i-08d3c05eed1316c9d&quot;]\r\n    [&quot;USAMZLAB10003&quot;,&quot;i-79eebb29&quot;]\r\n\r\n## Variant using `try`\r\n\r\n    .Reservations[].Instances[]\r\n    | [ try (.Tags[] | select(.Key==&quot;Name&quot;)|.Value) // null,\r\n        .InstanceId  ] \r\n",
                "title": "JQ Pulling Inconsistent Results"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1543966431,
                "creation_date": 1543966431,
                "answer_id": 53622992,
                "question_id": 53563511,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "In your json, not all instances have a set of `Tags` thus the error.  You would have to handle it or substitute an empty array in its place with `(.Tags // [])`.  But overall, I would write it like this:\r\n\r\n    .Reservations[].Instances[] | [ (.Tags // [] | from_entries.Name), .InstanceId ]",
                "title": "JQ Pulling Inconsistent Results"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1544007046,
        "creation_date": 1543605127,
        "last_edit_date": 1543957490,
        "question_id": 53563511,
        "body_markdown": "If I run this very straight query on my json data from an aws command I get a correct result as to how many aws server instances I have in an account:\r\n\r\n    aws ec2 describe-instances | jq -r &#39;.Reservations[].Instances[].InstanceId&#39;\r\n\r\nProduces a list of 47 instance IDs which corresponds to the number of server instances I have in the account. For example:\r\n\r\n    i-01adbf1408ef1a333\r\n    i-0f92d078ce975c138\r\n    i-0e4e117c44b17b417\r\n    and on up to 47 instances\r\n\r\nThis next query still produces the correct number of results:\r\n\r\n    aws ec2 describe-instances | jq -r &#39;.Reservations[].Instances[] | [( .InstanceId ) ]&#39;\r\n\r\nHowever, if I add a query to include the name tags of the servers I get dramatically less number of server instances reported:\r\n\r\n    aws ec2 describe-instances | jq -r &#39;.Reservations[].Instances[] | [( (.Tags[]|select(.Key==&quot;Name&quot;)|.Value), .InstanceId ) ]&#39;\r\n\r\nThis is the output of that command:\r\n\r\n    &quot;i-08d3c05eed1316c9d&quot;\r\n    &quot;USAMZLAB10003&quot;,&quot;i-79eebb29&quot;\r\n    &quot;EOMLABAMZ1306&quot;,&quot;i-dbc98af4&quot;\r\n    &quot;USAMZLAB10002&quot;,&quot;i-d1dc1d83&quot;\r\n    &quot;i-0366c9bf18d27eb96&quot;\r\n    &quot;i-04d061334bc2f2d6b&quot;\r\n    &quot;USAMZLAB10007&quot;,&quot;i-f7a680a7&quot;\r\n    &quot;i-090e84eff4fece2b3&quot;\r\n    &quot;EOMLABAMZ1303&quot;,&quot;i-7cc98a53&quot;\r\n    &quot;EOMLABCSE713&quot;,&quot;i-08233926&quot;\r\n    &quot;i-0705eb3039cd56e04&quot;\r\n    jq: error (at &lt;stdin&gt;:5013): Cannot iterate over null (null)\r\n\r\nFor some reason that query reports that there are only 11 aws server instances (when there should be 47). It does report that there are servers with and without name tags. But it&#39;s not reporting the correct number of servers.\r\n\r\nIt also produces the jq error &quot;Cannot iterate over null&quot;.\r\n\r\nI have put the original JSON into this paste:\r\n\r\n[Original JSON][1]\r\n\r\nHow can I make the error more verbose so I can find out what&#39;s going on? \r\n\r\nAnd why does adding the name tag to the query dramatically reduce the number of results?\r\n\r\n\r\n  [1]: https://pastebin.com/dUVthQKh",
        "link": "https://stackoverflow.com/questions/53563511/jq-pulling-inconsistent-results",
        "title": "JQ Pulling Inconsistent Results"
    },
    {
        "tags": [
            "unix",
            "awk",
            "sed",
            "jq"
        ],
        "comments": [
            {
                "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": 3,
                "creation_date": 1543626492,
                "post_id": 53566477,
                "comment_id": 93999445,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5301,
                    "reputation": 94077,
                    "user_id": 8454,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/2NlHs.png?s=256",
                    "display_name": "Andy Lester",
                    "link": "https://stackoverflow.com/users/8454/andy-lester"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1543628304,
                "post_id": 53566477,
                "comment_id": 93999752,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1543626384,
                "creation_date": 1543626384,
                "answer_id": 53566880,
                "question_id": 53566477,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use `jq` to parse json:\r\n\r\n    jq -r &#39;.prefixes[] | select(.region == &quot;us-west-2&quot;) | .ip_prefix&#39; input-file\r\n\r\n ",
                "title": "How to grep by section in a file?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1543636038,
        "creation_date": 1543622109,
        "last_edit_date": 1543636038,
        "question_id": 53566477,
        "body_markdown": "I need to know all IP range (ip_prefix), associated with us-west-2 region only from this link - https://ip-ranges.amazonaws.com/ip-ranges.json (it can be opened in wordpad for better visibility)\r\nPlease suggest, how would I do it. If vi, awk or sed is needed, I have downloaded it on my linux server.\r\n\r\nThanks",
        "link": "https://stackoverflow.com/questions/53566477/how-to-grep-by-section-in-a-file",
        "title": "How to grep by section in a file?"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1543629027,
                "post_id": 53567043,
                "comment_id": 93999852,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2424993,
                    "reputation": 85,
                    "user_id": 2117145,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/a3c2fa4a02fd6f6f8ceabd2abeb9fda2?s=256&d=identicon&r=PG",
                    "display_name": "mjcconsulting",
                    "link": "https://stackoverflow.com/users/2117145/mjcconsulting"
                },
                "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": 1543711816,
                "post_id": 53567043,
                "comment_id": 94017037,
                "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": 1543714329,
                "post_id": 53567043,
                "comment_id": 94017372,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1543762344,
                "last_edit_date": 1543762344,
                "creation_date": 1543629578,
                "answer_id": 53567139,
                "question_id": 53567043,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The easy thing to do is to build a map from the keys to the values (combining all the input sources in turn), and then go back and reprocess `default.json`, applying that generated map.\r\n\r\n    jq -n --slurpfile template default.json &#39;\r\n    # generate an unordered key:value dictionary\r\n    ([inputs | .[] | {(.ParameterKey): (.ParameterValue)}] | add) as $map |\r\n\r\n    # apply those pairs to the template to get its ordering\r\n    [ $template[0][] | {&quot;ParameterKey&quot;: (.ParameterKey), &quot;ParameterValue&quot;: ($map[.ParameterKey])} ]\r\n\r\n    &#39; default.json environment.json user.json secure.json\r\n\r\n...which properly outputs:\r\n\r\n    [\r\n      {\r\n        &quot;ParameterKey&quot;: &quot;FirstStackName&quot;,\r\n        &quot;ParameterValue&quot;: &quot;Development-App-Database&quot;\r\n      },\r\n      {\r\n        &quot;ParameterKey&quot;: &quot;SecondStackName&quot;,\r\n        &quot;ParameterValue&quot;: &quot;Development-Directory&quot;\r\n      },\r\n      {\r\n        &quot;ParameterKey&quot;: &quot;ThirdStackName&quot;,\r\n        &quot;ParameterValue&quot;: &quot;Development-VPC&quot;\r\n      },\r\n      {\r\n        &quot;ParameterKey&quot;: &quot;FourthStackName&quot;,\r\n        &quot;ParameterValue&quot;: &quot;AMIFunctions&quot;\r\n      },\r\n      {\r\n        &quot;ParameterKey&quot;: &quot;FifthKeyName&quot;,\r\n        &quot;ParameterValue&quot;: &quot;jdoe&quot;\r\n      },\r\n      {\r\n        &quot;ParameterKey&quot;: &quot;SixthUserName&quot;,\r\n        &quot;ParameterValue&quot;: &quot;admin&quot;\r\n      },\r\n      {\r\n        &quot;ParameterKey&quot;: &quot;SeventhPassword&quot;,\r\n        &quot;ParameterValue&quot;: &quot;secretvalue&quot;\r\n      }\r\n    ]\r\n\r\n...retaining `default.json`&#39;s ordering.\r\n\r\n---\r\n\r\nIf you *insist* on having the whitespace just so, one way to do it is by piping output of the above through the following:\r\n\r\n    #!/usr/bin/env bash\r\n    shopt -s extglob\r\n    pieces=( )\r\n    while read -r line; do\r\n      case $line in\r\n        &quot;[&quot;|&quot;]&quot;)       printf &#39;%s\\n&#39; &quot;$line&quot;;;\r\n        *(&#39; &#39;)&quot;}&quot;?(,)) printf &#39;%2s %-35s %s %2s\\n&#39; &quot;${pieces[@]}&quot; &quot;$line&quot;; pieces=( );;\r\n        *)             pieces+=( &quot;$line&quot; )\r\n      esac\r\n    done\r\n\r\nThe above is careful to only change whitespace, and to not recognize any delimiters other than newlines; as such, its output should always be semantically identical to its input. See https://ideone.com/EI0RuJ as a demonstration of this code working in practice, with output of:\r\n\r\n    [\r\n     { &quot;ParameterKey&quot;: &quot;FirstStackName&quot;,   &quot;ParameterValue&quot;: &quot;Development-App-Database&quot; },\r\n     { &quot;ParameterKey&quot;: &quot;SecondStackName&quot;,  &quot;ParameterValue&quot;: &quot;Development-Directory&quot; },\r\n     { &quot;ParameterKey&quot;: &quot;ThirdStackName&quot;,   &quot;ParameterValue&quot;: &quot;Development-VPC&quot; },\r\n     { &quot;ParameterKey&quot;: &quot;FourthStackName&quot;,  &quot;ParameterValue&quot;: &quot;AMIFunctions&quot; },\r\n     { &quot;ParameterKey&quot;: &quot;FifthKeyName&quot;,     &quot;ParameterValue&quot;: &quot;jdoe&quot; },\r\n     { &quot;ParameterKey&quot;: &quot;SixthUserName&quot;,    &quot;ParameterValue&quot;: &quot;admin&quot; },\r\n     { &quot;ParameterKey&quot;: &quot;SeventhPassword&quot;,  &quot;ParameterValue&quot;: &quot;secretvalue&quot;  }\r\n    ]",
                "title": "How to merge JSON arrays from multiple files via jq with order preserved"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1543660780,
                "last_edit_date": 1543660780,
                "creation_date": 1543632212,
                "answer_id": 53567330,
                "question_id": 53567043,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`unique_by` entails a sort, so the simplest would be to use `INDEX` (uppercase):\r\n\r\n    [INDEX(inputs[]; .ParameterKey)[]]\r\n\r\nI&#39;ve used `inputs` here to avoid all the disadvantages of the -s option, but remember to use the -n option instead.  \r\n\r\nIn case your jq does not have INDEX, you can use this def:\r\n\r\n    def INDEX(s; f):\r\n      reduce s as $x  (null; .[$x|f] = $x );\r\n\r\n\r\n\r\n   \r\n",
                "title": "How to merge JSON arrays from multiple files via jq with order preserved"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1543762344,
        "creation_date": 1543628291,
        "question_id": 53567043,
        "body_markdown": "I&#39;m attempting to setup a hierarchy of JSON configuration files where defaults can be overridden at multiple levels. Each file is a set of key/value pairs. There are many of these organized by function in non-alphabetical order.\r\n\r\nI&#39;ve found a method to get the logical result I want, but it&#39;s sorted in alphabetical order, and due to the number of expected parameters, it will be hard for the user to clearly/quickly see if the set is what they want before using it.\r\n\r\nIs there a way to perform this sort of merge, replacing values on matching keys and preserving order?\r\n\r\nI have these files:\r\n\r\ndefault.json:\r\n\r\n    [\r\n      { &quot;ParameterKey&quot;: &quot;FirstStackName&quot;,  &quot;ParameterValue&quot;: &quot;Production-App-Database&quot; },\r\n      { &quot;ParameterKey&quot;: &quot;SecondStackName&quot;, &quot;ParameterValue&quot;: &quot;Production-Directory&quot; },\r\n      { &quot;ParameterKey&quot;: &quot;ThirdStackName&quot;,  &quot;ParameterValue&quot;: &quot;Production-VPC&quot; },\r\n      { &quot;ParameterKey&quot;: &quot;FourthStackName&quot;, &quot;ParameterValue&quot;: &quot;AMIFunctions&quot; },\r\n      { &quot;ParameterKey&quot;: &quot;FifthKeyName&quot;,    &quot;ParameterValue&quot;: &quot;administrator&quot; },\r\n      { &quot;ParameterKey&quot;: &quot;SixthUserName&quot;,   &quot;ParameterValue&quot;: &quot;admin&quot; },\r\n      { &quot;ParameterKey&quot;: &quot;SeventhPassword&quot;, &quot;ParameterValue&quot;: &quot;&quot; }\r\n    ]\r\n\r\nenvironment.json:\r\n\r\n    [\r\n      { &quot;ParameterKey&quot;: &quot;FirstStackName&quot;,  &quot;ParameterValue&quot;: &quot;Development-App-Database&quot; },\r\n      { &quot;ParameterKey&quot;: &quot;SecondStackName&quot;, &quot;ParameterValue&quot;: &quot;Development-Directory&quot; },\r\n      { &quot;ParameterKey&quot;: &quot;ThirdStackName&quot;,  &quot;ParameterValue&quot;: &quot;Development-VPC&quot; },\r\n      { &quot;ParameterKey&quot;: &quot;FifthKeyName&quot;,    &quot;ParameterValue&quot;: &quot;developer&quot; }\r\n    ] \r\n\r\nuser.json:\r\n\r\n    [\r\n      { &quot;ParameterKey&quot;: &quot;FifthKeyName&quot;,    &quot;ParameterValue&quot;: &quot;jdoe&quot; }\r\n    ] \r\n\r\nsecure.json:\r\n\r\n    [\r\n      { &quot;ParameterKey&quot;: &quot;SeventhPassword&quot;, &quot;ParameterValue&quot;: &quot;secretvalue&quot; }\r\n    ] \r\n\r\nIf I run this:\r\n\r\n    jq -s &#39;.[3] + .[2] + .[1] + .[0] | unique_by(.ParameterKey)&#39; default.json environment.json user.json secure.json\r\n\r\nI get something that works:\r\n\r\n    [\r\n      { \r\n        &quot;ParameterKey&quot;: &quot;FifthKeyName&quot;,\r\n        &quot;ParameterValue&quot;: &quot;jdoe&quot;\r\n      },\r\n      {\r\n        &quot;ParameterKey&quot;: &quot;FirstStackName&quot;,\r\n        &quot;ParameterValue&quot;: &quot;Development-App-Database&quot;\r\n      },\r\n      {\r\n        &quot;ParameterKey&quot;: &quot;FourthStackName&quot;,\r\n        &quot;ParameterValue&quot;: &quot;AMIFunctions&quot;\r\n      },\r\n      {\r\n        &quot;ParameterKey&quot;: &quot;SecondStackName&quot;,\r\n        &quot;ParameterValue&quot;: &quot;Development-Directory&quot;\r\n      },\r\n      {\r\n        &quot;ParameterKey&quot;: &quot;SeventhPassword&quot;,\r\n        &quot;ParameterValue&quot;: &quot;secretvalue&quot;\r\n      },\r\n      {\r\n        &quot;ParameterKey&quot;: &quot;SixthUserName&quot;,\r\n        &quot;ParameterValue&quot;: &quot;admin&quot;\r\n      },\r\n      {\r\n        &quot;ParameterKey&quot;: &quot;ThirdStackName&quot;,\r\n        &quot;ParameterValue&quot;: &quot;Development-VPC&quot;\r\n      }\r\n    ]\r\n\r\nBut (imagine 60 params) it&#39;s not easily scanned as correct, and what I want is this:\r\n\r\n    [\r\n      { &quot;ParameterKey&quot;: &quot;FirstStackName&quot;,  &quot;ParameterValue&quot;: &quot;Development-App-Database&quot; },\r\n      { &quot;ParameterKey&quot;: &quot;SecondStackName&quot;, &quot;ParameterValue&quot;: &quot;Development-Directory&quot; },\r\n      { &quot;ParameterKey&quot;: &quot;ThirdStackName&quot;,  &quot;ParameterValue&quot;: &quot;Development-VPC&quot; },\r\n      { &quot;ParameterKey&quot;: &quot;FourthStackName&quot;, &quot;ParameterValue&quot;: &quot;AMIFunctions&quot; },\r\n      { &quot;ParameterKey&quot;: &quot;FifthKeyName&quot;,    &quot;ParameterValue&quot;: &quot;jdoe&quot; },\r\n      { &quot;ParameterKey&quot;: &quot;SixthUserName&quot;,   &quot;ParameterValue&quot;: &quot;admin&quot; },\r\n      { &quot;ParameterKey&quot;: &quot;SeventhPassword&quot;, &quot;ParameterValue&quot;: &quot;secretvalue&quot; }\r\n    ] ",
        "link": "https://stackoverflow.com/questions/53567043/how-to-merge-json-arrays-from-multiple-files-via-jq-with-order-preserved",
        "title": "How to merge JSON arrays from multiple files via jq with order preserved"
    },
    {
        "tags": [
            "json",
            "select",
            "key",
            "jq",
            "aws-cli"
        ],
        "answers": [
            {
                "up_vote_count": 6,
                "is_accepted": true,
                "score": 6,
                "last_activity_date": 1543742199,
                "creation_date": 1543742199,
                "answer_id": 53578922,
                "question_id": 53578837,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use `select`:\r\n\r\n    jq -r &#39;.Snapshots[].Tags[] | select(.Key == &quot;Name&quot;).Value&#39;",
                "title": "Extract key value with jq if key name matches &#39;Name&#39;"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1543743781,
        "creation_date": 1543741162,
        "last_edit_date": 1543743781,
        "question_id": 53578837,
        "body_markdown": "I need to extract a key value with jq, only if key name is `Name`. Below is an example. I have some AMI&#39;s that don&#39;t have a key name of `Name` and I want to ignore them.\r\n\r\n    aws ec2 describe-snapshots --snapshot-id snap-123 --region eu-west-1 --profile myprofile\r\n    {\r\n        &quot;Snapshots&quot;: [\r\n            {\r\n                &quot;Description&quot;: &quot;AMI upgrader&quot;,\r\n                &quot;Tags&quot;: [\r\n                    {\r\n                        &quot;Value&quot;: &quot;AMI upgrader&quot;,\r\n                        &quot;Key&quot;: &quot;Name&quot;\r\n                    }\r\n                ],\r\n                &quot;Encrypted&quot;: false,\r\n                &quot;VolumeId&quot;: &quot;vol-9356e811&quot;,\r\n                &quot;State&quot;: &quot;completed&quot;,\r\n                &quot;VolumeSize&quot;: 20,\r\n                &quot;StartTime&quot;: &quot;2018-05-31T13:58:31.000Z&quot;,\r\n                &quot;Progress&quot;: &quot;100%&quot;,\r\n                &quot;OwnerId&quot;: &quot;1234&quot;,\r\n                &quot;SnapshotId&quot;: &quot;snap-1234&quot;\r\n            }\r\n        ]\r\n    }\r\n\r\nI have tried;\r\n\r\n    aws ec2 describe-snapshots --snapshot-id snap-123 --region eu-west-1 --profile myprofile | jq -r &#39;.Snapshots[].Tags[]|.Name?.Value&#39;\r\n\r\nBut it returns `null`",
        "link": "https://stackoverflow.com/questions/53578837/extract-key-value-with-jq-if-key-name-matches-name",
        "title": "Extract key value with jq if key name matches &#39;Name&#39;"
    },
    {
        "tags": [
            "sh",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1543839273,
                "last_edit_date": 1543839273,
                "creation_date": 1543836296,
                "answer_id": 53592820,
                "question_id": 53591656,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you need to access something &quot;no matter how deeply it is nested&quot;, then `recurse` is your friend.\r\n\r\n    jq &#39;[recurse|.url? // empty]&#39; file.json\r\n\r\nThe question mark prevents us from failing when the recursion reaches something that is not an object (eg. the leaf strings). And `//empty` replaces the nulls we get from objects without an &quot;url&quot; key with empty results (so it deletes them).",
                "title": "jq to fetch value using key from a nested json when a key can be deeply nested"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1543839273,
        "creation_date": 1543832370,
        "last_edit_date": 1543832617,
        "question_id": 53591656,
        "body_markdown": "I have a nested JSON as shown below. I need to list down the values of all  &#39;.url&#39; no matter how deeply it is nested.\r\n\r\n\r\n\r\n    {\r\n     section1: {\r\n      url: &quot;abc/efg/dgh.com&quot;,\r\n      name: &quot;test1&quot;\r\n     },\r\n     section2: {\r\n       .section3: {\r\n         url: &quot;efef/dedede/efdgh.com&quot;,\r\n         name: &quot;test2&quot;\r\n        }\r\n     }\r\n    }\r\n\r\nThe expected output is as follows:\r\n\r\n    [&quot;abc/efg/dgh.com&quot;, &quot;efef/dedede/efdgh.com&quot;]\r\n\r\nThanks in advance",
        "link": "https://stackoverflow.com/questions/53591656/jq-to-fetch-value-using-key-from-a-nested-json-when-a-key-can-be-deeply-nested",
        "title": "jq to fetch value using key from a nested json when a key can be deeply nested"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1543853545,
                "last_edit_date": 1543853545,
                "creation_date": 1543850549,
                "answer_id": 53596714,
                "question_id": 53594410,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You need to map the objects contained in the `field3Array` to their string values and join the resulting array :\r\n\r\n    .root | map({field1, field2, field3Array: .field3Array | map(.prop1) | join(&quot;,&quot;)})\r\n\r\nYou can try it [here](https://jqplay.org/s/IlBiXAcAud).\r\n\r\n----\r\n\r\nIt can be somewhat simplified in the following where we update the `.field3Array` in-place instead of recreating a whole object :\r\n\r\n    .root | map(.field3Array |= (map(.prop1) | join(&quot;,&quot;)))\r\n\r\nYou can try it [here](https://jqplay.org/s/wFwB_10_8C).\r\n\r\n------\r\n\r\nIf you&#39;re unfamiliar with the `map` function, the following would have worked as well :\r\n\r\n    [.root[] | {field1, field2, field3Array: [ .field3Array[] | .prop1 ] | join(&quot;,&quot;)}]\r\n\r\nYou can try it [here](https://jqplay.org/s/wTPAhzvUxG).",
                "title": "jq transform JSON child array objects to delimited string"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1627418082,
        "creation_date": 1543842088,
        "last_edit_date": 1627418082,
        "question_id": 53594410,
        "body_markdown": "I want to transform the following input with jq:\r\n\r\n    {\r\n       &quot;root&quot;:[\r\n          {\r\n             &quot;field1&quot;:&quot;field1value1&quot;,\r\n             &quot;field2&quot;:&quot;field2value2&quot;,\r\n             &quot;field3Array&quot;:[\r\n                {\r\n                   &quot;prop1&quot;:&quot;prop1_value1&quot;\r\n                }\r\n             ]\r\n          },\r\n          {\r\n             &quot;field1&quot;:&quot;field1value3&quot;,\r\n             &quot;field2&quot;:&quot;field2value4&quot;,\r\n             &quot;field3Array&quot;:[\r\n                {\r\n                   &quot;prop1&quot;:&quot;prop1_value3&quot;\r\n                },\r\n                {\r\n                   &quot;prop1&quot;:&quot;prop1_value4&quot;\r\n                }\r\n             ]\r\n          }\r\n       ]\r\n    }\r\n\r\nOutput should be:\r\n\r\n    [\r\n      {\r\n        &quot;field1&quot;: &quot;field1value1&quot;,\r\n        &quot;field2&quot;: &quot;field2value2&quot;,\r\n        &quot;field3Array&quot;: &quot;prop1_value1&quot;\r\n      },\r\n      {\r\n        &quot;field1&quot;: &quot;field1value3&quot;,\r\n        &quot;field2&quot;: &quot;field2value4&quot;,\r\n        &quot;field3Array&quot;: &quot;prop1_value3,prop1_value4&quot;\r\n      }\r\n    ]\r\n\r\nI use this jq filter so far:\r\n\r\n    [.root[] | {field1, field2, field3Array: .field3Array[].prop1}]\r\n\r\nbut I don&#39;t know how to join the array property `&quot;prop1&quot;` to a comma-delimited string `&quot;prop1_value3,prop1_value4&quot;`.\r\n\r\nhttps://jqplay.org/s/CR8mGBX8Dz\r\n",
        "link": "https://stackoverflow.com/questions/53594410/jq-transform-json-child-array-objects-to-delimited-string",
        "title": "jq transform JSON child array objects to delimited string"
    },
    {
        "tags": [
            "json",
            "merge",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 353791,
                    "reputation": 27081,
                    "user_id": 691711,
                    "user_type": "registered",
                    "accept_rate": 91,
                    "profile_image": "https://www.gravatar.com/avatar/bf26891a2ec4eca6dd1962a6804f5a40?s=256&d=identicon&r=PG",
                    "display_name": "zero298",
                    "link": "https://stackoverflow.com/users/691711/zero298"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1543872958,
                "post_id": 53602197,
                "comment_id": 94066968,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1543873858,
                "creation_date": 1543873858,
                "answer_id": 53602461,
                "question_id": 53602197,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Create a list of the values and concatenate the elements in that list:\r\n\r\n    [.[]] | add\r\n\r\nCreate a list of each element in each array:\r\n\r\n    [.[][]]\r\n\r\nI&#39;d prefer the first one since it parses easier in my mind. ",
                "title": "Merge arrays in object"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1543877700,
                "creation_date": 1543877700,
                "answer_id": 53603186,
                "question_id": 53602197,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Generalizing a bit:\r\n\r\n    \r\n    jq &#39;[..|scalars]&#39; input.json",
                "title": "Merge arrays in object"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1543880940,
        "creation_date": 1543872614,
        "last_edit_date": 1543880940,
        "question_id": 53602197,
        "body_markdown": "I have an object that is just a bunch of arbitrary keys with each an array:\r\n\r\n    {\r\n      &quot;foo&quot;: [\r\n        &quot;hello&quot;,\r\n        &quot;world&quot;\r\n      ],\r\n      &quot;bar&quot;: [\r\n        &quot;foobar&quot;\r\n      ]\r\n    }\r\n\r\nHow can I return the merged arrays in this object. The expected output would be:\r\n\r\n    [\r\n      &quot;hello&quot;,\r\n      &quot;world&quot;,\r\n      &quot;foobar&quot;\r\n    ]",
        "link": "https://stackoverflow.com/questions/53602197/merge-arrays-in-object",
        "title": "Merge arrays in object"
    },
    {
        "tags": [
            "json",
            "linux",
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1543937653,
                "post_id": 53616327,
                "comment_id": 94093401,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 490514,
                    "reputation": 569,
                    "user_id": 986597,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/O0hCj.jpg?s=256",
                    "display_name": "Graham Nicholls",
                    "link": "https://stackoverflow.com/users/986597/graham-nicholls"
                },
                "reply_to_user": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1543937666,
                "post_id": 53616327,
                "comment_id": 94093411,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 57200,
                    "reputation": 158728,
                    "user_id": 171318,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/ePRKy.jpg?s=256",
                    "display_name": "hek2mgl",
                    "link": "https://stackoverflow.com/users/171318/hek2mgl"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1543938223,
                "post_id": 53616327,
                "comment_id": 94093730,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 490514,
                    "reputation": 569,
                    "user_id": 986597,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/O0hCj.jpg?s=256",
                    "display_name": "Graham Nicholls",
                    "link": "https://stackoverflow.com/users/986597/graham-nicholls"
                },
                "reply_to_user": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1543938269,
                "post_id": 53616327,
                "comment_id": 94093757,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 490514,
                    "reputation": 569,
                    "user_id": 986597,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/O0hCj.jpg?s=256",
                    "display_name": "Graham Nicholls",
                    "link": "https://stackoverflow.com/users/986597/graham-nicholls"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1543939010,
                "post_id": 53616327,
                "comment_id": 94094226,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1543943405,
                "last_edit_date": 1543943405,
                "creation_date": 1543939478,
                "answer_id": 53616949,
                "question_id": 53616327,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; ... using as small a toolset as possible.\r\n\r\nAs far as processing the JSON is concerned, it seems you need look no further than jq.\r\n\r\nFor example, your first command can be simplified to:\r\n\r\n    jq -r &#39;keys[]&#39; devsvr.json\r\n\r\nUse `keys_unsorted` if you want the keys in the original order.\r\n\r\nMore importantly, iterating over the keys can (and probably should) be done in jq. I&#39;m not sure what your exact requirements are but you should easily be able to adapt the following:\r\n\r\n\r\n    jq -r &#39;.[] | keys_unsorted[]&#39; devsvr.json\r\n\r\nwhich produces:\r\n\r\n    type\r\n    stage\r\n    descriptor\r\n    type\r\n    stage\r\n    descriptor\r\n\r\n## Update\r\n\r\nIn accordance with the update to the Q, the following filter should be considered:\r\n\r\n     keys[] as $serverName \r\n     | .[$serverName] \r\n     | &quot;\\($serverName) : \\(keys|join(&quot;,&quot;))&quot;\r\n",
                "title": "Json extracting list of field names for a key"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1543943405,
        "creation_date": 1543937515,
        "last_edit_date": 1543940049,
        "question_id": 53616327,
        "body_markdown": "jq is a great tool.   If I have a json file, I can extract the list of keys \r\n\r\nlike so:\r\n\r\n    jq keys filename | tr -d &#39;][&quot;,&#39;\r\neg:\r\n\r\n    $jq  keys pipeline/components/devsvr.json  | tr -d &#39;][&quot;,&#39;\r\n    server1\r\n    server2\r\n\r\nNow I&#39;d like to iterate over each key, listing the top-level field names only (I&#39;m trying to write a very simple validator for some CloudFormation json files).\r\n\r\nThe shell part is easy - just a for loop, but I can&#39;t work out how to say to jq: &quot;show me all the field-names only for key x.\r\n\r\nI&#39;ll then (in shell) check that each field I require is present.  As an aside, jq will report with an error if the json is malformed, which is useful as well.\r\n\r\nHere&#39;s an example file:\r\n\r\n\r\n    {\r\n      &quot;server1&quot;: {\r\n        &quot;type&quot;: &quot;single-instance&quot;,\r\n        &quot;stage&quot;: &quot;10default&quot;,\r\n        &quot;descriptor&quot;: {\r\n          &quot;Resources&quot;: {\r\n            &quot;Instance&quot;: {\r\n              &quot;Properties&quot;: {\r\n                &quot;InstanceType&quot;: &quot;t2.medium&quot;,\r\n                &quot;ImageId&quot;: {\r\n                  }\r\n                }\r\n              },\r\n              &quot;Metadata&quot;: {\r\n                &quot;AWS::CloudFormation::Init&quot;: {\r\n                  &quot;app&quot;: {\r\n                    &quot;packages&quot;: {\r\n                      &quot;yum&quot;: {\r\n                        &quot;tmux&quot;: [],\r\n                        &quot;vim&quot;: []\r\n                      }\r\n                    },\r\n                    &quot;files&quot;: {\r\n                    &quot;sources&quot;: {},\r\n                    &quot;commands&quot;: {},\r\n                    &quot;services&quot;: {}\r\n                  }\r\n                }\r\n              }\r\n            }\r\n          }\r\n        }\r\n      },\r\n      &quot;server2&quot;: {\r\n        &quot;type&quot;: &quot;single-instance&quot;,\r\n        &quot;stage&quot;: &quot;10default&quot;,\r\n        &quot;descriptor&quot;: {\r\n          &quot;Resources&quot;: {\r\n            &quot;Instance&quot;: {\r\n              &quot;Properties&quot;: {\r\n                &quot;InstanceType&quot;: &quot;t2.medium&quot;,\r\n                &quot;ImageId&quot;: {\r\n                  }\r\n                }\r\n              },\r\n              &quot;Metadata&quot;: {\r\n                &quot;AWS::CloudFormation::Init&quot;: {\r\n                  &quot;app&quot;: {\r\n                    &quot;packages&quot;: {\r\n                      &quot;yum&quot;: {\r\n                        &quot;tmux&quot;: [],\r\n                        &quot;vim&quot;: []\r\n                      }\r\n                    },\r\n                    &quot;files&quot;: {\r\n                    &quot;sources&quot;: {},\r\n                    &quot;commands&quot;: {},\r\n                    &quot;services&quot;: {}\r\n                  }\r\n                }\r\n              }\r\n            }\r\n          }\r\n        }\r\n      }\r\n    }\r\n\r\nSo with the example above, I&#39;d run jq keys &lt;filename&gt; to get the list of keys, then iterate over that.  I&#39;ve possibly answered my own question with the sed example which I&#39;ve commented with, but that&#39;s a bit heath-robinson, IMO.  Here&#39;s the result:\r\n\r\n    $jq  &#39;.server1&#39; /tmp/afile   | sed -n &#39;s#^  \\&quot;\\([^&quot;]*\\).*$#\\1#p&#39;\r\n    type\r\n    stage\r\n    descriptor\r\n\r\n(that would be in a loop around the output of  the jq &#39;keys&#39; command).\r\n\r\nUpdate: As per @peak and @Aaron, I can do this:\r\n\r\n    jq -r &#39;. as $in | keys[] | . as $serverName | $in[$serverName] | keys | join(&quot;,&quot;) | &quot;\\($serverName) : \\(.)&quot;&#39; pipeline/components/devsvr.json\r\n    devsvr : descriptor,stage,type\r\n    devsvr1 :\r\n\r\nWith the proviso that http://json-schema.org exists for a more rigorous implementation.\r\n\r\n",
        "link": "https://stackoverflow.com/questions/53616327/json-extracting-list-of-field-names-for-a-key",
        "title": "Json extracting list of field names for a key"
    },
    {
        "tags": [
            "json",
            "join",
            "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": 1543943599,
                "post_id": 53618118,
                "comment_id": 94096751,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2873877,
                    "reputation": 113,
                    "user_id": 2466550,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/ae3ba371b5f0c3fd116c1e246fb41da0?s=256&d=identicon&r=PG",
                    "display_name": "heartlex",
                    "link": "https://stackoverflow.com/users/2466550/heartlex"
                },
                "reply_to_user": {
                    "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": 1543998809,
                "post_id": 53618118,
                "comment_id": 94115921,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1543950403,
                "creation_date": 1543950403,
                "answer_id": 53619825,
                "question_id": 53618118,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s one of many possible solutions.  If your jq does not have `INDEX/2`, then either upgrade your jq or include its def (available e.g. from https://github.com/stedolan/jq/blob/master/src/builtin.jq):\r\n\r\nInvocation:\r\n\r\n    jq -n --argfile f1 file1.json --argfile f2 file2.json -f merge.jq\r\n\r\nmerge.jq:\r\n\r\n    INDEX($f2[] ; .id) as $dict\r\n    | $f1\r\n    | map( ($dict[.suppliers[0]|tostring]|.vatNumber) as $vn\r\n           | if $vn then .vatNumber = $vn else . end)\r\n\r\n",
                "title": "jq- merge two json files on a value"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1543950403,
        "creation_date": 1543943166,
        "last_edit_date": 1543943602,
        "question_id": 53618118,
        "body_markdown": "i have two json files structured like that:\r\n\r\nfile 1\r\n\r\n    [\r\n    {\r\n        &quot;id&quot;: 25422,\r\n        &quot;location&quot;: &quot;Hotel X&quot;,\r\n        &quot;suppliers&quot;: [\r\n            12\r\n        ]\r\n    },\r\n    {\r\n        &quot;id&quot;: 25423,\r\n        &quot;location&quot;: &quot;Hotel Y&quot;,\r\n        &quot;suppliers&quot;: [\r\n            13\r\n        ]\r\n    }]\r\n\r\nfile 2\r\n\r\n    [\r\n    {\r\n        &quot;id&quot;: 12,\r\n        &quot;vatNumber&quot;: &quot;0000000000&quot;\r\n    },\r\n    {\r\n        &quot;id&quot;: 14,\r\n        &quot;vatNumber&quot;: &quot;0000000001&quot;\r\n    }]\r\n\r\nand i&#39;d like a result like this\r\n\r\n    [\r\n    {\r\n        &quot;id&quot;: 25422,\r\n        &quot;location&quot;: &quot;Hotel X&quot;,\r\n        &quot;suppliers&quot;: [\r\n            12\r\n        ],\r\n        &quot;vatNumber&quot;: &quot;0000000000&quot;\r\n    },\r\n    {\r\n        &quot;id&quot;: 25423,\r\n        &quot;location&quot;: &quot;Hotel Y&quot;,\r\n        &quot;suppliers&quot;: [\r\n            13\r\n        ],\r\n    }]\r\n\r\nThe important thing to me is that the matching vatNumbers, are set in the first file. Supplier arrays are not required anymore after the melding, if it simplifies the job.\r\nAlso jq is not essential, but i need something i can use via terminal to set up a script.\r\nThank you in advance.",
        "link": "https://stackoverflow.com/questions/53618118/jq-merge-two-json-files-on-a-value",
        "title": "jq- merge two json files on a value"
    },
    {
        "tags": [
            "arrays",
            "json",
            "curl",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 349625,
                    "reputation": 1883,
                    "user_id": 685022,
                    "user_type": "registered",
                    "accept_rate": 97,
                    "profile_image": "https://www.gravatar.com/avatar/8beaf2927f474fe7ae3da6cd75846ba7?s=256&d=identicon&r=PG",
                    "display_name": "krizzo",
                    "link": "https://stackoverflow.com/users/685022/krizzo"
                },
                "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": 1543990832,
                "post_id": 53625680,
                "comment_id": 94112426,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1544070316,
                "creation_date": 1544070316,
                "answer_id": 53644650,
                "question_id": 53625680,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you know a better solution using jq with in the forloop to write the user data to the array with in the file let me know. I&#39;m really interested in understanding if that is possible with jq.\r\n\r\nI would prefer if I didn&#39;t have to write to a temp file and instead could read from the file append the new curl user data and write back to the file within the for loop but I get the results and proper json this way.\r\n\r\nMy semi decent solution using JQ. I end up writing multiple user files and then combine them together with slurping. \r\n\r\n    for i in {1..4}; do\r\n      echo -e &quot;==&gt; Creating a temp user json file for user${i}.&quot;\r\n      testUrl=https://jsonplaceholder.typicode.com/users/${i}\r\n      curl -s ${testUrl} | jq &#39;. + {level: 15}&#39; &gt;&gt; /tmp/temp_user_${i}_information_file.json\r\n    done\r\n\r\n    echo -e &quot;==&gt; Creating the final users json file.&quot;\r\n    jq -s &#39;.&#39; /tmp/temp_user_*_information_file.json &gt; userList.json",
                "title": "Append to curl object and add to array in file with jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1544070316,
        "creation_date": 1543987595,
        "last_edit_date": 1543992011,
        "question_id": 53625680,
        "body_markdown": "I&#39;m trying to generate a json array of objects dynamically from a URL and save the array to a file. Is it possible to pipe curls output to jq modify the curl json object and then append it to a json list in a file and save the updated list back to the file?\r\n\r\nThe goal is to iterate over a list and hit a URL pulling the object down then adding a field to the object and writing the output to a single json file.\r\n\r\nFirst we curl the url to get the user object and add a new field to it.\r\n\r\n    curl -s https://jsonplaceholder.typicode.com/users/1 | jq &#39;. + {&quot;level&quot;: 15}&#39;\r\n\r\nA diff showing what is being added to the object.\r\n\r\n    diff &lt;(curl -s https://jsonplaceholder.typicode.com/users/1 | jq . ) &lt;(curl -s https://jsonplaceholder.typicode.com/users/1 | jq &#39;. + {&quot;level&quot;: 15}&#39;)\r\n\r\nSecond we add that user object to the list in userList.json. This is the part that I&#39;m stumped on. \r\n\r\nThird we write that updated list back to the file.\r\n\r\n    JQ updated list command &gt; userList.json\r\n\r\nCurl URL for user object, append value to user object and append user object to array in file. I tried using `--argjson fileInfo &quot;$(&lt;userList.json)&quot;` but couldn&#39;t seem to get it to work. I get an invalid path expression or other errors of not being able to add an object to an array. I&#39;ve tried the `|= . +` but can&#39;t figure out how to reference the two data sets correctly.\r\n\r\n    echo -e &quot;[\\n]&quot; &gt; userList.json\r\n    for i in {1..4}; do\r\n      echo -e &quot;\\n==&gt; User ${i}&quot;\r\n      testUrl=https://jsonplaceholder.typicode.com/users/${i}\r\n      curl -s ${testUrl} | jq --argjson fileData &quot;$(&lt;userList.json)&quot; &#39;. + {level: 15} += [$fileData]&#39; &gt; userList.json\r\n    done\r\n    echo -e &quot;==&gt; Complete&quot;\r\n    jq . userList.json\r\n\r\nA non-json way of creating the file but it&#39;s would be missing the comma separator between each user object, I could programmatically add the comma but I&#39;d rather figure out jq and have it write proper json instead. Compare the output of this loop with the expected data below.\r\n\r\n    for i in {1..4}; do \r\n      testUrl=https://jsonplaceholder.typicode.com/users/${i}\r\n      curl -s ${testUrl} | jq &#39;. + {level: 15}&#39; &gt;&gt; userList.json\r\n    done\r\n\r\nExpected result of userList.json file, it&#39;s the 4 user objects with an added field level.\r\n\r\n    [\r\n      {\r\n        &quot;id&quot;: 1,\r\n        &quot;name&quot;: &quot;Leanne Graham&quot;,\r\n        &quot;username&quot;: &quot;Bret&quot;,\r\n        &quot;email&quot;: &quot;Sincere@april.biz&quot;,\r\n        &quot;address&quot;: {\r\n          &quot;street&quot;: &quot;Kulas Light&quot;,\r\n          &quot;suite&quot;: &quot;Apt. 556&quot;,\r\n          &quot;city&quot;: &quot;Gwenborough&quot;,\r\n          &quot;zipcode&quot;: &quot;92998-3874&quot;,\r\n          &quot;geo&quot;: {\r\n            &quot;lat&quot;: &quot;-37.3159&quot;,\r\n            &quot;lng&quot;: &quot;81.1496&quot;\r\n          }\r\n        },\r\n        &quot;phone&quot;: &quot;1-770-736-8031 x56442&quot;,\r\n        &quot;website&quot;: &quot;hildegard.org&quot;,\r\n        &quot;company&quot;: {\r\n          &quot;name&quot;: &quot;Romaguera-Crona&quot;,\r\n          &quot;catchPhrase&quot;: &quot;Multi-layered client-server neural-net&quot;,\r\n          &quot;bs&quot;: &quot;harness real-time e-markets&quot;\r\n        },\r\n        &quot;level&quot;: 15\r\n      },\r\n      {\r\n        &quot;id&quot;: 2,\r\n        &quot;name&quot;: &quot;Ervin Howell&quot;,\r\n        &quot;username&quot;: &quot;Antonette&quot;,\r\n        &quot;email&quot;: &quot;Shanna@melissa.tv&quot;,\r\n        &quot;address&quot;: {\r\n          &quot;street&quot;: &quot;Victor Plains&quot;,\r\n          &quot;suite&quot;: &quot;Suite 879&quot;,\r\n          &quot;city&quot;: &quot;Wisokyburgh&quot;,\r\n          &quot;zipcode&quot;: &quot;90566-7771&quot;,\r\n          &quot;geo&quot;: {\r\n            &quot;lat&quot;: &quot;-43.9509&quot;,\r\n            &quot;lng&quot;: &quot;-34.4618&quot;\r\n          }\r\n        },\r\n        &quot;phone&quot;: &quot;010-692-6593 x09125&quot;,\r\n        &quot;website&quot;: &quot;anastasia.net&quot;,\r\n        &quot;company&quot;: {\r\n          &quot;name&quot;: &quot;Deckow-Crist&quot;,\r\n          &quot;catchPhrase&quot;: &quot;Proactive didactic contingency&quot;,\r\n          &quot;bs&quot;: &quot;synergize scalable supply-chains&quot;\r\n        },\r\n        &quot;level&quot;: 15\r\n      },\r\n      {\r\n        &quot;id&quot;: 3,\r\n        &quot;name&quot;: &quot;Clementine Bauch&quot;,\r\n        &quot;username&quot;: &quot;Samantha&quot;,\r\n        &quot;email&quot;: &quot;Nathan@yesenia.net&quot;,\r\n        &quot;address&quot;: {\r\n          &quot;street&quot;: &quot;Douglas Extension&quot;,\r\n          &quot;suite&quot;: &quot;Suite 847&quot;,\r\n          &quot;city&quot;: &quot;McKenziehaven&quot;,\r\n          &quot;zipcode&quot;: &quot;59590-4157&quot;,\r\n          &quot;geo&quot;: {\r\n            &quot;lat&quot;: &quot;-68.6102&quot;,\r\n            &quot;lng&quot;: &quot;-47.0653&quot;\r\n          }\r\n        },\r\n        &quot;phone&quot;: &quot;1-463-123-4447&quot;,\r\n        &quot;website&quot;: &quot;ramiro.info&quot;,\r\n        &quot;company&quot;: {\r\n          &quot;name&quot;: &quot;Romaguera-Jacobson&quot;,\r\n          &quot;catchPhrase&quot;: &quot;Face to face bifurcated interface&quot;,\r\n          &quot;bs&quot;: &quot;e-enable strategic applications&quot;\r\n        },\r\n        &quot;level&quot;: 15\r\n      },\r\n      {\r\n        &quot;id&quot;: 4,\r\n        &quot;name&quot;: &quot;Patricia Lebsack&quot;,\r\n        &quot;username&quot;: &quot;Karianne&quot;,\r\n        &quot;email&quot;: &quot;Julianne.OConner@kory.org&quot;,\r\n        &quot;address&quot;: {\r\n          &quot;street&quot;: &quot;Hoeger Mall&quot;,\r\n          &quot;suite&quot;: &quot;Apt. 692&quot;,\r\n          &quot;city&quot;: &quot;South Elvis&quot;,\r\n          &quot;zipcode&quot;: &quot;53919-4257&quot;,\r\n          &quot;geo&quot;: {\r\n            &quot;lat&quot;: &quot;29.4572&quot;,\r\n            &quot;lng&quot;: &quot;-164.2990&quot;\r\n          }\r\n        },\r\n        &quot;phone&quot;: &quot;493-170-9623 x156&quot;,\r\n        &quot;website&quot;: &quot;kale.biz&quot;,\r\n        &quot;company&quot;: {\r\n          &quot;name&quot;: &quot;Robel-Corkery&quot;,\r\n          &quot;catchPhrase&quot;: &quot;Multi-tiered zero tolerance productivity&quot;,\r\n          &quot;bs&quot;: &quot;transition cutting-edge web services&quot;\r\n        },\r\n        &quot;level&quot;: 15\r\n      }\r\n    ]",
        "link": "https://stackoverflow.com/questions/53625680/append-to-curl-object-and-add-to-array-in-file-with-jq",
        "title": "Append to curl object and add to array in file with jq?"
    },
    {
        "tags": [
            "json",
            "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": 1544007854,
                "post_id": 53630450,
                "comment_id": 94121037,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 7868325,
                    "reputation": 11,
                    "user_id": 5946490,
                    "user_type": "registered",
                    "profile_image": "https://lh4.googleusercontent.com/-KDXBCmUwwPI/AAAAAAAAAAI/AAAAAAAAAJM/RZaqpgrK9Lw/s256-rj/photo.jpg",
                    "display_name": "Eli Blumen",
                    "link": "https://stackoverflow.com/users/5946490/eli-blumen"
                },
                "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": 1544014939,
                "post_id": 53630450,
                "comment_id": 94125277,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1544015847,
                "post_id": 53630450,
                "comment_id": 94125848,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 7868325,
                    "reputation": 11,
                    "user_id": 5946490,
                    "user_type": "registered",
                    "profile_image": "https://lh4.googleusercontent.com/-KDXBCmUwwPI/AAAAAAAAAAI/AAAAAAAAAJM/RZaqpgrK9Lw/s256-rj/photo.jpg",
                    "display_name": "Eli Blumen",
                    "link": "https://stackoverflow.com/users/5946490/eli-blumen"
                },
                "reply_to_user": {
                    "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": 1544025804,
                "post_id": 53630450,
                "comment_id": 94132188,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 7868325,
                    "reputation": 11,
                    "user_id": 5946490,
                    "user_type": "registered",
                    "profile_image": "https://lh4.googleusercontent.com/-KDXBCmUwwPI/AAAAAAAAAAI/AAAAAAAAAJM/RZaqpgrK9Lw/s256-rj/photo.jpg",
                    "display_name": "Eli Blumen",
                    "link": "https://stackoverflow.com/users/5946490/eli-blumen"
                },
                "reply_to_user": {
                    "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": 1544025870,
                "post_id": 53630450,
                "comment_id": 94132225,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1544009628,
                "creation_date": 1544009628,
                "answer_id": 53631362,
                "question_id": 53630450,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The following answer does not deal with every requirement you&#39;ve mentioned\r\nbut it will hopefully get you over the main hurdle you&#39;ve evidently been facing.\r\n\r\nSince your requirements regarding the &quot;customVariables&quot; are not clear to me,\r\nI&#39;ll ignore .customVariables completely, and hopefully you&#39;ll also\r\nbe able to handle .pluginsIcons yourself once you&#39;re over the main hurdle.\r\nSo for clarity, I&#39;ll simply delete those keys.\r\n\r\nAs I understand it, you want some grouping to take place after the flattening based\r\non .actionDetails.  These requirements are also unclear to me so let&#39;s\r\nfocus on the flattening:\r\n\r\n    .[]\r\n    | .actionDetails[] + (del(.actionDetails) | del(.customVariables) | del(.pluginsIcons))\r\n\r\nThis produces a stream of JSON objects, the first two of which are:\r\n\r\n    {\r\n      &quot;timestamp&quot;: 84615195,\r\n      &quot;interactionPosition&quot;: &quot;1&quot;,\r\n      &quot;type&quot;: &quot;action&quot;,\r\n      &quot;Value1&quot;: &quot;0&quot;,\r\n      &quot;Conversions&quot;: &quot;0&quot;,\r\n      &quot;Revenue&quot;: &quot;0.00&quot;,\r\n      &quot;serverTimestamp&quot;: 84615198,\r\n      &quot;plugins&quot;: &quot;pdf, java&quot;,\r\n      &quot;interactions&quot;: &quot;7&quot;,\r\n      &quot;actions&quot;: &quot;3&quot;,\r\n      &quot;operatingSystem&quot;: &quot;Windows 10&quot;\r\n    }\r\n    {\r\n      &quot;timestamp&quot;: 84615145,\r\n      &quot;interactionPosition&quot;: &quot;2&quot;,\r\n      &quot;type&quot;: &quot;action&quot;,\r\n      &quot;Value1&quot;: &quot;0&quot;,\r\n      &quot;Conversions&quot;: &quot;0&quot;,\r\n      &quot;Revenue&quot;: &quot;0.00&quot;,\r\n      &quot;serverTimestamp&quot;: 84615198,\r\n      &quot;plugins&quot;: &quot;pdf, java&quot;,\r\n      &quot;interactions&quot;: &quot;7&quot;,\r\n      &quot;actions&quot;: &quot;3&quot;,\r\n      &quot;operatingSystem&quot;: &quot;Windows 10&quot;\r\n    }\r\n\r\nThis is very similar to the expected output you&#39;ve shown, so hopefully you can take it from here.\r\n\r\n\r\n",
                "title": "jq: Group by nested structures and flatten JSON"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1544015314,
        "creation_date": 1544006564,
        "last_edit_date": 1544015314,
        "question_id": 53630450,
        "body_markdown": "I&#39;m new to jq and command line tools in general, but I need to group by nested structures in a JSON file and flatten the nested structures, and I&#39;ve not been able to find a workable solution for a few days, here&#39;s a sample of my JSON.\r\n\r\n    [\r\n      {\r\n        &quot;Value1&quot;: &quot;0&quot;,\r\n        &quot;Conversions&quot;: &quot;0&quot;,\r\n        &quot;Revenue&quot;: &quot;0.00&quot;,\r\n        &quot;serverTimestamp&quot;: 84615198,\r\n        &quot;pluginsIcons&quot;: [\r\n          {\r\n            &quot;pluginName&quot;: &quot;pdf&quot;,\r\n            &quot;pluginIcon&quot;: &quot;pdf1&quot;\r\n          },\r\n          {\r\n            &quot;pluginName&quot;: &quot;java&quot;,\r\n            &quot;pluginIcon&quot;: &quot;java1&quot;\r\n          }\r\n        ],\r\n        &quot;plugins&quot;: &quot;pdf, java&quot;,\r\n        &quot;customVariables&quot;: {\r\n          &quot;3&quot;: {\r\n            &quot;customVariableValue3&quot;: &quot;F&quot;,\r\n            &quot;customVariableName3&quot;: &quot;Gender&quot;\r\n          },\r\n          &quot;2&quot;: {\r\n            &quot;customVariableValue2&quot;: &quot;Person&quot;,\r\n            &quot;customVariableName2&quot;: &quot;Role&quot;\r\n          },\r\n          &quot;1&quot;: {\r\n            &quot;customVariableValue1&quot;: &quot;Partner1&quot;,\r\n            &quot;customVariableName1&quot;: &quot;Partner&quot;\r\n          }\r\n        },\r\n        &quot;interactions&quot;: &quot;7&quot;,\r\n        &quot;actions&quot;: &quot;3&quot;,\r\n        &quot;actionDetails&quot;: [\r\n          {\r\n            &quot;timestamp&quot;: 84615195,\r\n            &quot;interactionPosition&quot;: &quot;1&quot;,\r\n            &quot;type&quot;: &quot;action&quot;\r\n          },\r\n          {\r\n            &quot;timestamp&quot;: 84615145,\r\n            &quot;interactionPosition&quot;: &quot;2&quot;,\r\n            &quot;type&quot;: &quot;action&quot;\r\n          },\r\n          {\r\n            &quot;timestamp&quot;: 84615693,\r\n            &quot;interactionPosition&quot;: &quot;3&quot;,\r\n            &quot;type&quot;: &quot;action&quot;,\r\n            &quot;customVariables&quot;: {\r\n              &quot;2&quot;: {\r\n                &quot;customVariablePageValue2&quot;: &quot;value2&quot;,\r\n                &quot;customVariablePageName2&quot;: &quot;name2&quot;\r\n              },\r\n              &quot;1&quot;: {\r\n                &quot;customVariablePageValue1&quot;: &quot;value1&quot;,\r\n                &quot;customVariablePageName1&quot;: &quot;name1&quot;\r\n              }\r\n            }\r\n          }\r\n        ],\r\n        &quot;operatingSystem&quot;: &quot;Windows 10&quot;\r\n      },\r\n      {\r\n        &quot;Value1&quot;: &quot;18&quot;,\r\n        &quot;Conversions&quot;: &quot;1&quot;,\r\n        &quot;Revenue&quot;: &quot;0.00&quot;,\r\n        &quot;serverTimestamp&quot;: 84615189,\r\n        &quot;pluginsIcons&quot;: [\r\n          {\r\n            &quot;pluginName&quot;: &quot;pdf&quot;,\r\n            &quot;pluginIcon&quot;: &quot;pdf1&quot;\r\n          }\r\n        ],\r\n        &quot;plugins&quot;: &quot;pdf&quot;,\r\n        &quot;customVariables&quot;: {\r\n          &quot;3&quot;: {\r\n            &quot;customVariableValue3&quot;: &quot;M&quot;,\r\n            &quot;customVariableName3&quot;: &quot;Gender&quot;\r\n          },\r\n          &quot;2&quot;: {\r\n            &quot;customVariableValue2&quot;: &quot;Admin&quot;,\r\n            &quot;customVariableName2&quot;: &quot;Role&quot;\r\n         },\r\n          &quot;1&quot;: {\r\n            &quot;customVariableValue1&quot;: &quot;Place&quot;,\r\n            &quot;customVariableName1&quot;: &quot;Subdomain&quot;\r\n          }\r\n        },\r\n        &quot;interactions&quot;: &quot;6&quot;,\r\n        &quot;actions&quot;: &quot;3&quot;,\r\n        &quot;actionDetails&quot;: [\r\n          {\r\n            &quot;timestamp&quot;: 84635189,\r\n            &quot;timeSpent&quot;: &quot;11&quot;,\r\n            &quot;interactionPosition&quot;: &quot;1&quot;,\r\n            &quot;type&quot;: &quot;action&quot;\r\n          },\r\n          {\r\n            &quot;timestamp&quot;: 846351834,\r\n            &quot;timeSpent&quot;: &quot;11&quot;,\r\n            &quot;interactionPosition&quot;: &quot;2&quot;,\r\n            &quot;type&quot;: &quot;search&quot;\r\n          },\r\n          {\r\n            &quot;timestamp&quot;: 846351832,\r\n            &quot;timeSpent&quot;: &quot;1&quot;,\r\n            &quot;interactionPosition&quot;: &quot;3&quot;,\r\n            &quot;type&quot;: &quot;action&quot;,\r\n            &quot;customVariables&quot;: {\r\n              &quot;2&quot;: {\r\n                &quot;customVariablePageValue2&quot;: &quot;value2&quot;,\r\n                &quot;customVariablePageName2&quot;: &quot;name2&quot;\r\n              },\r\n              &quot;1&quot;: {\r\n                &quot;customVariablePageValue3&quot;: &quot;value3&quot;,\r\n                &quot;customVariablePageName3&quot;: &quot;name3&quot;\r\n              }\r\n            },\r\n            &quot;generationTime&quot;: &quot;890&quot;\r\n          }\r\n        ],\r\n        &quot;operatingSystem&quot;: &quot;Windows 10&quot;\r\n      }\r\n    ]\r\n\r\nThe way it should look at the end result would be with one flattened entry for each &quot;action&quot; in the nested arrays under &quot;actionDetails&quot;\r\n\r\nI have been able to flatten the structures, but then grouping by (and duplicating the other columns for each action) becomes convoluted.  Grouping by the &quot;action&quot;s before flattening has not worked for me because they&#39;re nested.\r\n\r\nAn example of how the first entry in the original JSON should look afterwards is:  \r\n\r\n    [\r\n      {\r\n        &quot;timestamp&quot;: 84615195,\r\n        &quot;interactionPosition&quot;: &quot;1&quot;,\r\n        &quot;type&quot;: &quot;action&quot;,\r\n        &quot;Value1&quot;: &quot;0&quot;,\r\n        &quot;Conversions&quot;: &quot;0&quot;,\r\n        &quot;Revenue&quot;: &quot;0.00&quot;,\r\n        &quot;pluginName1&quot;: &quot;pdf&quot;,\r\n        &quot;pluginIcon1&quot;: &quot;pdf&quot;,\r\n        &quot;pluginName2&quot;: &quot;java&quot;,\r\n        &quot;pluginIcon2&quot;: &quot;java&quot;,\r\n        &quot;plugins&quot;: &quot;pdf, java&quot;,\r\n        &quot;Gender&quot;: &quot;F&quot;,\r\n        &quot;Role&quot;: &quot;Person&quot;,\r\n        &quot;Partner&quot;: &quot;Partner1&quot;,\r\n        &quot;interactions&quot;: &quot;7&quot;,\r\n        &quot;actions&quot;: &quot;3&quot;,\r\n        &quot;operatingSystem&quot;: &quot;Windows 10&quot;\r\n      },\r\n      {\r\n        &quot;timestamp&quot;: 84615145,\r\n        &quot;interactionPosition&quot;: &quot;2&quot;,\r\n        &quot;type&quot;: &quot;action&quot;,\r\n        &quot;Value1&quot;: &quot;0&quot;,\r\n        &quot;Conversions&quot;: &quot;0&quot;,\r\n        &quot;Revenue&quot;: &quot;0.00&quot;,\r\n        &quot;pluginName1&quot;: &quot;pdf&quot;,\r\n        &quot;pluginIcon1&quot;: &quot;pdf&quot;,\r\n        &quot;pluginName2&quot;: &quot;java&quot;,\r\n        &quot;pluginIcon2&quot;: &quot;java&quot;,\r\n        &quot;plugins&quot;: &quot;pdf, java&quot;,\r\n        &quot;Gender&quot;: &quot;F&quot;,\r\n        &quot;Role&quot;: &quot;Person&quot;,\r\n        &quot;Partner&quot;: &quot;Partner1&quot;,\r\n        &quot;interactions&quot;: &quot;7&quot;,\r\n        &quot;actions&quot;: &quot;3&quot;,\r\n        &quot;operatingSystem&quot;: &quot;Windows 10&quot;\r\n      },\r\n      {\r\n        &quot;timestamp&quot;: 84615693,\r\n        &quot;interactionPosition&quot;: &quot;3&quot;,\r\n        &quot;type&quot;: &quot;action&quot;,\r\n        &quot;Value1&quot;: &quot;0&quot;,\r\n        &quot;Conversions&quot;: &quot;0&quot;,\r\n        &quot;Revenue&quot;: &quot;0.00&quot;,\r\n        &quot;pluginName1&quot;: &quot;pdf&quot;,\r\n        &quot;pluginIcon1&quot;: &quot;pdf&quot;,\r\n        &quot;pluginName2&quot;: &quot;java&quot;,\r\n        &quot;pluginIcon2&quot;: &quot;java&quot;,\r\n        &quot;plugins&quot;: &quot;pdf, java&quot;,\r\n        &quot;Gender&quot;: &quot;F&quot;,\r\n        &quot;Role&quot;: &quot;Person&quot;,\r\n        &quot;Partner&quot;: &quot;Partner1&quot;,\r\n        &quot;interactions&quot;: &quot;7&quot;,\r\n        &quot;actions&quot;: &quot;3&quot;,\r\n        &quot;operatingSystem&quot;: &quot;Windows 10&quot;,\r\n        &quot;name1&quot;: &quot;value1&quot;,\r\n        &quot;name2&quot;: &quot;value2&quot;\r\n       }\r\n    ]\r\n\r\nYou may note in the above that some of the flattened key names have been replaced by an associated value (inside the same nested structure).  This isn&#39;t completely necessary, but it would be a nice bonus.  Also worth noting:  My JSON is large (800MB), and I would like to do that, but I suppose that point would be best posed in another question.\r\n\r\nThanks in advance for any assistance or advice!\r\n",
        "link": "https://stackoverflow.com/questions/53630450/jq-group-by-nested-structures-and-flatten-json",
        "title": "jq: Group by nested structures and flatten JSON"
    },
    {
        "tags": [
            "bash",
            "curl",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": -2,
                "last_activity_date": 1544083517,
                "last_edit_date": 1544083517,
                "creation_date": 1544023907,
                "answer_id": 53635690,
                "question_id": 53635253,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Maybe you should store the response in a variable, and use it to access the `ETag:` header and the json.\r\n\r\nGive a try to this:\r\n\r\n    response=&quot;$(curl -s &#39;https://ci.example.com/go/api/admin/pipelines/my_pipeline&#39; \\\r\n    -u &#39;username:password&#39; \\\r\n    -H &#39;Accept: application/vnd.go.cd.v6+json&#39; \\\r\n    -i)&quot;\r\n    etag_header=$(printf &#39;%s&#39; &quot;${response}&quot; | sed -n &#39;/^ETag.*/ { p }&#39;)\r\n    body_json=&quot;{${response#*{}&quot;\r\n\r\n    # use etag_header\r\n    printf &quot;%s\\n&quot; &quot;${etag_header}&quot;\r\n\r\n    # use body_json\r\n    printf &quot;%s\\n&quot; &quot;${body_json}&quot; | jq\r\n    \r\nOutput:\r\n\r\n    ETag: &quot;e064ca0fe5d8a39602e19666454b8d77&quot;\r\n    {\r\n      &quot;_links&quot;: {\r\n        &quot;self&quot;: {\r\n          &quot;href&quot;: &quot;https://ci.example.com/go/api/admin/pipelines/my_pipeline&quot;    \r\n        }\r\n      },\r\n      &quot;doc&quot;: {\r\n        &quot;href&quot;: &quot;https://api.gocd.org/#pipeline-config&quot;\r\n      },\r\n    ...",
                "title": "Curl bash get a header and the body without string manipulation"
            },
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1544026096,
                "last_edit_date": 1544026096,
                "creation_date": 1544025702,
                "answer_id": 53636219,
                "question_id": 53635253,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`curl` returns a sequence of CR/LF-terminated lines, with the last line (following an empty line) being the actual body. You can write a code block that first uses a `while` loop to parse the headers out of the standard input, terminating when the header block is complete, then uses `jq` to read the rest of the input. For example:\r\n\r\n    # Consume standard input up to, and including, an empty line.\r\n    # Sets global variable &#39;etag&#39;.\r\n    parse_headers () {\r\n      local header etag_regex=&#39;ETag: (.*)&#39;\r\n      while read -d $&#39;\\r\\n&#39; header; do\r\n        if [[ $header =~ $etag_regex ]]; then\r\n          etag=${BASH_REMATCH[1]}\r\n        elif [[ -z $header ]]; then\r\n          # End of headers\r\n          break\r\n        fi\r\n      done\r\n    }\r\n\r\n    # Pass input first to parse_headers, then to jq\r\n    {\r\n      parse_headers\r\n      jq &#39;._links.self&#39;  # After parse_headers is done, only the JSON should remain\r\n    } &lt; &lt;(curl ...)\r\n    echo &quot;ETag is $etag&quot;\r\n\r\nExample output\r\n\r\n    {\r\n      &quot;href&quot;: &quot;https://ci.example.com/go/api/admin/pipelines/my_pipeline&quot;\r\n    }\r\n    ETag is &quot;e064ca0fe5d8a39602e19666454b8d77&quot;",
                "title": "Curl bash get a header and the body without string manipulation"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 4,
        "last_activity_date": 1544083517,
        "creation_date": 1544022493,
        "question_id": 53635253,
        "body_markdown": "I am using curl and bash to get a config from go cd. i need the header labeled ETag but also want the json body. is there a easy way to do this using curl or do i have to manipulate the result in bash?\r\n\r\n    $ curl &#39;https://ci.example.com/go/api/admin/pipelines/my_pipeline&#39; \\\r\n        -u &#39;username:password&#39; \\\r\n        -H &#39;Accept: application/vnd.go.cd.v6+json&#39; \\\r\n        -i\r\n\r\nreturns this: \r\n\r\n    HTTP/1.1 200 OK\r\n    Content-Type: application/vnd.go.cd.v6+json; charset=utf-8\r\n    ETag: &quot;e064ca0fe5d8a39602e19666454b8d77&quot;\r\n    {\r\n         &quot;_links&quot;: {\r\n         &quot;self&quot;: {\r\n                 &quot;href&quot;: &quot;https://ci.example.com/go/api/admin/pipelines/my_pipeline&quot;\r\n    },\r\n    &quot;doc&quot;: {\r\n      &quot;href&quot;: &quot;https://api.gocd.org/#pipeline-config&quot;\r\n    },\r\n    ...\r\n\r\ni cannot use jq because it complains about the headers, but i want the ETag header and its value too. ",
        "link": "https://stackoverflow.com/questions/53635253/curl-bash-get-a-header-and-the-body-without-string-manipulation",
        "title": "Curl bash get a header and the body without string manipulation"
    },
    {
        "tags": [
            "json",
            "edit",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1544032399,
                "creation_date": 1544032399,
                "answer_id": 53638076,
                "question_id": 53637610,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Yes it is.\r\n\r\n    $ jq -c &#39;map(.id |= &quot;coupon\\(.)&quot;)&#39; &lt;&lt;&lt; &#39;[{&quot;id&quot;: 25422},{&quot;id&quot;: 25423}]&#39;\r\n    [{&quot;id&quot;:&quot;coupon25422&quot;},{&quot;id&quot;:&quot;coupon25423&quot;}]",
                "title": "jq-update a value of a json adding a prefix"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1544119743,
        "creation_date": 1544030508,
        "last_edit_date": 1544119743,
        "question_id": 53637610,
        "body_markdown": "i&#39;ve a json file like this\r\n\r\n    [{&quot;id&quot;: 25422},{&quot;id&quot;: 25423}]\r\n\r\nand i like to update the id value and obtain this result\r\n\r\n    [{&quot;id&quot;: &quot;coupon25422&quot;},{&quot;id&quot;: &quot;coupon25423&quot;}]\r\n\r\nIs this possible? thank you",
        "link": "https://stackoverflow.com/questions/53637610/jq-update-a-value-of-a-json-adding-a-prefix",
        "title": "jq-update a value of a json adding a prefix"
    },
    {
        "tags": [
            "json",
            "linux",
            "wordpress",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1544033524,
                "post_id": 53638148,
                "comment_id": 94136305,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 9,
                "is_accepted": false,
                "score": 9,
                "last_activity_date": 1544036268,
                "last_edit_date": 1544036268,
                "creation_date": 1544033774,
                "answer_id": 53638411,
                "question_id": 53638148,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To add `&quot;siteurl&quot;:&quot;http://mysite1.com&quot;` to every object:\r\n\r\n    jq &#39;map(.siteurl = &quot;http://mytest1.com&quot;)&#39; file.json\r\n\r\nTo copy `siteurl` from the first object:\r\n\r\n    jq &#39;.[0].siteurl as $v | map(.siteurl = $v)&#39; file.json",
                "title": "Add a Key Value Pair in JSON Object Using JQ and Bash"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1544046950,
        "creation_date": 1544032739,
        "last_edit_date": 1544046950,
        "question_id": 53638148,
        "body_markdown": "Editing this post for clarification as I didn&#39;t do a good job the first time around --\r\n\r\nI have a script that crawls through a directory and pulls info from WP sites and builds a JSON array of objects that will eventually be fed into a visual dashboard. The script works perfectly but I can&#39;t seem to get the `siteurl` key to post in every object as it does in the first.\r\n\r\nThe key-pairs that have null need to be replaced with the corresponding `siteurl` within it&#39;s array. \r\n\r\nI feel I should be able to do this with jq and the `--arg name value` option but I clearly am doing something wrong. Not sure if I&#39;m not passing the variables correctly or if it&#39;s an issue with WPCLI.\r\n\r\nOutput and script are below.\r\n\r\n    [\r\n      {\r\n        &quot;eventType&quot;: &quot;WordpressSite&quot;,\r\n        &quot;siteurl&quot;: &quot;http://mytest1.com&quot;\r\n      },\r\n      {\r\n        &quot;eventType&quot;: &quot;WordpressPlugin&quot;,\r\n        &quot;plugin_name&quot;: &quot;akismet&quot;,\r\n        &quot;plugin_status&quot;: &quot;inactive&quot;,\r\n        &quot;plugin_update&quot;: &quot;available&quot;,\r\n        &quot;plugin_version&quot;: &quot;4.0.8&quot;,\r\n        &quot;siteurl&quot;: null\r\n      },\r\n      {\r\n        &quot;eventType&quot;: &quot;WordpressPlugin&quot;,\r\n        &quot;plugin_name&quot;: &quot;hello&quot;,\r\n        &quot;plugin_status&quot;: &quot;inactive&quot;,\r\n        &quot;plugin_update&quot;: &quot;none&quot;,\r\n        &quot;plugin_version&quot;: &quot;1.7&quot;,\r\n        &quot;siteurl&quot;: null\r\n      },\r\n      {\r\n        &quot;eventType&quot;: &quot;WordpressUser&quot;,\r\n        &quot;siteurl&quot;: null,\r\n        &quot;user_email&quot;: &quot;example.user@email.com&quot;,\r\n        &quot;user_name&quot;: &quot;testuser1&quot;,\r\n        &quot;user_registered&quot;: &quot;2018-11-26 17:44:09&quot;,\r\n        &quot;user_role&quot;: &quot;administrator&quot;\r\n      }\r\n    ]\r\n    [\r\n      {\r\n        &quot;eventType&quot;: &quot;WordpressSite&quot;,\r\n        &quot;siteurl&quot;: &quot;http://mytest2.com&quot;\r\n      },\r\n      {\r\n        &quot;eventType&quot;: &quot;WordpressPlugin&quot;,\r\n        &quot;plugin_name&quot;: &quot;akismet&quot;,\r\n        &quot;plugin_status&quot;: &quot;inactive&quot;,\r\n        &quot;plugin_update&quot;: &quot;available&quot;,\r\n        &quot;plugin_version&quot;: &quot;4.0.8&quot;,\r\n        &quot;siteurl&quot;: null\r\n      },\r\n      {\r\n        &quot;eventType&quot;: &quot;WordpressPlugin&quot;,\r\n        &quot;plugin_name&quot;: &quot;hello&quot;,\r\n        &quot;plugin_status&quot;: &quot;inactive&quot;,\r\n        &quot;plugin_update&quot;: &quot;none&quot;,\r\n        &quot;plugin_version&quot;: &quot;1.7&quot;,\r\n        &quot;siteurl&quot;: null\r\n      },\r\n      {\r\n        &quot;eventType&quot;: &quot;WordpressUser&quot;,\r\n        &quot;siteurl&quot;: null,\r\n        &quot;user_email&quot;: &quot;example.user@email.com&quot;,\r\n        &quot;user_name&quot;: &quot;testuser2&quot;,\r\n        &quot;user_registered&quot;: &quot;2018-11-26 17:44:04&quot;,\r\n        &quot;user_role&quot;: &quot;administrator&quot;\r\n      }\r\n    ]\r\n\r\n\r\n----------\r\n\r\n\r\n    #!/bin/bash\r\n    \r\n    #for d in /var/www/* ; do\r\n    #   echo &quot;$d&quot;\r\n    #done\r\n    \r\n    for f in /var/www/*/public_html/; do\r\n        if [[ -d $f ]]; then\r\n                    #echo &quot;$f&quot;\r\n    \r\n                    cd $f;\r\n                    siteurl=$(wp option get siteurl)\r\n                    users=$(wp user list --fields=display_name,user_email,user_registered,roles --format=json | jq &#39;.[] | .eventType = &quot;WordpressUser&quot;&#39; | jq . --arg siteurl $(wp option get siteurl) | jq &#39;. + {&quot;user_name&quot;: .display_name, &quot;user_role&quot;: .roles, &quot;siteurl&quot;: .&quot;$siteurl&quot;} | del (.display_name, .roles)&#39;)\r\n                    plugins=$(wp plugin list --format=json | jq &#39;.[] | .eventType = &quot;WordpressPlugin&quot;&#39; | jq &#39;. + {&quot;plugin_name&quot;: .name, &quot;plugin_status&quot;: .status, &quot;plugin_version&quot;: .version, &quot;plugin_update&quot;: .update, &quot;siteurl&quot;: .&quot;$siteurl&quot;} | del(.name, .status, .version, .update)&#39;)\r\n    \r\n    \r\n                    {\r\n                    printf &#39;{&quot;eventType&quot;:&quot;WordpressSite&quot;,&quot;siteurl&quot;:&quot;%s&quot;}\\n&#39; &quot;$(wp option get siteurl)&quot;\r\n                    echo &quot;$plugins&quot;\r\n                    echo &quot;$users&quot;\r\n                    } | jq -sS .\r\n                    cd ../..;\r\n        fi\r\n    done\r\n\r\n",
        "link": "https://stackoverflow.com/questions/53638148/add-a-key-value-pair-in-json-object-using-jq-and-bash",
        "title": "Add a Key Value Pair in JSON Object Using JQ and Bash"
    },
    {
        "tags": [
            "json",
            "key",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1544215033,
                "last_edit_date": 1544215033,
                "creation_date": 1544068350,
                "answer_id": 53644390,
                "question_id": 53643808,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is a solution that is based on the uniformity of the format.  \r\n\r\nFirst, let&#39;s define a helper function that handles JSON objects whose values are arrays of objects of the form `{&quot;e&quot;: _}`:\r\n\r\n    def combine:\r\n      keys_unsorted[] as $k\r\n      | $k + (.[$k][]|.e) ;\r\n\r\nNow the solution can be written in just two lines:\r\n \r\n    keys_unsorted[] as $k\r\n    | $k + (.[$k]|combine)\r\n\r\nUsing the -r command-line option will cause the strings to be emitted without enclosing quotation marks.\r\n\r\n## Another strategy\r\n\r\nThe following is not only much more general but also illustrates a different strategy that opens up further generalizations and variants:\r\n\r\n    paths as $p\r\n    | getpath($p) as $v\r\n    | select($v | type == &quot;string&quot;)\r\n    | $p\r\n    | map(select(type==&quot;string&quot;))\r\n    | map(select(. != &quot;e&quot;))\r\n    | . + [$v]\r\n    | join(&quot;&quot;)\r\n\r\n",
                "title": "JQ with nested JSON"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1544215033,
        "creation_date": 1544063965,
        "last_edit_date": 1544068801,
        "question_id": 53643808,
        "body_markdown": "Hello I am new to JQ and command line tools in general so I am really lost with this. I have a JSON file in the form of:\r\n\r\n    {\r\n    \t&quot;Z&quot;: {\r\n    \t\t&quot;00&quot;: [{\r\n    \t\t\t\t&quot;e&quot;: &quot;A000&quot;\r\n    \t\t\t}, {\r\n    \t\t\t\t&quot;e&quot;: &quot;A020&quot;\r\n    \t\t\t}\r\n    \t\t],\r\n    \t\t&quot;01&quot;: [{\r\n    \t\t\t\t&quot;e&quot;: &quot;A102&quot;\r\n    \t\t\t}, {\r\n    \t\t\t\t&quot;e&quot;: &quot;C027&quot;\r\n    \t\t\t}\r\n    \t\t]\r\n    \t},\r\n    \t&quot;X&quot;: {\r\n    \t\t&quot;00&quot;: [{\r\n    \t\t\t\t&quot;e&quot;: &quot;P002&quot;\r\n    \t\t\t}, {\r\n    \t\t\t\t&quot;e&quot;: &quot;T027&quot;\r\n    \t\t\t}\r\n    \t\t],\r\n    \t\t&quot;01&quot;: [{\r\n    \t\t\t\t&quot;e&quot;: &quot;A003&quot;\r\n    \t\t\t}, {\r\n    \t\t\t\t&quot;e&quot;: &quot;A020&quot;\r\n    \t\t\t}\r\n    \t\t]\r\n    \t}\r\n    }\r\n\r\nwhere each object is a seven character alphanumeric code.\r\n\r\nWhat I am looking for is a command to output each code separated by a newline so like this:\r\n\r\n    Z00A000\r\n    Z00A020\r\n    Z01A102\r\n    Z01C027\r\n    X00P002\r\n    X00T027\r\n    X01A003\r\n    X01A020\r\n\r\nThe format of the JSON will always be the same though the names &quot;Z&quot; and &quot;X&quot; and the sub names &quot;00&quot; &quot;01&quot; etc are liable to change so they cannot be hard coded.\r\n\r\nAs already stated I am new to this and the closest I have come is \r\n\r\n    jq &#39;.[] | .[] | .[] | .e&#39;\r\n\r\nwhich gave me a list of the the last four characters of the codes.\r\n\r\nTo be honest I am completely lost so any help would be much appreciated. Thanks for reading.",
        "link": "https://stackoverflow.com/questions/53643808/jq-with-nested-json",
        "title": "JQ with nested JSON"
    },
    {
        "tags": [
            "arrays",
            "json",
            "object",
            "merge",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1544150930,
                "creation_date": 1544150930,
                "answer_id": 53662549,
                "question_id": 53661930,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The invocation:\r\n\r\n    jq -f patch.jq --argfile patch patch.json  orig.json\r\n\r\nwhere patch.jq contains:\r\n\r\n    (.a.list + $patch.a.list) as $a\r\n    | . + $patch\r\n    | .a.list = $a\r\n\r\nproduces:\r\n\r\n    {\r\n      &quot;a&quot;: {\r\n        &quot;a1&quot;: &quot;patch a1&quot;,\r\n        &quot;list&quot;: [\r\n          &quot;baz&quot;,\r\n          &quot;bar&quot;,\r\n          &quot;foo&quot;\r\n        ]\r\n      },\r\n      &quot;b&quot;: &quot;original value B&quot;,\r\n      &quot;c&quot;: &quot;original c&quot;\r\n    }\r\n\r\n",
                "title": "jq: recursively merge objects and concatenate arrays"
            },
            {
                "up_vote_count": 9,
                "is_accepted": false,
                "score": 9,
                "last_activity_date": 1592105219,
                "last_edit_date": 1592105219,
                "creation_date": 1544174614,
                "answer_id": 53666584,
                "question_id": 53661930,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is a generic function that recursively combines two composite JSON entities by concatenating arrays at the same position:\r\n\r\n    # Recursively meld a and b,\r\n    # concatenating arrays and\r\n    # favoring b when there is a conflict \r\n    def meld(a; b):\r\n      a as $a | b as $b\r\n      | if ($a|type) == &quot;object&quot; and ($b|type) == &quot;object&quot;\r\n        then reduce ([$a,$b]|add|keys_unsorted[]) as $k ({}; \r\n          .[$k] = meld( $a[$k]; $b[$k]) )\r\n        elif ($a|type) == &quot;array&quot; and ($b|type) == &quot;array&quot;\r\n        then $a+$b\r\n        elif $b == null then $a\r\n        else $b\r\n        end;\r\n\r\n## Output of meld($orig; $patch)\r\n\r\nWith $orig set to the contents of orig.json and\r\n$patch set to the contents of patch.json:\r\n\r\n    {\r\n      &quot;a&quot;: {\r\n        &quot;a1&quot;: &quot;patch a1&quot;,\r\n        &quot;a2&quot;: &quot;original a2&quot;,\r\n        &quot;list&quot;: [\r\n          &quot;baz&quot;,\r\n          &quot;bar&quot;,\r\n          &quot;foo&quot;\r\n        ]\r\n      },\r\n      &quot;b&quot;: &quot;original value B&quot;,\r\n      &quot;c&quot;: &quot;original c&quot;\r\n    }\r\n\r\n\r\n\r\n ",
                "title": "jq: recursively merge objects and concatenate arrays"
            },
            {
                "up_vote_count": 9,
                "is_accepted": false,
                "score": 9,
                "last_activity_date": 1626177899,
                "creation_date": 1626177899,
                "answer_id": 68362041,
                "question_id": 53661930,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```shell\r\n$ jq -s &#39;def deepmerge(a;b):\r\n  reduce b[] as $item (a;\r\n    reduce ($item | keys_unsorted[]) as $key (.;\r\n      $item[$key] as $val | ($val | type) as $type | .[$key] = if ($type == &quot;object&quot;) then\r\n        deepmerge({}; [if .[$key] == null then {} else .[$key] end, $val])\r\n      elif ($type == &quot;array&quot;) then\r\n        (.[$key] + $val | unique)\r\n      else\r\n        $val\r\n      end)\r\n    );\r\n  deepmerge({}; .)&#39; file1.json file2.json &gt; merged.json\r\n```\r\n",
                "title": "jq: recursively merge objects and concatenate arrays"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 11,
        "last_activity_date": 1695593058,
        "creation_date": 1544145216,
        "last_edit_date": 1544179611,
        "question_id": 53661930,
        "body_markdown": "I have two json files, orig.json and patch.json, which have similar formats.\r\n\r\norig.json:\r\n\r\n    {\r\n            &quot;a&quot;: {\r\n                    &quot;a1&quot;: &quot;original a1&quot;,\r\n                    &quot;a2&quot;: &quot;original a2&quot;,\r\n                    &quot;list&quot;: [&quot;baz&quot;, &quot;bar&quot;]\r\n            },\r\n            &quot;b&quot;: &quot;original value B&quot;\r\n    }\r\n\r\npatch.json:\r\n\r\n    {\r\n        &quot;a&quot;: {\r\n                &quot;a1&quot;: &quot;patch a1&quot;,\r\n                &quot;list&quot;: [&quot;foo&quot;]\r\n        },\r\n        &quot;c&quot;: &quot;original c&quot;\r\n    }\r\n\r\nCurrently I am using `jq` to merge them recursively. However, jq&#39;s default behavior for lists is just reassignment. Example output from jq using `$ jq -s &#39;.[0] * .[1]&#39; orig.json patch.json`:\r\n\r\n    {\r\n      &quot;a&quot;: {\r\n        &quot;a1&quot;: &quot;patch a1&quot;,\r\n        &quot;a2&quot;: &quot;original a2&quot;,\r\n        &quot;list&quot;: [\r\n          &quot;foo&quot;\r\n        ]\r\n      },\r\n      &quot;b&quot;: &quot;original value B&quot;,\r\n      &quot;c&quot;: &quot;original c&quot;\r\n    }\r\n\r\nNote that `a.list` is now equal to patch.json&#39;s `a.list`. I want The new `a.list` to be orig.json&#39;s list and patch.json&#39;s lists merged. In other words, I want `a.list` to equal `[&quot;baz&quot;, &quot;bar&quot;, &quot;foo&quot;]`.\r\n\r\nIs there a way I can easily do this with jq, perhaps by overriding the default merge strategy for arrays?\r\n",
        "link": "https://stackoverflow.com/questions/53661930/jq-recursively-merge-objects-and-concatenate-arrays",
        "title": "jq: recursively merge objects and concatenate arrays"
    },
    {
        "tags": [
            "shell",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 36,
                "is_accepted": true,
                "score": 34,
                "last_activity_date": 1544190283,
                "creation_date": 1544190283,
                "answer_id": 53670832,
                "question_id": 53670702,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You have some extra quotes in there and `test1` needs to be `[&quot;test1&quot;]`\r\n\r\n`jq &quot;.environments.${Environment_Name} += [\\&quot;test1\\&quot;]&quot; tmp.json`",
                "title": "jq: error: test1/0 is not defined at &lt;top-level&gt;, line 1"
            },
            {
                "up_vote_count": 22,
                "is_accepted": false,
                "score": 21,
                "last_activity_date": 1591828645,
                "last_edit_date": 1591828645,
                "creation_date": 1544202852,
                "answer_id": 53674099,
                "question_id": 53670702,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using shell-based variable interpolation is usually a very bad idea. In the present case, what if the shell variable contains a double-quotation mark, for example?  \r\n\r\nThe safe thing to do is to use `env` or `--arg` or `--argjson` as appropriate, e.g.\r\n\r\n    jq --arg e &quot;${Environment_Name}&quot; &#39;.environments[$e] += [&quot;test1&quot;]&#39;",
                "title": "jq: error: test1/0 is not defined at &lt;top-level&gt;, line 1"
            },
            {
                "up_vote_count": 5,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1695741388,
                "creation_date": 1695741388,
                "answer_id": 77181330,
                "question_id": 53670702,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "when I am using jq to check the validity of a json file I use it like this: `cat myfile.json | jq`.",
                "title": "jq: error: test1/0 is not defined at &lt;top-level&gt;, line 1"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 43,
        "last_activity_date": 1695741388,
        "creation_date": 1544189798,
        "question_id": 53670702,
        "body_markdown": "I have below JSON file and facing error when trying to add values to array dynamically in the shell.\r\n\r\nBelow is a tmp.json file,\r\n\r\n    {\r\n      &quot;environments&quot;: {\r\n        &quot;integration&quot;: [\r\n          &quot;testing for jenkins job&quot;\r\n        ],\r\n        &quot;prod&quot;: [],\r\n        &quot;staging&quot;: [],\r\n        &quot;uat&quot;: []\r\n      }\r\n    }\r\n\r\nWhen I try to append values to an array with a static variable, it works fine.\r\nBelow is the command,\r\njq &#39;.environments.integration += [&quot;test1&quot;]&#39; tmp.json\r\n\r\nThe respective output is,\r\n\r\n    {\r\n      &quot;environments&quot;: {\r\n        &quot;appbuild&quot;: [],\r\n        &quot;integration&quot;: [\r\n          &quot;testing for jenkins job&quot;,\r\n          &quot;test1&quot;\r\n        ],\r\n        &quot;prod&quot;: [],\r\n        &quot;staging&quot;: [],\r\n        &quot;uat&quot;: []\r\n      }\r\n     }\r\n\r\nWhereas when I try to append values dynamically, it throws an error.\r\n\r\n    export Environment_Name=&quot;integration&quot;\r\n    jq &quot;.environments.&quot;\\&quot;${Environment_Name}&quot;\\&quot; += test1&quot; tmp.json\r\n\r\nError I am getting is,\r\n\r\n    jq: error: test1/0 is not defined at &lt;top-level&gt;, line 1:\r\n    .environments.&quot;integration&quot; += test1\r\n    jq: 1 compile error\r\n\r\nCan anyone please help to fix this.",
        "link": "https://stackoverflow.com/questions/53670702/jq-error-test1-0-is-not-defined-at-top-level-line-1",
        "title": "jq: error: test1/0 is not defined at &lt;top-level&gt;, line 1"
    },
    {
        "tags": [
            "json",
            "csv",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1002989,
                    "reputation": 1385,
                    "user_id": 1017466,
                    "user_type": "registered",
                    "accept_rate": 50,
                    "profile_image": "https://www.gravatar.com/avatar/73d62289ed695b520ad2a3ae80c45277?s=256&d=identicon&r=PG",
                    "display_name": "bluethundr",
                    "link": "https://stackoverflow.com/users/1017466/bluethundr"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1544219897,
                "post_id": 53677054,
                "comment_id": 94212592,
                "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": 1544219901,
                "post_id": 53677054,
                "comment_id": 94212595,
                "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": 1544219917,
                "post_id": 53677054,
                "comment_id": 94212600,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1002989,
                    "reputation": 1385,
                    "user_id": 1017466,
                    "user_type": "registered",
                    "accept_rate": 50,
                    "profile_image": "https://www.gravatar.com/avatar/73d62289ed695b520ad2a3ae80c45277?s=256&d=identicon&r=PG",
                    "display_name": "bluethundr",
                    "link": "https://stackoverflow.com/users/1017466/bluethundr"
                },
                "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": 1544219985,
                "post_id": 53677054,
                "comment_id": 94212628,
                "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": 1544220002,
                "post_id": 53677054,
                "comment_id": 94212633,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1002989,
                    "reputation": 1385,
                    "user_id": 1017466,
                    "user_type": "registered",
                    "accept_rate": 50,
                    "profile_image": "https://www.gravatar.com/avatar/73d62289ed695b520ad2a3ae80c45277?s=256&d=identicon&r=PG",
                    "display_name": "bluethundr",
                    "link": "https://stackoverflow.com/users/1017466/bluethundr"
                },
                "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": 1544220145,
                "post_id": 53677054,
                "comment_id": 94212685,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1544227419,
                "last_edit_date": 1544227419,
                "creation_date": 1544219802,
                "answer_id": 53677287,
                "question_id": 53677054,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Don&#39;t use `sed` to remove quotes. The quotes are not just *important*, they&#39;re **critical**.\r\n\r\nConsider the following example:\r\n\r\n    jq -Rnr &#39;[inputs] | @csv&#39; &lt;&lt;EOF\r\n    first item\r\n    second item,has,commas\r\n    third item\r\n    EOF\r\n\r\nThat code emits a single line, **which is in fact a valid 3-cell CSV**:\r\n\r\n    &quot;first item&quot;,&quot;second item,has,commas&quot;,&quot;third item&quot;\r\n\r\nSee how the commas that are data are inside quotes, whereas the commas that are syntax are outside them? This is a critical element of CSV syntax.\r\n\r\n---\r\n\r\nIt&#39;s only when you get rid of the quotes protecting those commas that you end up with:\r\n\r\n    first item,second item,has,commas,third item\r\n\r\n...where the data is parsed as 5 cells instead of 3.\r\n\r\n---\r\n\r\nTo actually ensure that your IP addresses are passed to `@csv` as a single field, you may want to join them ahead-of-time; that might be something like:\r\n\r\n    jq -r &#39;\r\n      .Reservations[].Instances[]\r\n      | [ .InstanceId,\r\n          ([.NetworkInterfaces[].PrivateIpAddresses[].Association.PublicIp // null\r\n           ] | join(&quot;,&quot;))\r\n        ] | @csv&#39;\r\n\r\nThis still has commas between the IPs, but those commas will be **inside quotes**, and thus treated as data within a field -- rather than a split between two fields -- by a compliant parser.",
                "title": "JQ Array Overflows CSV Column"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1544228882,
        "creation_date": 1544218408,
        "last_edit_date": 1544228882,
        "question_id": 53677054,
        "body_markdown": "I need to pull a list of AWS instances with their instance ID and public IP, and outputting that to a spread sheet in csv format. \r\n\r\n\r\nHere is the [ORIGINAL JSON][1] I am working with (external IP info has been obscured).\r\n\r\nThis is the command I&#39;m using:\r\n\r\n    aws ec2 describe-instances --profile=&quot;$aws_account&quot;  | jq -r &#39;.Reservations[].Instances[] | [ .InstanceId,  .NetworkInterfaces[].PrivateIpAddresses[].Association.PublicIp // null] | @csv&#39;\r\n\r\nThis works! But a problem happens if there is more than one public IP.\r\n\r\nWith one public ip the output looks good:\r\n\r\n    AWS Instance ID    | Public IP\r\n    i-0e636f1d0f0009f78,18.xxx.xx.112\r\n\r\nWith more than one public IP the output overflows the columns in the CSV spread sheeet:\r\n\r\n       AWS Instance ID | Public IP\t   |Key Name\tOwner\t  Instance State\r\n     \r\n       i-9a02a66b      ,54.xx.xx.201,52.x.xxxx.160,52.x.xx.175,34.xx.xx.31\r\n\r\nI would like to know how to use the JQ command to replace the commas with spaces (so csv can fit them in the same column) and also replace null values with a space (for aws instances with no public IP).\r\n\r\nI am leaving out the code that creates the extra columns so we can focus on the public IPs which is the biggest problem.\r\n\r\n\r\n  [1]: https://pastebin.com/SiNbVgkq",
        "link": "https://stackoverflow.com/questions/53677054/jq-array-overflows-csv-column",
        "title": "JQ Array Overflows CSV Column"
    },
    {
        "tags": [
            "json",
            "parsing",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1544289437,
                "creation_date": 1544289437,
                "answer_id": 53684979,
                "question_id": 53684343,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "There is a slight mismatch between the given JSON input, the stated requirements, and the expected output, so I will focus on the requirements and the given input.\r\n\r\n## (1)\r\n\r\n    .[]\r\n    | .cipher |= gsub(&quot; *(?&lt;x&gt;[A-Za-z]+)=(?&lt;y&gt;[^ ]+)&quot;; &quot;,&quot; + .y)\r\n    | .cipher |= (split(&quot; |,&quot;) | join(&quot;,&quot;))\r\n    | &quot;\\(.host),\\(.ip),\\(.cipher)&quot;\r\n\r\n\r\nproduces\r\n\r\n    xys.com,0.20.0.4,ECDHE-RSA-AES128-GCM-SHA256 TLSv1.2,ECDH,RSA,AESGCM(128),AEAD\r\n\r\n\r\n## (2)\r\n\r\n    .[]\r\n    | .cipher |= (split(&quot; &quot;)[0])\r\n    | &quot;\\(.host),\\(.ip),\\(.cipher)&quot;\r\n\r\nproduces\r\n\r\n    xys.com,0.20.0.4,ECDHE-RSA-AES128-GCM-SHA256\r\n\r\n",
                "title": "How to extract part of a string value in json object using jq parser"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1544289437,
        "creation_date": 1544285201,
        "last_edit_date": 1544286188,
        "question_id": 53684343,
        "body_markdown": "I have a json file which contains an array of objects. I need to extract them into a comma separated file. However, there is one of the values (cipher) that has multiple values separated by spaces. I need to extract (parse) them into two formats: \r\n1) Each value separated by comma. \r\n\r\n2) Only the first value before the first space. \r\n\r\nMy json file contains:\r\n\r\n    [{ &quot;host&quot;: &quot;xys.com&quot;, &quot;ip&quot;: &quot;0.20.0.4&quot;, &quot;port&quot;: 222, &quot;cipher&quot;: &quot;ECDHE-RSA-AES128-GCM-SHA256 TLSv1.2 Kx=ECDH     Au=RSA  Enc=AESGCM(128) Mac=AEAD&quot;}]\r\n\r\nI use this jq command:\r\n\r\n    cat test.json | jq -r &#39;.[] | &quot;\\(.host),\\(.ip),\\(.cipher)&quot;&#39; &gt; test_parsing.txt\r\n\r\nWhich gives me:\r\n\r\n    xys.com,0.20.0.4,TLSv1.2,ECDHE-RSA-AES128-GCM-SHA256 TLSv1.2 Kx=ECDH     Au=RSA  Enc=AESGCM(128) Mac=AEAD\r\n\r\nWhat I want is two formts: \r\n\r\n1) Separate the cipher values by commas and if there is an `=` sign, take what comes after it: \r\n\r\n    xys.com,0.20.0.4,TLSv1.2,ECDHE-RSA-AES128-GCM-SHA256,TLSv1.2,ECDH,RSA,AESGCM(128),AEAD\r\n\r\n2) Extract just the first part of the `cipher` value which is:\r\n\r\n    xys.com,0.20.0.4,TLSv1.2,ECDHE-RSA-AES128-GCM-SHA256\r\n\r\nHow can I extract the two formats from mu `json` file?",
        "link": "https://stackoverflow.com/questions/53684343/how-to-extract-part-of-a-string-value-in-json-object-using-jq-parser",
        "title": "How to extract part of a string value in json object using jq parser"
    },
    {
        "tags": [
            "json",
            "bash",
            "shell",
            "parsing",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1544350912,
                "post_id": 53691243,
                "comment_id": 94238571,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": -2,
                "last_activity_date": 1544353803,
                "creation_date": 1544353803,
                "answer_id": 53691680,
                "question_id": 53691243,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I had to use single-quotes. not double quotes. and no need to named parameters.\r\n\r\n    for k in $(jq -c &#39;.[]&#39; &lt;&lt;&lt; &quot;$data1&quot;); do\r\n     \tcurrent_region=$(jq &#39;.region&#39; &lt;&lt;&lt; $k)\r\n        matching_obj=$(jq -c &#39;.[] | select(.region==&#39;$current_region&#39;)&#39; &lt;&lt;&lt; &quot;$data2&quot;)\r\n\t    echo &quot;matching_obj is $matching_obj&quot;\r\n\t    echo &quot;current region is $current_region&quot; \r\n    done",
                "title": "using jq select operation on json arrays"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1546898637,
        "creation_date": 1544350193,
        "question_id": 53691243,
        "body_markdown": "I have 2 json arrays: data1 and data2. \r\nI&#39;m trying to merge the 2 json arrays into one json, using jq.\r\nfor this: I&#39;m fetching the shared property &quot;region&quot; from the data1, and trying to find the matching one in data2.\r\nYet, jq&#39;s select fails to work with the parameter I pass, but it does work with any specific value.\r\n\r\n    data1=&#39;[ \r\n     {&quot;domain&quot;: &quot;domain1&quot;, &quot;region&quot;: &quot;region1&quot;}, {&quot;domain&quot;: &quot;domain2&quot;,&quot;region&quot;: &quot;region2&quot;}, { &quot;domain&quot;: &quot;domain3&quot;, &quot;region&quot;: &quot;region3&quot;} ]&#39;\r\n\r\n    data2=&#39;[ \r\n     {&quot;region&quot;: &quot;eustaging1&quot;, &quot;secret&quot;: &quot;s1&quot;}, {&quot;region&quot;: &quot;eustaging2&quot;, &quot;secret&quot;: &quot;s2&quot;}, { &quot;region&quot;: &quot;eustaging2&quot;, &quot;secret&quot;: &quot;s3&quot;}]&#39;\r\n\r\n    for k in $(jq -c &#39;.[]&#39; &lt;&lt;&lt; &quot;$data1&quot;); do\r\n    \tcrgn=$(jq &#39;.region&#39; &lt;&lt;&lt; $k)\r\n        # select with parameter not working :(\r\n        matching_obj=$(jq -c  &#39;.[] | select(.region==&quot;$crgn&quot;) &#39; &lt;&lt;&lt; &quot;$data2&quot;)\r\n\t    echo &quot;current region is $crgn&quot; \r\n        echo &quot;matching object is $matching_obj&quot;\r\n    done\r\n\r\n\r\n\r\n\r\n\r\noutput:\r\n\r\n     current region is &quot;region1&quot;\r\n     matching object is\r\n     current region is &quot;region2&quot;\r\n     matching object is\r\n     current region is &quot;region3&quot;\r\n     matching object is",
        "link": "https://stackoverflow.com/questions/53691243/using-jq-select-operation-on-json-arrays",
        "title": "using jq select operation on json arrays"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1544520195,
                "last_edit_date": 1544520195,
                "creation_date": 1544459474,
                "answer_id": 53709796,
                "question_id": 53709718,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Also [string interpolation][1] could be used, in combination with `join`:\r\n\r\n    jq -r &#39;map(&quot;\\(.min)-\\(.max)&quot;) | join(&quot;,&quot;)&#39; file.json\r\n\r\nThanks to [peak][1] for the idea.\r\n\r\n\r\n  [1]: https://stackoverflow.com/questions/53709718/jq-merge-json-array-elements/53710139?noredirect=1#comment94275693_53710139",
                "title": "jq merge json array elements"
            },
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1544460679,
                "creation_date": 1544460679,
                "answer_id": 53710139,
                "question_id": 53709718,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "    jq -r &#39;map([.min, .max|tostring] | join(&quot;-&quot;)) | join(&quot;,&quot;)&#39; input.json\r\n    1-2,5-6\r\n\r\nIf you have a sufficiently recent version of jq, you can drop the call to `tostring`.\r\n\r\nIf the min/max elements are always in that order and if there are no other keys, you might like to consider:\r\n\r\n    map([.[]] | join(&quot;-&quot;)) | join(&quot;,&quot;)",
                "title": "jq merge json array elements"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 3,
        "last_activity_date": 1544520195,
        "creation_date": 1544459236,
        "question_id": 53709718,
        "body_markdown": "I have my data in the following json array:\r\n\r\n    [{ &quot;min&quot;: 1, &quot;max&quot;: 2},\r\n     { &quot;min&quot;: 5, &quot;max&quot;: 6}]\r\n\r\n\r\n\r\nand I would need to have it in the format:\r\n\r\n    1-2,5-6\r\n\r\nI have tried the following filter:\r\n\r\n    .[] | [ .min, .max|tostring ] | join(&quot;-&quot;)\r\n\r\nand I ended up having:\r\n\r\n    &quot;1-2&quot;\r\n    &quot;5-6&quot;\r\n\r\nI do not know how to get from that to expression to the desired &quot;1-2&quot;,&quot;5-6&quot;.\r\nI am new to jq and would appreciate any hints.\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/53709718/jq-merge-json-array-elements",
        "title": "jq merge json array elements"
    },
    {
        "tags": [
            "json",
            "merge",
            "edit",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 7750510,
                    "reputation": 134447,
                    "user_id": 5866580,
                    "user_type": "registered",
                    "accept_rate": 25,
                    "profile_image": "https://www.gravatar.com/avatar/f69cec226400d61f887446d813471488?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "RavinderSingh13",
                    "link": "https://stackoverflow.com/users/5866580/ravindersingh13"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1544522371,
                "post_id": 53721334,
                "comment_id": 94296727,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 14467919,
                    "reputation": 453,
                    "user_id": 10450762,
                    "user_type": "registered",
                    "profile_image": "https://lh5.googleusercontent.com/-nL_w38eWmuc/AAAAAAAAAAI/AAAAAAAAAAA/AAN31DXwL63goRuWJI4yR4oTUkEPb8IY4g/mo/s256-rj/photo.jpg",
                    "display_name": "wkde",
                    "link": "https://stackoverflow.com/users/10450762/wkde"
                },
                "reply_to_user": {
                    "account_id": 7750510,
                    "reputation": 134447,
                    "user_id": 5866580,
                    "user_type": "registered",
                    "accept_rate": 25,
                    "profile_image": "https://www.gravatar.com/avatar/f69cec226400d61f887446d813471488?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "RavinderSingh13",
                    "link": "https://stackoverflow.com/users/5866580/ravindersingh13"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1544522677,
                "post_id": 53721334,
                "comment_id": 94296927,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 7750510,
                    "reputation": 134447,
                    "user_id": 5866580,
                    "user_type": "registered",
                    "accept_rate": 25,
                    "profile_image": "https://www.gravatar.com/avatar/f69cec226400d61f887446d813471488?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "RavinderSingh13",
                    "link": "https://stackoverflow.com/users/5866580/ravindersingh13"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1544522751,
                "post_id": 53721334,
                "comment_id": 94296980,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 14467919,
                    "reputation": 453,
                    "user_id": 10450762,
                    "user_type": "registered",
                    "profile_image": "https://lh5.googleusercontent.com/-nL_w38eWmuc/AAAAAAAAAAI/AAAAAAAAAAA/AAN31DXwL63goRuWJI4yR4oTUkEPb8IY4g/mo/s256-rj/photo.jpg",
                    "display_name": "wkde",
                    "link": "https://stackoverflow.com/users/10450762/wkde"
                },
                "reply_to_user": {
                    "account_id": 7750510,
                    "reputation": 134447,
                    "user_id": 5866580,
                    "user_type": "registered",
                    "accept_rate": 25,
                    "profile_image": "https://www.gravatar.com/avatar/f69cec226400d61f887446d813471488?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "RavinderSingh13",
                    "link": "https://stackoverflow.com/users/5866580/ravindersingh13"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1544523739,
                "post_id": 53721334,
                "comment_id": 94297527,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1544543743,
                "last_edit_date": 1544543743,
                "creation_date": 1544526285,
                "answer_id": 53722766,
                "question_id": 53721334,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Better use [tag:jq] to manipulate JSON data.\r\n\r\nIn the code below I used `reduce` because `with_entries` doesn&#39;t work with arrays.\r\n\r\n    jq &#39;.species |= (\r\n            to_entries | map(.value.nStrains = $repl[.key]) |\r\n            reduce .[] as $item ([]; .[$item.key] = $item.value)\r\n        )&#39; --argfile repl a2 config\r\nSee `man jq` for further information.",
                "title": "how to replace numbers in a JSON document with corresponding values in a text file"
            },
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1544536269,
                "last_edit_date": 1544536269,
                "creation_date": 1544533180,
                "answer_id": 53724727,
                "question_id": 53721334,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is a reduce-less solution. Note that the -n option is needed because `inputs` is used.  The -R option is used mainly because the requirements implicitly specify that the replacement values should be strings, but also for robustness:\r\n\r\n###  Invocation:\r\n\r\n    jq -Rn --argfile config config.json -f update.jq a2\r\n\r\n### update.jq\r\n\r\n    [inputs] as $dict\r\n    | $config\r\n    | .species |= [to_entries[] | (.value.nStrains = $dict[.key]) | .value]\r\n\r\n",
                "title": "how to replace numbers in a JSON document with corresponding values in a text file"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1544962990,
        "creation_date": 1544521520,
        "last_edit_date": 1544962990,
        "question_id": 53721334,
        "body_markdown": "I have a `config` file that looks like this :\r\n\r\n    {\r\n        &quot;reads&quot;: {\r\n            &quot;no_Reads&quot;: 5000000,\r\n        \r\n            &quot;length&quot;: 150,\r\n             \r\n            &quot;insert_length&quot;: 300,\r\n            \r\n            &quot;insert_sd&quot;: 10\r\n        },\r\n        \r\n        &quot;no_Samples&quot; : 20,\r\n         \r\n        &quot;species_dist_Params&quot;: {\r\n            &quot;mean_log_Mean&quot;: 1.0,\r\n        \r\n            &quot;sd_log_Mean&quot;: 0.25,\r\n        \r\n            &quot;k_log_Sd&quot;: 1.0,\r\n        \r\n            &quot;theta_log_Sd&quot;: 1.0,\r\n            \r\n            &quot;beta&quot;: 1.0,\r\n            \r\n            &quot;alpha&quot;: 1.0\r\n        },\r\n        \r\n        &quot;no_Species&quot; : 100,\r\n    \r\n        &quot;species&quot;: [\r\n            {\r\n                &quot;dir&quot;: &quot;Strain_35814/&quot;,\r\n                &quot;nStrains&quot;: &quot;4&quot;\r\n            },\r\n            {\r\n                &quot;dir&quot;: &quot;Strain_285/&quot;,\r\n                &quot;nStrains&quot;: &quot;2&quot;\r\n            },\r\n            {\r\n                &quot;dir&quot;: &quot;Strain_438/&quot;,\r\n                &quot;nStrains&quot;: &quot;1&quot;\r\n            },\r\n            {\r\n                &quot;dir&quot;: &quot;Strain_1833/&quot;,\r\n                &quot;nStrains&quot;: &quot;3&quot;\r\n            },\r\n            {\r\n                &quot;dir&quot;: &quot;Strain_782/&quot;,\r\n                &quot;nStrains&quot;: &quot;1&quot;\r\n            },\r\n            {\r\n                &quot;dir&quot;: &quot;Strain_1509/&quot;,\r\n                &quot;nStrains&quot;: &quot;2&quot;\r\n            },\r\n            {\r\n                &quot;dir&quot;: &quot;Strain_2095/&quot;,\r\n                &quot;nStrains&quot;: &quot;2&quot;\r\n            },\r\n            {\r\n                &quot;dir&quot;: &quot;Strain_85698/&quot;,\r\n                &quot;nStrains&quot;: &quot;2&quot;\r\n            },\r\n            {\r\n                &quot;dir&quot;: &quot;Strain_382/&quot;,\r\n                &quot;nStrains&quot;: &quot;2&quot;\r\n            },\r\n            {\r\n                &quot;dir&quot;: &quot;Strain_2096/&quot;,\r\n                &quot;nStrains&quot;: &quot;3&quot;\r\n            },\r\n            {\r\n                &quot;dir&quot;: &quot;Strain_1582/&quot;,\r\n                &quot;nStrains&quot;: &quot;1&quot;\r\n            },\r\n            {\r\n                &quot;dir&quot;: &quot;Strain_1245/&quot;,\r\n                &quot;nStrains&quot;: &quot;1&quot;\r\n            },\r\n            {\r\n                &quot;dir&quot;: &quot;Strain_1452/&quot;,\r\n                &quot;nStrains&quot;: &quot;2&quot;\r\n            },\r\n            {\r\n                &quot;dir&quot;: &quot;Strain_1613/&quot;,\r\n                &quot;nStrains&quot;: &quot;1&quot;\r\n            },\r\n            {\r\n                &quot;dir&quot;: &quot;Strain_43080/&quot;,\r\n                &quot;nStrains&quot;: &quot;1&quot;\r\n            },\r\n            {\r\n                &quot;dir&quot;: &quot;Strain_29519/&quot;,\r\n                &quot;nStrains&quot;: &quot;3&quot;\r\n            },\r\n            {\r\n                &quot;dir&quot;: &quot;Strain_96345/&quot;,\r\n                &quot;nStrains&quot;: &quot;3&quot;\r\n            },\r\n            {\r\n                &quot;dir&quot;: &quot;Strain_777/&quot;,\r\n                &quot;nStrains&quot;: &quot;3&quot;\r\n            },\r\n            {\r\n                &quot;dir&quot;: &quot;Strain_375/&quot;,\r\n                &quot;nStrains&quot;: &quot;1&quot;\r\n            },\r\n            {\r\n                &quot;dir&quot;: &quot;Strain_168695/&quot;,\r\n                &quot;nStrains&quot;: &quot;1&quot;\r\n            },\r\n            {\r\n                &quot;dir&quot;: &quot;Strain_236/&quot;,\r\n                &quot;nStrains&quot;: &quot;1&quot;\r\n            },\r\n            {\r\n                &quot;dir&quot;: &quot;Strain_358/&quot;,\r\n                &quot;nStrains&quot;: &quot;1&quot;\r\n            },\r\n            {\r\n                &quot;dir&quot;: &quot;Strain_399/&quot;,\r\n                &quot;nStrains&quot;: &quot;1&quot;\r\n            },\r\n            {\r\n                &quot;dir&quot;: &quot;Strain_109790/&quot;,\r\n                &quot;nStrains&quot;: &quot;1&quot;\r\n            },\r\n            {\r\n                &quot;dir&quot;: &quot;Strain_1718/&quot;,\r\n                &quot;nStrains&quot;: &quot;1&quot;\r\n            },\r\n            {\r\n                &quot;dir&quot;: &quot;Strain_2252/&quot;,\r\n                &quot;nStrains&quot;: &quot;2&quot;\r\n            },\r\n            {\r\n                &quot;dir&quot;: &quot;Strain_729/&quot;,\r\n                &quot;nStrains&quot;: &quot;1&quot;\r\n            },\r\n            {\r\n                &quot;dir&quot;: &quot;Strain_1334/&quot;,\r\n                &quot;nStrains&quot;: &quot;1&quot;\r\n            },\r\n            {\r\n                &quot;dir&quot;: &quot;Strain_1624/&quot;,\r\n                &quot;nStrains&quot;: &quot;1&quot;\r\n            },\r\n            {\r\n                &quot;dir&quot;: &quot;Strain_29484/&quot;,\r\n                &quot;nStrains&quot;: &quot;1&quot;\r\n            },\r\n            {\r\n                &quot;dir&quot;: &quot;Strain_636/&quot;,\r\n                &quot;nStrains&quot;: &quot;1&quot;\r\n            },\r\n            {\r\n                &quot;dir&quot;: &quot;Strain_1408/&quot;,\r\n                &quot;nStrains&quot;: &quot;1&quot;\r\n            },\r\n            {\r\n                &quot;dir&quot;: &quot;Strain_1402/&quot;,\r\n                &quot;nStrains&quot;: &quot;2&quot;\r\n            },\r\n            {\r\n                &quot;dir&quot;: &quot;Strain_2287/&quot;,\r\n                &quot;nStrains&quot;: &quot;1&quot;\r\n            },\r\n            {\r\n                &quot;dir&quot;: &quot;Strain_582/&quot;,\r\n                &quot;nStrains&quot;: &quot;1&quot;\r\n            },\r\n            {\r\n                &quot;dir&quot;: &quot;Strain_57975/&quot;,\r\n                &quot;nStrains&quot;: &quot;1&quot;\r\n            },\r\n            {\r\n                &quot;dir&quot;: &quot;Strain_38323/&quot;,\r\n                &quot;nStrains&quot;: &quot;1&quot;\r\n            },\r\n            {\r\n                &quot;dir&quot;: &quot;Strain_2039/&quot;,\r\n                &quot;nStrains&quot;: &quot;1&quot;\r\n            },\r\n            {\r\n                &quot;dir&quot;: &quot;Strain_486/&quot;,\r\n                &quot;nStrains&quot;: &quot;1&quot;\r\n            },\r\n            {\r\n                &quot;dir&quot;: &quot;Strain_738/&quot;,\r\n                &quot;nStrains&quot;: &quot;1&quot;\r\n            },\r\n    \r\n            {\r\n                &quot;dir&quot;: &quot;Strain_305/&quot;,\r\n                &quot;nStrains&quot;: &quot;4&quot;\r\n            },\r\n            {\r\n                &quot;dir&quot;: &quot;Strain_1580/&quot;,\r\n                &quot;nStrains&quot;: &quot;1&quot;\r\n            },\r\n            {\r\n                &quot;dir&quot;: &quot;Strain_1542/&quot;,\r\n                &quot;nStrains&quot;: &quot;1&quot;\r\n            },\r\n            {\r\n                &quot;dir&quot;: &quot;Strain_553/&quot;,\r\n                &quot;nStrains&quot;: &quot;4&quot;\r\n            },\r\n            {\r\n                &quot;dir&quot;: &quot;Strain_774/&quot;,\r\n                &quot;nStrains&quot;: &quot;4&quot;\r\n            },\r\n            {\r\n                &quot;dir&quot;: &quot;Strain_83560/&quot;,\r\n                &quot;nStrains&quot;: &quot;2&quot;\r\n            },\r\n            {\r\n                &quot;dir&quot;: &quot;Strain_715/&quot;,\r\n                &quot;nStrains&quot;: &quot;3&quot;\r\n            },\r\n            {\r\n                &quot;dir&quot;: &quot;Strain_1502/&quot;,\r\n                &quot;nStrains&quot;: &quot;2&quot;\r\n            },\r\n            {\r\n                &quot;dir&quot;: &quot;Strain_948/&quot;,\r\n                &quot;nStrains&quot;: &quot;4&quot;\r\n            },\r\n            {\r\n                &quot;dir&quot;: &quot;Strain_54291/&quot;,\r\n                &quot;nStrains&quot;: &quot;1&quot;\r\n            },\r\n            {\r\n                &quot;dir&quot;: &quot;Strain_480/&quot;,\r\n                &quot;nStrains&quot;: &quot;3&quot;\r\n            },\r\n    \r\n            {\r\n                &quot;dir&quot;: &quot;Strain_1349/&quot;,\r\n                &quot;nStrains&quot;: &quot;1&quot;\r\n            },\r\n            {\r\n                &quot;dir&quot;: &quot;Strain_83558/&quot;,\r\n                &quot;nStrains&quot;: &quot;3&quot;\r\n            },\r\n            {\r\n                &quot;dir&quot;: &quot;Strain_366648/&quot;,\r\n                &quot;nStrains&quot;: &quot;1&quot;\r\n            },\r\n            {\r\n                &quot;dir&quot;: &quot;Strain_747/&quot;,\r\n                &quot;nStrains&quot;: &quot;1&quot;\r\n            },\r\n            {\r\n                &quot;dir&quot;: &quot;Strain_750/&quot;,\r\n                &quot;nStrains&quot;: &quot;1&quot;\r\n            },\r\n            {\r\n                &quot;dir&quot;: &quot;Strain_837/&quot;,\r\n                &quot;nStrains&quot;: &quot;1&quot;\r\n            },\r\n            {\r\n                &quot;dir&quot;: &quot;Strain_1911/&quot;,\r\n                &quot;nStrains&quot;: &quot;1&quot;\r\n            },\r\n            {\r\n                &quot;dir&quot;: &quot;Strain_1238/&quot;,\r\n                &quot;nStrains&quot;: &quot;1&quot;\r\n            },\r\n            {\r\n                &quot;dir&quot;: &quot;Strain_644/&quot;,\r\n                &quot;nStrains&quot;: &quot;1&quot;\r\n            },\r\n            {\r\n                &quot;dir&quot;: &quot;Strain_196/&quot;,\r\n                &quot;nStrains&quot;: &quot;1&quot;\r\n            },\r\n            {\r\n                &quot;dir&quot;: &quot;Strain_552/&quot;,\r\n                &quot;nStrains&quot;: &quot;2&quot;\r\n            },\r\n            {\r\n                &quot;dir&quot;: &quot;Strain_40576/&quot;,\r\n                &quot;nStrains&quot;: &quot;2&quot;\r\n            },\r\n            {\r\n                &quot;dir&quot;: &quot;Strain_28025/&quot;,\r\n                &quot;nStrains&quot;: &quot;1&quot;\r\n            },\r\n            {\r\n                &quot;dir&quot;: &quot;Strain_43306/&quot;,\r\n                &quot;nStrains&quot;: &quot;1&quot;\r\n            },\r\n            {\r\n                &quot;dir&quot;: &quot;Strain_663/&quot;,\r\n                &quot;nStrains&quot;: &quot;1&quot;\r\n            },\r\n            {\r\n                &quot;dir&quot;: &quot;Strain_29447/&quot;,\r\n                &quot;nStrains&quot;: &quot;5&quot;\r\n            },\r\n            {\r\n                &quot;dir&quot;: &quot;Strain_546/&quot;,\r\n                &quot;nStrains&quot;: &quot;3&quot;\r\n            },\r\n            {\r\n                &quot;dir&quot;: &quot;Strain_48296/&quot;,\r\n                &quot;nStrains&quot;: &quot;1&quot;\r\n            },\r\n            {\r\n                &quot;dir&quot;: &quot;Strain_1308/&quot;,\r\n                &quot;nStrains&quot;: &quot;5&quot;\r\n            },\r\n            {\r\n                &quot;dir&quot;: &quot;Strain_1398/&quot;,\r\n                &quot;nStrains&quot;: &quot;2&quot;\r\n            },\r\n            {\r\n                &quot;dir&quot;: &quot;Strain_1338/&quot;,\r\n                &quot;nStrains&quot;: &quot;1&quot;\r\n            },\r\n            {\r\n                &quot;dir&quot;: &quot;Strain_770/&quot;,\r\n                &quot;nStrains&quot;: &quot;2&quot;\r\n            },\r\n            {\r\n                &quot;dir&quot;: &quot;Strain_9/&quot;,\r\n                &quot;nStrains&quot;: &quot;4&quot;\r\n            },\r\n            {\r\n                &quot;dir&quot;: &quot;Strain_75985/&quot;,\r\n                &quot;nStrains&quot;: &quot;4&quot;\r\n            },\r\n            {\r\n                &quot;dir&quot;: &quot;Strain_1406/&quot;,\r\n                &quot;nStrains&quot;: &quot;4&quot;\r\n            },\r\n            {\r\n                &quot;dir&quot;: &quot;Strain_33970/&quot;,\r\n                &quot;nStrains&quot;: &quot;1&quot;\r\n            },\r\n            {\r\n                &quot;dir&quot;: &quot;Strain_587753/&quot;,\r\n                &quot;nStrains&quot;: &quot;4&quot;\r\n            },\r\n            {\r\n                &quot;dir&quot;: &quot;Strain_39152/&quot;,\r\n                &quot;nStrains&quot;: &quot;5&quot;\r\n    \r\n            },\r\n    \r\n            {\r\n                &quot;dir&quot;: &quot;Strain_2208/&quot;,\r\n                &quot;nStrains&quot;: &quot;5&quot;\r\n            },\r\n    \r\n            {\r\n                &quot;dir&quot;: &quot;Strain_2209/&quot;,\r\n                &quot;nStrains&quot;: &quot;5&quot;\r\n            },\r\n    \r\n            {\r\n                &quot;dir&quot;: &quot;Strain_2162/&quot;,\r\n                &quot;nStrains&quot;: &quot;2&quot;\r\n            },\r\n    \r\n            {\r\n                &quot;dir&quot;: &quot;Strain_43687/&quot;,\r\n                &quot;nStrains&quot;: &quot;1&quot;\r\n            },\r\n    \r\n            {\r\n                &quot;dir&quot;: &quot;Strain_2173/&quot;,\r\n                &quot;nStrains&quot;: &quot;1&quot;\r\n            },\r\n    \r\n            {\r\n                &quot;dir&quot;: &quot;Strain_1219/&quot;,\r\n                &quot;nStrains&quot;: &quot;1&quot;\r\n            },\r\n    \r\n            {\r\n                &quot;dir&quot;: &quot;Strain_28173/&quot;,\r\n                &quot;nStrains&quot;: &quot;2&quot;\r\n            },\r\n    \r\n            {\r\n                &quot;dir&quot;: &quot;Strain_1598/&quot;,\r\n                &quot;nStrains&quot;: &quot;1&quot;\r\n            },\r\n    \r\n            {\r\n                &quot;dir&quot;: &quot;Strain_1358/&quot;,\r\n                &quot;nStrains&quot;: &quot;1&quot;\r\n            },\r\n            {\r\n                &quot;dir&quot;: &quot;Strain_714/&quot;,\r\n                &quot;nStrains&quot;: &quot;4&quot;\r\n            },\r\n            {\r\n                &quot;dir&quot;: &quot;Strain_34085/&quot;,\r\n                &quot;nStrains&quot;: &quot;5&quot;\r\n            },\r\n            {\r\n                &quot;dir&quot;: &quot;Strain_1076/&quot;,\r\n                &quot;nStrains&quot;: &quot;2&quot;\r\n            },\r\n            {\r\n                &quot;dir&quot;: &quot;Strain_1270/&quot;,\r\n                &quot;nStrains&quot;: &quot;2&quot;\r\n            },\r\n            {\r\n                &quot;dir&quot;: &quot;Strain_2371/&quot;,\r\n                &quot;nStrains&quot;: &quot;5&quot;\r\n            },\r\n            {\r\n                &quot;dir&quot;: &quot;Strain_1681/&quot;,\r\n                &quot;nStrains&quot;: &quot;5&quot;\r\n            },\r\n            {\r\n                &quot;dir&quot;: &quot;Strain_28197/&quot;,\r\n                &quot;nStrains&quot;: &quot;3&quot;\r\n            },\r\n            {\r\n                &quot;dir&quot;: &quot;Strain_28108/&quot;,\r\n                &quot;nStrains&quot;: &quot;5&quot;\r\n            },\r\n            {\r\n                &quot;dir&quot;: &quot;Strain_1744/&quot;,\r\n                &quot;nStrains&quot;: &quot;2&quot;\r\n            },\r\n            {\r\n                &quot;dir&quot;: &quot;Strain_300/&quot;,\r\n                &quot;nStrains&quot;: &quot;2&quot;\r\n            },\r\n            {\r\n                &quot;dir&quot;: &quot;Strain_160/&quot;,\r\n                &quot;nStrains&quot;: &quot;5&quot;\r\n            },\r\n            {\r\n                &quot;dir&quot;: &quot;Strain_316/&quot;,\r\n                &quot;nStrains&quot;: &quot;1&quot;\r\n            }\r\n            \r\n        ],\r\n        \r\n        &quot;max_seqs&quot; : 5,\r\n        \r\n        &quot;min_div&quot;  : 0.01,\r\n        \r\n        &quot;max_div&quot;  : 10.0,\r\n        \r\n        &quot;min_scg&quot;  : 35\r\n    }\r\n\r\nI have a file `a2` that looks like this :\r\n\r\n    1\r\n    1\r\n    1\r\n    2\r\n    3\r\n    1\r\n    3\r\n    1\r\n    3\r\n    4\r\n    4\r\n    2\r\n    1\r\n    2\r\n    5\r\n    1\r\n    2\r\n    5\r\n    2\r\n    1\r\n    1\r\n    2\r\n    2\r\n    1\r\n    2\r\n    2\r\n    1\r\n    3\r\n    1\r\n    1\r\n    1\r\n    1\r\n    2\r\n    2\r\n    1\r\n    7\r\n    1\r\n    2\r\n    1\r\n    1\r\n    4\r\n    1\r\n    1\r\n    1\r\n    5\r\n    1\r\n    2\r\n    1\r\n    3\r\n    3\r\n    1\r\n    1\r\n    1\r\n    1\r\n    3\r\n    1\r\n    1\r\n    1\r\n    1\r\n    4\r\n    1\r\n    1\r\n    1\r\n    6\r\n    1\r\n    1\r\n    4\r\n    2\r\n    1\r\n    1\r\n    1\r\n    1\r\n    1\r\n    9\r\n    4\r\n    1\r\n    2\r\n    1\r\n    2\r\n    2\r\n    2\r\n    2\r\n    3\r\n    1\r\n    3\r\n    1\r\n    2\r\n    2\r\n    1\r\n    3\r\n    4\r\n    1\r\n    2\r\n    3\r\n    1\r\n    3\r\n    2\r\n    1\r\n    6\r\n    7\r\nI want to replace the number following `&quot;nStrains&quot;:` with the lines in file `a2`. The desired output is:\r\n        \r\n\r\n    {\r\n                &quot;dir&quot;: &quot;Strain_35814/&quot;,\r\n                &quot;nStrains&quot;: &quot;1&quot;\r\n            },\r\n            {\r\n                &quot;dir&quot;: &quot;Strain_285/&quot;,\r\n                &quot;nStrains&quot;: &quot;1&quot;\r\n            },\r\n            {\r\n                &quot;dir&quot;: &quot;Strain_438/&quot;,\r\n                &quot;nStrains&quot;: &quot;1&quot;\r\n            ...\r\n\r\nI have tried\r\n \r\n    awk &#39;NR==FNR {a[$1];next}/nStrains/{$2=&quot;a&quot;}1&#39; a2 FS=&quot;:&quot; config &gt; config_new\r\n\r\nBut does not seem to work. I think I have done array part wroge. How can I fix it and what is the reason it does not work? Thank you very much. \r\n",
        "link": "https://stackoverflow.com/questions/53721334/how-to-replace-numbers-in-a-json-document-with-corresponding-values-in-a-text-fi",
        "title": "how to replace numbers in a JSON document with corresponding values in a text file"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 15,
                "is_accepted": true,
                "score": 15,
                "last_activity_date": 1544524794,
                "creation_date": 1544524794,
                "answer_id": 53722321,
                "question_id": 53721635,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Filter keys that start with `Test` and get only the attribute of your choice using the `select()` expression\r\n\r\n    jq &#39;to_entries[] | select(.key|startswith(&quot;Task&quot;)).value.attributes.processid&#39; json\r\n",
                "title": "How can i match fields with wildcards using jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 10,
        "last_activity_date": 1544529760,
        "creation_date": 1544522497,
        "last_edit_date": 1544529760,
        "question_id": 53721635,
        "body_markdown": "I have a JSON object of the following form:\r\n    \r\n    {\r\n      &quot;Task11c-0-20181209-12:59:30-65611&quot; : {\r\n        &quot;attributes&quot; : {\r\n          &quot;configname&quot; : &quot;Task11c&quot;,\r\n          &quot;datetime&quot; : &quot;20181209-12:59:30&quot;,\r\n          &quot;experiment&quot; : &quot;Task11c&quot;,\r\n          &quot;inifile&quot; : &quot;lab1.ini&quot;,\r\n          &quot;iterationvars&quot; : &quot;&quot;,\r\n          &quot;iterationvarsf&quot; : &quot;&quot;,\r\n          &quot;measurement&quot; : &quot;&quot;,\r\n          &quot;network&quot; : &quot;Manhattan1_1C&quot;,\r\n          &quot;processid&quot; : &quot;65611&quot;,\r\n          &quot;repetition&quot; : &quot;0&quot;,\r\n          &quot;replication&quot; : &quot;#0&quot;,\r\n          &quot;resultdir&quot; : &quot;results&quot;,\r\n          &quot;runnumber&quot; : &quot;0&quot;,\r\n          &quot;seedset&quot; : &quot;0&quot;\r\n        },\r\n        ......\r\n      },\r\n      ......\r\n      &quot;Task11b-12-20181209-13:03:17-65612&quot; : {\r\n        ....\r\n        .... \r\n      },\r\n      .......\r\n    }\r\n\r\nI reported only the first part, but in general I have many other sub-objects which match a string like `Task11c-0-20181209-12:59:30-65611`. They all have in common the initial word `Task`. I want to extract the `processid` from each sub-object. I&#39;m trying to use a wildcard like in bash, but it seems not to be possible.\r\n\r\nI also read about the [match()][1] function, but it works with strings and not json objects.\r\n\r\nThanks for the support.\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/#Builtinoperatorsandfunctions",
        "link": "https://stackoverflow.com/questions/53721635/how-can-i-match-fields-with-wildcards-using-jq",
        "title": "How can i match fields with wildcards using jq?"
    },
    {
        "tags": [
            "json",
            "shell",
            "jq",
            "fifo"
        ],
        "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": 1544565417,
                "post_id": 53732698,
                "comment_id": 94319731,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1143565,
                    "reputation": 535973,
                    "user_id": 1126841,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa05233b2357f8d11c22ef4cfc7bb85c?s=256&d=identicon&r=PG",
                    "display_name": "chepner",
                    "link": "https://stackoverflow.com/users/1126841/chepner"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1544565472,
                "post_id": 53732698,
                "comment_id": 94319753,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1544565516,
                "post_id": 53732698,
                "comment_id": 94319765,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1544595297,
                "post_id": 53732698,
                "comment_id": 94327009,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4616979,
                    "reputation": 8319,
                    "user_id": 3743145,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/680680d82143e4d33dc569913e5ef8c5?s=256&d=identicon&r=PG",
                    "display_name": "kyb",
                    "link": "https://stackoverflow.com/users/3743145/kyb"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1544614610,
                "post_id": 53732698,
                "comment_id": 94336847,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4616979,
                    "reputation": 8319,
                    "user_id": 3743145,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/680680d82143e4d33dc569913e5ef8c5?s=256&d=identicon&r=PG",
                    "display_name": "kyb",
                    "link": "https://stackoverflow.com/users/3743145/kyb"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1544614632,
                "post_id": 53732698,
                "comment_id": 94336867,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 173557,
                    "reputation": 24077,
                    "user_id": 402322,
                    "user_type": "registered",
                    "accept_rate": 67,
                    "profile_image": "https://i.sstatic.net/GWEWt.gif?s=256",
                    "display_name": "ceving",
                    "link": "https://stackoverflow.com/users/402322/ceving"
                },
                "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": 1624556468,
                "post_id": 53732698,
                "comment_id": 120398033,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1143565,
                    "reputation": 535973,
                    "user_id": 1126841,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa05233b2357f8d11c22ef4cfc7bb85c?s=256&d=identicon&r=PG",
                    "display_name": "chepner",
                    "link": "https://stackoverflow.com/users/1126841/chepner"
                },
                "reply_to_user": {
                    "account_id": 173557,
                    "reputation": 24077,
                    "user_id": 402322,
                    "user_type": "registered",
                    "accept_rate": 67,
                    "profile_image": "https://i.sstatic.net/GWEWt.gif?s=256",
                    "display_name": "ceving",
                    "link": "https://stackoverflow.com/users/402322/ceving"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1624557219,
                "post_id": 53732698,
                "comment_id": 120398286,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1608177675,
                "last_edit_date": 1608177675,
                "creation_date": 1608064878,
                "answer_id": 65313363,
                "question_id": 53732698,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`jq` doesn&#39;t have to read to the whole input to get the first value. This can be verified by feeding an infinite sequence of values to jq which takes the first value and exit:\r\n\r\n    yes &#39;{}&#39; | jq -n input\r\n\r\n\r\nThough, the question assumes a bit more. Namely that `jq` can read a single JSON value from a named pipe and stop reading _&quot;right at that point&quot;_ so the rest can be then read by `cat`.\r\n\r\n    mkfifo xxs\r\n    exec 3&lt;&gt;xxs              ## keep open file descriptor\r\n    echo &#39;1 2 3&#39; &gt;&amp;3\r\n    jq -nc input &lt;&amp;3 &gt;first  ## Get first value\r\n    cat &lt;&amp;3 &gt;rest            ## Nothing to show jq read all data\r\n\r\nThis gets more complicated as we don&#39;t know where that first value ends and most Unix programs (jq included) read input in larger chunks to limit the number of read syscalls.\r\n\r\n`jq` would need an option to read its input one byte at a time. And, while this could be implemented, it may be of limited utility.\r\n\r\nThe closest thing I can think of is to output the first value to \r\n`stderr` and the rest to `stdout`.\r\n\r\n    jq -n &#39;input | stderr | inputs&#39; &lt;&amp;3 2&gt;first 1&gt;rest\r\n\r\nInput is processed in a streaming fashion (one input value at a time) and you can pipe `stdout` and/or `stderr` to something else. Though the whole input has to be valid JSON and it will be prettified while passing through `jq` (unlike with cat above).\r\n\r\n---\r\n\r\nIf reading from a named pipe is not a requirement and you can afford to read the input from a file. Then, you can access the first value and the rest in two separate invocations.\r\n\r\n```\r\necho &#39;1 2 3&#39; &gt; in\r\njq -n &#39;input&#39; in &gt;first\r\njq -n &#39;input | inputs&#39; in &gt;rest\r\n```\r\n\r\nIf stream processing is the goal, it may also be possible to do everything in a single `jq` script that processes its input incrementally.\r\n\r\nThis all assumes top-level values. Though, `jq` can also process nested structures incrementally using the `--stream` option.",
                "title": "Take only first json object from stream with jq, do not touch rest"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1627806390,
                "creation_date": 1627806390,
                "answer_id": 68608692,
                "question_id": 53732698,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "\r\n\r\nIf you want to partially read a stream you will probably need to do it yourself.\r\nYou could write a trivial C program to do this.\r\nI doubt there are any off-the-shelf parsers you can find to specify stopping the read of a stream after n objects.\r\nAs mentioned before, most stream readers will use stdio and read all they can into a buffer.\r\n",
                "title": "Take only first json object from stream with jq, do not touch rest"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 4,
        "last_activity_date": 1627806390,
        "creation_date": 1544564230,
        "last_edit_date": 1544564558,
        "question_id": 53732698,
        "body_markdown": "This thread https://stackoverflow.com/questions/53496484/split-multiple-input-jsons-with-jq helped me to solve one problem. But not other.\r\n\r\n    mkfifo xxs\r\n    exec 3&lt;&gt;xxs  ## keep open file descriptor\r\n    echo &#39;{&quot;a&quot;:0,&quot;b&quot;:{&quot;c&quot;:&quot;C&quot;}}{&quot;x&quot;:33}{&quot;asd&quot;:889}&#39; &gt;&amp;3\r\n    jq -nc input &lt;&amp;3  ## prints 1st object &#39;{&quot;a&quot;:0,&quot;b&quot;:{&quot;c&quot;:&quot;C&quot;}}&#39; and reads out the rest\r\n    cat &lt;&amp;3 ## prints nothing\r\n\r\nMy problem is to make `jq` stop reading after first object is read, and do not touch other data in stream (fifo). So `cat` should show the rest of data: `&#39;{&quot;x&quot;:33}{&quot;asd&quot;:889}&#39;`.\r\n\r\n### How to achive that with jq?",
        "link": "https://stackoverflow.com/questions/53732698/take-only-first-json-object-from-stream-with-jq-do-not-touch-rest",
        "title": "Take only first json object from stream with jq, do not touch rest"
    },
    {
        "tags": [
            "json",
            "nested",
            "key",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1544569877,
                "creation_date": 1544569877,
                "answer_id": 53733742,
                "question_id": 53733671,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can search using [recursive decent][1]\r\n\r\n### Solution\r\n    jq &#39;..|.foo?&#39;\r\n\r\n\r\n### Demo\r\nhttps://jqplay.org/s/Xp64LfJFBc\r\n\r\n### Documentation\r\n\r\nhttps://stedolan.github.io/jq/manual/#RecursiveDescent:..\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/#RecursiveDescent:..",
                "title": "Get all values and nested values that match a key name"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1544584478,
        "creation_date": 1544569458,
        "last_edit_date": 1544584478,
        "question_id": 53733671,
        "body_markdown": "I have some data that looks like:\r\n\r\n    {\r\n      &quot;hello&quot;: {\r\n         &quot;foo&quot;: &quot;x&quot;,\r\n         &quot;y&quot;: &quot;z&quot;\r\n      },\r\n      &quot;foo&quot;: &quot;a&quot;,\r\n      &quot;bar&quot;: {\r\n        {\r\n          &quot;foo&quot;: &quot;b&quot;\r\n        }\r\n      }\r\n    }\r\n\r\nHow can I get all values with key `foo`, wherever they are?",
        "link": "https://stackoverflow.com/questions/53733671/get-all-values-and-nested-values-that-match-a-key-name",
        "title": "Get all values and nested values that match a key name"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 165387,
                    "reputation": 74845,
                    "user_id": 388787,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/2f786b1ad349a30e02802ae61b4518fc?s=256&d=identicon&r=PG",
                    "display_name": "Dan D.",
                    "link": "https://stackoverflow.com/users/388787/dan-d"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1544603447,
                "post_id": 53738501,
                "comment_id": 94330318,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1544608219,
                "last_edit_date": 1544608219,
                "creation_date": 1544604962,
                "answer_id": 53739278,
                "question_id": 53738501,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "    #!/bin/bash\r\n    \r\n    JQ=jq-1.4\r\n    \r\n    # For ease of understanding, the following is a bit more verbose than\r\n    # necessary.  \r\n    # One way to get around the constraints of using jq 1.4 is\r\n    # to use the &quot;slurp&quot; option so that the contents of the two files can\r\n    # be kept separately.\r\n    \r\n    # Note that jq 1.6 includes the following def of INDEX, but we can use it with jq 1.4.\r\n    \r\n    ($JQ -s . tmp1.json ; $JQ -s . tmp2.json) | $JQ -s &#39;\r\n    \r\n    def INDEX(stream; idx_expr):\r\n      reduce stream as $row ({};\r\n        .[$row|idx_expr|\r\n          if type != &quot;string&quot; then tojson\r\n          else .\r\n          end] |= $row);\r\n\r\n    .[0] as $tmp1\r\n    | .[1] as $tmp2\r\n    | INDEX($tmp2[]; .InstanceId) as $dict\r\n    | $tmp1\r\n    | map( .Instances |= map(.InstanceName = $dict[.InstanceId].InstanceName))\r\n    | .[]\r\n    &#39;\r\n\r\n## Streamlined\r\n\r\n    INDEX(.[1][]; .InstanceId) as $dict\r\n    | .[0][]\r\n    | .Instances |= map(.InstanceName = $dict[.InstanceId].InstanceName)\r\n\r\n\r\n",
                "title": "How to merge objects with InstanceId unique in bash shell?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": -1,
                "last_activity_date": 1544608881,
                "creation_date": 1544608881,
                "answer_id": 53740459,
                "question_id": 53738501,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "1. minify the two json files\r\n2. try the following command:\r\n\r\n        cat tmp2.json|jq -r &#39;&quot;\\(.InstanceId) \\(.InstanceName)&quot;&#39;|xargs -n2 sh -c &#39;cat tmp1.json|jq &quot;if .Instances[0].InstanceId==\\&quot;$0\\&quot; then .Instances[0].InstanceName=\\&quot;$1\\&quot; else empty end&quot;&#39;\r\n\r\nHere is the output:\r\n\r\n    {\r\n      &quot;VolumeId&quot;: &quot;vol-007253a7d24c1c668&quot;,\r\n      &quot;Instances&quot;: [\r\n        {\r\n          &quot;InstanceId&quot;: &quot;i-0c0650c15b099b993&quot;,\r\n          &quot;InstanceName&quot;: &quot;Test1&quot;\r\n        }\r\n      ]\r\n    }\r\n    {\r\n      &quot;VolumeId&quot;: &quot;vol-046e0be08ac95095a&quot;,\r\n      &quot;Instances&quot;: [\r\n        {\r\n          &quot;InstanceId&quot;: &quot;i-020ce1b2ad08fa6bd&quot;,\r\n          &quot;InstanceName&quot;: &quot;Test&quot;\r\n        }\r\n      ]\r\n    }\r\n",
                "title": "How to merge objects with InstanceId unique in bash shell?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1546899214,
        "creation_date": 1544601685,
        "last_edit_date": 1544602923,
        "question_id": 53738501,
        "body_markdown": "I have two json files as below:\r\n\r\nI wanna merge objects in tmp1.json and tmp2.json with InstanceId unique value in bash shell.\r\n\r\nI have tried jq with argjson option but my jq 1.4 version not support this option. Sorry, I unable update jq to 1.5 version.\r\n\r\n    #cat tmp1.json\r\n    {\r\n      &quot;VolumeId&quot;: &quot;vol-046e0be08ac95095a&quot;,\r\n      &quot;Instances&quot;: [\r\n        {\r\n          &quot;InstanceId&quot;: &quot;i-020ce1b2ad08fa6bd&quot;\r\n        }\r\n      ]\r\n    }\r\n    {\r\n      &quot;VolumeId&quot;: &quot;vol-007253a7d24c1c668&quot;,\r\n      &quot;Instances&quot;: [\r\n        {\r\n          &quot;InstanceId&quot;: &quot;i-0c0650c15b099b993&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\n    #cat tmp2.json\r\n    {\r\n      &quot;InstanceId&quot;: &quot;i-0c0650c15b099b993&quot;,\r\n      &quot;InstanceName&quot;: &quot;Test1&quot;\r\n    }\r\n    {\r\n      &quot;InstanceId&quot;: &quot;i-020ce1b2ad08fa6bd&quot;,\r\n      &quot;InstanceName&quot;: &quot;Test&quot;\r\n    }\r\n\r\nMy desired is:\r\n\r\n    {\r\n          &quot;VolumeId&quot;: &quot;vol-046e0be08ac95095a&quot;,\r\n          &quot;Instances&quot;: [\r\n            {\r\n              &quot;InstanceId&quot;: &quot;i-020ce1b2ad08fa6bd&quot;\r\n              &quot;InstanceName&quot;: &quot;Test&quot;\r\n            }\r\n          ]\r\n        }\r\n        {\r\n          &quot;VolumeId&quot;: &quot;vol-007253a7d24c1c668&quot;,\r\n          &quot;Instances&quot;: [\r\n            {\r\n              &quot;InstanceId&quot;: &quot;i-0c0650c15b099b993&quot;\r\n              &quot;InstanceName&quot;: &quot;Test1&quot;\r\n            }\r\n          ]\r\n        }\r\n",
        "link": "https://stackoverflow.com/questions/53738501/how-to-merge-objects-with-instanceid-unique-in-bash-shell",
        "title": "How to merge objects with InstanceId unique in bash shell?"
    }
]