[
    {
        "tags": [
            "json",
            "jq",
            "aws-cli"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1565092313,
                "creation_date": 1565092313,
                "answer_id": 57375453,
                "question_id": 57375281,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "There should be no need to use `to_entries`:\r\n\r\n\r\n    .SecurityGroups[]\r\n    | [ .GroupName, .GroupId ]\r\n    | join(&quot; - &quot;)\r\n\r\nproduces:\r\n\r\n&quot;default - sg-abd837s&quot;",
                "title": "How to display a map which contains two values of two different keys?"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1565092386,
                "creation_date": 1565092386,
                "answer_id": 57375482,
                "question_id": 57375281,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using string interpolation:\r\n```\r\n.SecurityGroups[] | &quot;\\(.GroupName) - \\(.GroupId)&quot;\r\n```",
                "title": "How to display a map which contains two values of two different keys?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1565092386,
        "creation_date": 1565091746,
        "question_id": 57375281,
        "body_markdown": "As part of a shell script I&#39;m writing, I&#39;m querying AWS (cli) to pull information regarding available security group names and ids, like so:\r\n\r\n    aws ec2 describe-security-groups | jq -r &#39;.SecurityGroups[]&#39;\r\n    {\r\n      &quot;IpPermissionsEgress&quot;: [\r\n        {\r\n          &quot;IpProtocol&quot;: &quot;-1&quot;,\r\n          &quot;PrefixListIds&quot;: [],\r\n          &quot;IpRanges&quot;: [\r\n            {\r\n              &quot;CidrIp&quot;: &quot;0.0.0.0/0&quot;\r\n            }\r\n          ],\r\n          &quot;UserIdGroupPairs&quot;: [],\r\n          &quot;Ipv6Ranges&quot;: []\r\n        }\r\n      ],\r\n      &quot;Description&quot;: &quot;default VPC security group&quot;,\r\n      &quot;IpPermissions&quot;: [\r\n        {\r\n          &quot;PrefixListIds&quot;: [],\r\n          &quot;FromPort&quot;: 80,\r\n          &quot;IpRanges&quot;: [\r\n            {\r\n              &quot;CidrIp&quot;: &quot;0.0.0.0/0&quot;\r\n            }\r\n          ],\r\n          &quot;ToPort&quot;: 80,\r\n          &quot;IpProtocol&quot;: &quot;tcp&quot;,\r\n          &quot;UserIdGroupPairs&quot;: [],\r\n          &quot;Ipv6Ranges&quot;: [\r\n            {\r\n              &quot;CidrIpv6&quot;: &quot;::/0&quot;\r\n            }\r\n          ]\r\n        },\r\n        {\r\n          &quot;PrefixListIds&quot;: [],\r\n          &quot;FromPort&quot;: 22,\r\n          &quot;IpRanges&quot;: [\r\n            {\r\n              &quot;CidrIp&quot;: &quot;0.0.0.0/0&quot;\r\n            }\r\n          ],\r\n          &quot;ToPort&quot;: 22,\r\n          &quot;IpProtocol&quot;: &quot;tcp&quot;,\r\n          &quot;UserIdGroupPairs&quot;: [],\r\n          &quot;Ipv6Ranges&quot;: []\r\n        },\r\n        {\r\n          &quot;PrefixListIds&quot;: [],\r\n          &quot;FromPort&quot;: -1,\r\n          &quot;IpRanges&quot;: [\r\n            {\r\n              &quot;CidrIp&quot;: &quot;0.0.0.0/0&quot;\r\n            }\r\n          ],\r\n          &quot;ToPort&quot;: -1,\r\n          &quot;IpProtocol&quot;: &quot;icmp&quot;,\r\n          &quot;UserIdGroupPairs&quot;: [],\r\n          &quot;Ipv6Ranges&quot;: []\r\n        }\r\n      ],\r\n      &quot;GroupName&quot;: &quot;default&quot;,\r\n      &quot;VpcId&quot;: &quot;vpc-b3c29bcb&quot;,\r\n      &quot;OwnerId&quot;: &quot;506490286752&quot;,\r\n      &quot;GroupId&quot;: &quot;sg-83db2ef7&quot;\r\n    }\r\nAnd using `jq`, I&#39;m trying to return a list of maps which displays the info like so: \r\n\r\n&gt; GroupName , GroupId\r\n\r\nThis is what I&#39;ve tried:\r\n\r\n    aws ec2 describe-security-groups  | jq -r &#39;.SecurityGroups[] | to_entries[] | [ .GroupName.value , .GroupId.value]&#39;\r\n\r\nUsing the above method returns:\r\n\r\n    [\r\n      null,\r\n      null\r\n    ]\r\n    [\r\n      null,\r\n      null\r\n    ]\r\n\r\nIn the example, the delimiter is &quot;,&quot; but I&#39;d like the displayed output to be like so  (example):\r\n\r\n    &quot;default - sg-abd837s&quot;\r\n\r\nHow can it be done by using `jq`?",
        "link": "https://stackoverflow.com/questions/57375281/how-to-display-a-map-which-contains-two-values-of-two-different-keys",
        "title": "How to display a map which contains two values of two different keys?"
    },
    {
        "tags": [
            "windows",
            "jq",
            "startup",
            "chocolatey"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1565186739,
                "last_edit_date": 1565186739,
                "creation_date": 1565127333,
                "answer_id": 57384321,
                "question_id": 57380717,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "1. The standard installation does not include a .jq file or .jq directory.\r\n\r\n2. There are some good reasons not to use ~/.jq as a file, but setting those aside for the time being, if you want to use ~/.jq as a startup file, just create it. You might need to check (or alter) the HOME environment variable.  That is, jq&#39;s idea of where to look depends on HOME.  You might find you need to set or reset the environment variable HOME.\r\n\r\n3. The main reason for not using ~/.jq as a startup file is that if ~/.jq is a directory, jq&#39;s module system will take note of that.  So you may simply want to use the module system, though this has the disadvantage that you&#39;ll need to include an `include MODULE;` or `import MODULE as _;` directive in your scripts.\r\n\r\n4. You should consider upgrading to jq 1.6.  If this is not possible with choco, you can snarf the relevant jq.exe from Appveyor -- see https://github.com/stedolan/jq/wiki/Installation#windows-using-appveyor\r\n\r\n----\r\nThere is in my opinion room for improvement here -- you might like to repurpose your issue at https://github.com/stedolan/jq/issues/1955 with that in mind.\r\n\r\n\r\n\r\n",
                "title": "How to add Walk/1 to jq 1.5 installed by Chocolatey NuGet on Windows 10"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1590422418,
        "creation_date": 1565110305,
        "last_edit_date": 1590422418,
        "question_id": 57380717,
        "body_markdown": "I have been automating some data processing within a batch environment using jq. I recently ran into a use case where I need to recursively apply fromjson to strings inside of my json data. Unfortunately jq 1.5 does not have the walk/1 function natively so I need to add it. I am having trouble finding the correct location to add the code. I need to add this code:\r\n\r\n```\r\ndef walk(f):\r\n  . as $in\r\n  | if type == &quot;object&quot; then\r\n      reduce keys_unsorted[] as $key\r\n        ( {}; . + { ($key):  ($in[$key] | walk(f)) } ) | f\r\n  elif type == &quot;array&quot; then map( walk(f) ) | f\r\n  else f\r\n  end;\r\n```\r\n\r\nTo my initialization file, but I cannot find it. Does anyone know where the initialization fold is when jq is installed with chocolatey?",
        "link": "https://stackoverflow.com/questions/57380717/how-to-add-walk-1-to-jq-1-5-installed-by-chocolatey-nuget-on-windows-10",
        "title": "How to add Walk/1 to jq 1.5 installed by Chocolatey NuGet on Windows 10"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1565125374,
                "creation_date": 1565125374,
                "answer_id": 57383965,
                "question_id": 57383515,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s an efficient solution that has the advantage of also being simple and concise:\r\n\r\n    [2,4] as $list\r\n    | map(.x as $x | select( any($list[]; . == $x )))\r\n",
                "title": "Filter value contained in array in jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1566419423,
        "creation_date": 1565123097,
        "last_edit_date": 1566001567,
        "question_id": 57383515,
        "body_markdown": "I want something like\r\n\r\n    jq &#39;select(.x in [2,4])&#39; &lt;&lt;&lt;&#39;[{&quot;x&quot;:1}, {&quot;x&quot;: 2}, {&quot;x&quot;: 3}, {&quot;x&quot;: 4}]&#39;\r\n    [{&quot;x&quot;: 2}, {&quot;x&quot;: 4}]\r\n\r\nHow do I do this?",
        "link": "https://stackoverflow.com/questions/57383515/filter-value-contained-in-array-in-jq",
        "title": "Filter value contained in array in jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 7,
                "is_accepted": true,
                "score": 7,
                "last_activity_date": 1565206595,
                "creation_date": 1565206595,
                "answer_id": 57401253,
                "question_id": 57400852,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You&#39;re not really doing anything with the `with_entries` call there. But you probably should be filtering there. Filter the entries where the value&#39;s type is neither an array nor an object.\r\n\r\n    .person | with_entries(select(.value | type | . != &quot;array&quot; and . != &quot;object&quot;))\r\n\r\nIf you were on a more recent version of jq, you could filter using the `scalars` builtin which effectively does the same thing.\r\n\r\n    .person | with_entries(select(.value | scalars))\r\n",
                "title": "How do I show only top level JSON entries that are not arrays or objects with jq version 1.3?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 4,
        "last_activity_date": 1566638431,
        "creation_date": 1565204747,
        "question_id": 57400852,
        "body_markdown": "I have a JSON structure and I only want to print the entries that are simple types, e.g. not arrays or objects.\r\n\r\nSample input:\r\n```\r\n{\r\n  &quot;person&quot;: {\r\n    &quot;address&quot;: {\r\n      &quot;city&quot;: &quot;NY&quot;,\r\n      &quot;street&quot;: &quot;Wall Street&quot;\r\n    },\r\n    &quot;god&quot;: true,\r\n    &quot;nicks&quot;: [\r\n      &quot;Lar&quot;,\r\n      &quot;L&quot;,\r\n      &quot;Yo&quot;\r\n    ],\r\n    &quot;name&quot;: &quot;Larry&quot;,\r\n    &quot;id&quot;: 1\r\n  }\r\n}\r\n```\r\n\r\nExpected output:\r\n\r\n```\r\n&quot;god&quot;: true,\r\n&quot;name&quot;: &quot;Larry&quot;,\r\n&quot;id&quot;: 1\r\n```\r\n\r\nI tried many different variations on this which did not work:\r\n\r\n```jq &#39;.person | with_entries(.) | select(map(type) != &quot;array&quot; and map(type) != &quot;object&quot;)&#39;```\r\n\r\nPlease note that I am on jq version 1.3.\r\n\r\nThanks in advance for any help.",
        "link": "https://stackoverflow.com/questions/57400852/how-do-i-show-only-top-level-json-entries-that-are-not-arrays-or-objects-with-jq",
        "title": "How do I show only top level JSON entries that are not arrays or objects with jq version 1.3?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1565233912,
                "creation_date": 1565233912,
                "answer_id": 57404685,
                "question_id": 57404630,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Your desired output is not a valid JSON. The closest I know to get (without custom string formatting) is:\r\n\r\n    jq &#39;.parameters | map_values(select(has(&quot;defaultValue&quot;)))&#39;\r\n    # =&gt; {\r\n    #      &quot;componentName&quot;: {\r\n    #        &quot;defaultValue&quot;: &quot;storage&quot;,\r\n    #        &quot;type&quot;: &quot;string&quot;\r\n    #      }\r\n    #    }\r\n",
                "title": "jq - select an object based on existence of a property"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1565233912,
        "creation_date": 1565233464,
        "question_id": 57404630,
        "body_markdown": "At first glance this sounds like its incredibly straight forward but I&#39;ve been at it for hours.\r\n\r\nI am trying to extract the name of the parameter object (which cannot be known), but only if it has a &quot;defaultValue&quot; key listed. \r\n\r\nInput object (Azure ARM template):\r\n\r\n    {\r\n        &quot;$schema&quot;: &quot;https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#&quot;,\r\n        &quot;contentVersion&quot;: &quot;1.0.0.0&quot;,\r\n        &quot;parameters&quot;: {\r\n            &quot;componentName&quot;: {\r\n                &quot;defaultValue&quot;: &quot;storage&quot;,\r\n                &quot;type&quot;: &quot;string&quot;\r\n            },\r\n            &quot;subnetId&quot;: {\r\n                &quot;type&quot;: &quot;string&quot;,\r\n                &quot;metadata&quot;: {\r\n                    &quot;description&quot;: &quot;The subnet to which this storage component belongs.&quot;\r\n                }\r\n            }\r\n        },\r\n        &quot;variables&quot;: {}\r\n    }\r\n\r\nDesired output:\r\n\r\n        &quot;componentName&quot;: {\r\n            &quot;defaultValue&quot;: &quot;storage&quot;,\r\n            &quot;type&quot;: &quot;string&quot;\r\n        }\r\n\r\nI have tried many iterations of the following to no success:\r\n\r\n    .parameters[] | select(  has( &quot;defaultValue&quot;)) \r\n\r\n(expands the object beyond its name of &quot;componentName&quot; - though this does correctly find the matching object of the two)\r\n\r\n    .parameters | map(select(has(&quot;defaultValue&quot;))) \r\n(same deal as above)\r\n\r\n    .parameters | select( any (has( &quot;defaultValue&quot;))) \r\n(this incorrectly returns the SubnetId object as well, which does not have the &quot;defaultValue&quot; property)\r\n\r\nClearly I am misunderstanding something fundamental. I would greatly appreciate any advice or direction that could be given.",
        "link": "https://stackoverflow.com/questions/57404630/jq-select-an-object-based-on-existence-of-a-property",
        "title": "jq - select an object based on existence of a property"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1565305863,
                "creation_date": 1565305863,
                "answer_id": 57421707,
                "question_id": 57410632,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Sure. Though you&#39;ll need to parse (split) that list of ids to something that jq can work with, such as an array of ids. Then your problem becomes, given an array of keys, select objects that have any of these ids. Which you could use approaches found [here](https://stackoverflow.com/q/38121740).\r\n\r\n    $ jq --arg ID &#39;8df993c1-57d5-46b3-a8a3-d95066934e5b,1d5441ca-5758-474d-a9fc-40d0f68aa538,23cc618a-8ad4-4141-bc1c-0251y0663963&#39; &#39;\r\n    select(.id | IN($ID|split(&quot;,&quot;)[]))\r\n    &#39; ./my_json_file.json\r\n\r\nI&#39;m not sure what your input looks like but judging by your use of slurping then filtering the slurped input, it&#39;s a stream of objects. The slurping is not necessary here.",
                "title": "Can jq check each element of a comma seperated array of values to check if the value exists in JSON?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1565355995,
                "creation_date": 1565355995,
                "answer_id": 57430710,
                "question_id": 57410632,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is an approach that focuses on efficiency.\r\n\r\nYour Q indicates that in fact you have a stream of objects, so the first step towards efficiency is to avoid the `-s` option, and use `-n` with `inputs` instead.\r\n\r\nThe second step it to avoid splitting your comma-separated string of values more than once. \r\n\r\nSo your script might look like this:\r\n\r\n    INDEX($ids | splits(&quot;,&quot;); .) as $dict\r\n    | inputs\r\n    | select($dict[.id])\r\n\r\nAnd the invocation would look like this:\r\n\r\n    jq -n --args a,b,c -f by_id.jq\r\n\r\nThis of course assumes that simply splitting the string of ids on &quot;,&quot; will suffice. You might need to trim the values and take care of other potential anomalies.",
                "title": "Can jq check each element of a comma seperated array of values to check if the value exists in JSON?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1565622382,
                "creation_date": 1565622382,
                "answer_id": 57463754,
                "question_id": 57410632,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "For efficiency, it would be better to split $ID just once.\r\n\r\nSo if you have to use the -s option, you could use the following jq program:\r\n```\r\nINDEX($ID | splits(&quot;,&quot;); .) as $dict\r\n| .[]\r\n| select($dict[.id])\r\n```",
                "title": "Can jq check each element of a comma seperated array of values to check if the value exists in JSON?"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1566638512,
        "creation_date": 1565260537,
        "question_id": 57410632,
        "body_markdown": "I have a JSON file and I am extracting data from it using jq. One simple use case is pulling out any JSON Object that contains an Id which is provided as an argument. \r\n\r\nI use the following simple script to do so:\r\n\r\n`[.[] | select(.id == $ID)]`\r\n\r\nThe script is stored in a separate file (`by_id.jq`) which I pass in using the `-f` argument. \r\n\r\nThe full command looks something like this:\r\n\r\n`cat ./my_json_file.json | jq -sf --arg ID &quot;8df993c1-57d5-46b3-a8a3-d95066934e5b&quot; ./by_id.jq`\r\n\r\nIs there a way by only using jq that a comma separated list of values could be passed as an argument to the jq script and iterate through the ids and check them against the value of `.id` in the the JSON file with the result being the objects that have that id?\r\n\r\nFor example if I wanted to pull out three objects by their ids I would want to structure the command in this way:\r\n\r\n`cat ./my_json_file.json | jq -sf --arg ID &quot;8df993c1-57d5-46b3-a8a3-d95066934e5b,1d5441ca-5758-474d-a9fc-40d0f68aa538,23cc618a-8ad4-4141-bc1c-0251y0663963&quot; ./by_id.jq`",
        "link": "https://stackoverflow.com/questions/57410632/can-jq-check-each-element-of-a-comma-seperated-array-of-values-to-check-if-the-v",
        "title": "Can jq check each element of a comma seperated array of values to check if the value exists in JSON?"
    },
    {
        "tags": [
            "json",
            "linux",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1565391851,
                "post_id": 57437838,
                "comment_id": 101353307,
                "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": 1565391871,
                "post_id": 57437838,
                "comment_id": 101353310,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2255283,
                    "reputation": 1733,
                    "user_id": 1986597,
                    "user_type": "registered",
                    "accept_rate": 82,
                    "profile_image": "https://www.gravatar.com/avatar/59acb1f9dda0d6e2d7a60cc06d7c4b87?s=256&d=identicon&r=PG",
                    "display_name": "Casper",
                    "link": "https://stackoverflow.com/users/1986597/casper"
                },
                "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": 1565392125,
                "post_id": 57437838,
                "comment_id": 101353360,
                "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": 1565392159,
                "post_id": 57437838,
                "comment_id": 101353365,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2141010,
                    "reputation": 124401,
                    "user_id": 1899640,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/47374ccb28e4b0d2454b64f7b975bc66?s=256&d=identicon&r=PG",
                    "display_name": "that other guy",
                    "link": "https://stackoverflow.com/users/1899640/that-other-guy"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1565393686,
                "post_id": 57437838,
                "comment_id": 101353616,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "reply_to_user": {
                    "account_id": 2141010,
                    "reputation": 124401,
                    "user_id": 1899640,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/47374ccb28e4b0d2454b64f7b975bc66?s=256&d=identicon&r=PG",
                    "display_name": "that other guy",
                    "link": "https://stackoverflow.com/users/1899640/that-other-guy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1565404101,
                "post_id": 57437838,
                "comment_id": 101354899,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "reply_to_user": {
                    "account_id": 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": 1565410441,
                "post_id": 57437838,
                "comment_id": 101355568,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2141010,
                    "reputation": 124401,
                    "user_id": 1899640,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/47374ccb28e4b0d2454b64f7b975bc66?s=256&d=identicon&r=PG",
                    "display_name": "that other guy",
                    "link": "https://stackoverflow.com/users/1899640/that-other-guy"
                },
                "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": 1565410830,
                "post_id": 57437838,
                "comment_id": 101355617,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "reply_to_user": {
                    "account_id": 2141010,
                    "reputation": 124401,
                    "user_id": 1899640,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/47374ccb28e4b0d2454b64f7b975bc66?s=256&d=identicon&r=PG",
                    "display_name": "that other guy",
                    "link": "https://stackoverflow.com/users/1899640/that-other-guy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1565416827,
                "post_id": 57437838,
                "comment_id": 101356268,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 6,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1565392162,
                "creation_date": 1565392162,
                "answer_id": 57438049,
                "question_id": 57437838,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "In a jq query, your existing input is `.`. Thus, you can wrap it inside a new object by putting a `.` in the location where you want your existing content to be:\r\n\r\n```\r\njq &#39;{&quot;Variables&quot;: .}&#39; &lt;in.json &gt;out.json\r\n```",
                "title": "How can I wrap an existing JSON file&#39;s contents as part of an object?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1565392162,
        "creation_date": 1565390199,
        "last_edit_date": 1565392067,
        "question_id": 57437838,
        "body_markdown": "Since I don&#39;t know a lot about json terminology, I&#39;m going to give an example:\r\n\r\nSay I have a json:\r\n\r\n    {\r\n\r\n       &quot;var1&quot;: &quot;foo&quot;,\r\n       &quot;var2&quot;: &quot;bar&quot;,\r\n       ...\r\n    }\r\n\r\nHow can I use `jq` to convert this to:\r\n\r\n    {\r\n      &quot;Variables&quot;:\r\n      {\r\n          &quot;var1&quot;: &quot;foo&quot;,\r\n          &quot;var2&quot;: &quot;bar&quot;,\r\n          ...\r\n      }\r\n    }",
        "link": "https://stackoverflow.com/questions/57437838/how-can-i-wrap-an-existing-json-files-contents-as-part-of-an-object",
        "title": "How can I wrap an existing JSON file&#39;s contents as part of an object?"
    },
    {
        "tags": [
            "json",
            "regex",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 14574095,
                    "reputation": 31,
                    "user_id": 10526486,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/3973df00a7890dc011b1234f95dca5c1?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "foo_paul",
                    "link": "https://stackoverflow.com/users/10526486/foo-paul"
                },
                "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": 1565506317,
                "post_id": 57447290,
                "comment_id": 101371455,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 14574095,
                    "reputation": 31,
                    "user_id": 10526486,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/3973df00a7890dc011b1234f95dca5c1?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "foo_paul",
                    "link": "https://stackoverflow.com/users/10526486/foo-paul"
                },
                "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": 1565506838,
                "post_id": 57447290,
                "comment_id": 101371535,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1565512419,
                "last_edit_date": 1565512419,
                "creation_date": 1565506869,
                "answer_id": 57447982,
                "question_id": 57447290,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Your .Age value is a number, but regexes work on strings, so if you really want to use regexes, you would have to transform the number to a string. This can be done using `tostring`, but please remember that the `tostring` representation of a JSON number might not always be what you think it will be.\r\n\r\n–––\r\n\r\np.s. That should be `match(&quot;\\\\d&quot;)`",
                "title": "Cannot match integer value using regex - error (at &lt;stdin&gt;:6): number not a string or array"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1565512419,
        "creation_date": 1565496677,
        "last_edit_date": 1565512203,
        "question_id": 57447290,
        "body_markdown": "I have multiple JSON files with  a person&#39;s age and I want to match specific ages using regex, however, I cannot be able to match even a single integer in a file.\r\n\r\n\r\nI can select age using following `jq`,\r\n\r\n```\r\njq -r .details.Age\r\n```\r\n\r\nI can match `Name` using following `jq`,\r\n\r\n```\r\njq -r &#39;select(.details.Name | match(&quot;r.*&quot;))&#39;\r\n```\r\n\r\nBut when I try to use `test` or `match` with `Age` I get following error,\r\n\r\n```\r\njq -r &#39;select(.details.Age | match(32))&#39;\r\njq: error (at &lt;stdin&gt;:6): number not a string or array\r\n```\r\n\r\n\r\n\r\nHere is code,\r\n\r\n```\r\n{\r\n  &quot;details&quot;: {\r\n    &quot;Age&quot;: 32,\r\n    &quot;Name&quot;: &quot;reverent&quot;\r\n  }\r\n}\r\n```\r\n\r\nI want to be able to match `Age` using `jq` something like this,\r\n```\r\njq -r &#39;select(.details.Age | match(\\d))&#39;\r\n```",
        "link": "https://stackoverflow.com/questions/57447290/cannot-match-integer-value-using-regex-error-at-stdin6-number-not-a-stri",
        "title": "Cannot match integer value using regex - error (at &lt;stdin&gt;:6): number not a string or array"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1565609500,
                "creation_date": 1565609500,
                "answer_id": 57460400,
                "question_id": 57459947,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use `select`:\r\n```\r\n$ jq -r --arg q 99900 &#39;.[] | select(.id == $q).name&#39; file\r\nDEF\r\n```",
                "title": "Extract inner field value from JSON document based on a key using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1565614379,
        "creation_date": 1565607657,
        "last_edit_date": 1565614379,
        "question_id": 57459947,
        "body_markdown": "I have a json file with the below format. I want to extract the `name` field value from inside based on the `id` value.\r\nso, if I pass id value as 99900, it should return me DEF. How can I do that using jq.\r\n\r\n    {\r\n      &quot;11213-99900&quot;: {\r\n        &quot;cid&quot;: &quot;11213-99900&quot;,\r\n        &quot;name&quot;: &quot;DEF&quot;,\r\n        &quot;id&quot;: &quot;99900&quot;\r\n      },\r\n      &quot;11213-12345&quot;: {\r\n        &quot;cid&quot;: &quot;11213-12345&quot;,\r\n        &quot;name&quot;: &quot;ABC&quot;,\r\n        &quot;id&quot;: &quot;12345&quot;\r\n      },\r\n      &quot;11272-23456&quot;: {\r\n        &quot;cid&quot;: &quot;11272-23456&quot;,\r\n        &quot;name&quot;: &quot;YXX&quot;,\r\n        &quot;id&quot;: &quot;23456&quot;\r\n      }\r\n    }",
        "link": "https://stackoverflow.com/questions/57459947/extract-inner-field-value-from-json-document-based-on-a-key-using-jq",
        "title": "Extract inner field value from JSON document based on a key using jq"
    },
    {
        "tags": [
            "bash",
            "for-loop",
            "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": 4,
                "creation_date": 1565624655,
                "post_id": 57464276,
                "comment_id": 101402012,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 3,
                "creation_date": 1565624680,
                "post_id": 57464276,
                "comment_id": 101402028,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1565624895,
                "post_id": 57464276,
                "comment_id": 101402156,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1565625219,
                "post_id": 57464276,
                "comment_id": 101402327,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1565625261,
                "post_id": 57464276,
                "comment_id": 101402342,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 438773,
                    "reputation": 264873,
                    "user_id": 827263,
                    "user_type": "registered",
                    "accept_rate": 54,
                    "profile_image": "https://www.gravatar.com/avatar/216c1db53d752f87dd8176a6ba0c2190?s=256&d=identicon&r=PG",
                    "display_name": "Keith Thompson",
                    "link": "https://stackoverflow.com/users/827263/keith-thompson"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1565625335,
                "post_id": 57464276,
                "comment_id": 101402379,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1565625341,
                "post_id": 57464276,
                "comment_id": 101402385,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1565626879,
                "post_id": 57464276,
                "comment_id": 101403015,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1565624859,
                "creation_date": 1565624859,
                "answer_id": 57464361,
                "question_id": 57464276,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "That happens if `numsecs` isn&#39;t actually set to a (single integer) number.\r\n\r\nOne way that can happen is if your JSON file doesn&#39;t have any records in it at all; or if it has more than one (which would mean you&#39;d have several numbers in `jq`&#39;s output, which bash can&#39;t correctly parse to a single number).\r\n\r\n---\r\n\r\n### Some Examples\r\n\r\nThe zero-object document case:\r\n\r\n```\r\n$ numsecs=$(jq &#39;. | length&#39; &lt;&lt;&lt;&#39;&#39;)\r\n$ declare -p numsecs\r\ndeclare -- numsecs=&quot;&quot;\r\n$ for ((j=0;j&lt;$numsecs;j++)); do break; done\r\n-bash: ((: j&lt;: syntax error: operand expected (error token is &quot;&lt;&quot;)\r\n```\r\n\r\nThe multi-object document case:\r\n```\r\n$ numsecs=$(jq &#39;. | length&#39; &lt;&lt;&lt;$&#39;[1,2]\\n[3,4]&#39;)\r\n$ declare -p numsecs\r\ndeclare -- numsecs=&quot;2\r\n2&quot;\r\n$ for ((j=0;j&lt;$numsecs;j++)); do break; done\r\n-bash: ((: j&lt;2\r\n2: syntax error in expression (error token is &quot;2&quot;)\r\n```",
                "title": "syntax error: operand expected (error token is &quot;&lt;&quot;)"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1565656769,
        "creation_date": 1565624488,
        "last_edit_date": 1565624798,
        "question_id": 57464276,
        "body_markdown": "When i run this code, i get \r\n./file.sh: line 23: ((: j&lt;: syntax error: operand expected (error token is &quot;&lt;&quot;). The  $orgs+$i.json in the below code will generate files if it consists data, otherwise thise file wont be generated. The orgs and repos are from the file which i passed. Once the json file is created with data, then i will need to pull some fields like commit, repo, author, file fields from that json file. I will attach the json file format from which i&#39;m trying to pull values.\r\n\r\nJson file data looks like in below image\r\n[enter image description here][1]\r\n\r\n    #!/bin/bash\r\n    IFS=$IFS,\r\n    usr=&#39;*************&#39;\r\n    pwd=&#39;*************&#39;\r\n    url=&#39;*************&#39;\r\n    curl --header &quot;Content-Type: application/json&quot; --request GET \r\n    &quot;https://$usr:$pwd@$url&quot; |grep login|cut -d &#39;:&#39; -f2|sed &#39;s/,//g&#39;|sed \r\n    &#39;s/&quot;//g&#39; &gt;&gt; MHEOrgs.txt\r\n    File=./MHEOrgs.txt\r\n\r\n    while read orgs; do\r\n\r\n    #orgs= $i\r\n    curl -s --header &quot;Content-Type: application/json&quot; --request GET --user \r\n    &quot;$usr:$pwd&quot; $url/$orgs/repos?page=[1-100] &gt;&gt; $orgs+Repos.json\r\n    jq -r &#39;.[].name&#39; $orgs+Repos.json &gt;&gt;$orgs+Repolist.json\r\n    user=&quot;https://$usr:$pwd@********/$orgs/&quot;\r\n    repos=`cat $orgs+Repolist.json`\r\n    for i in $repos;\r\n    do\r\n        echo $user&quot;$i&quot;.git\r\n        #Below commabd will perform scan operation on the githubrepos and \r\n        generates multiple json files\r\n        ~/go/bin/gitleaks --repo=$user&quot;$i&quot; --report=$orgs+$i.json\r\n         #Now i wanted to get below values from each file generated above.\r\n         numsecs=$(jq &quot;.|length&quot; $orgs+$i.json)\r\n         for ((j=0;j&lt;$numsecs;j++))\r\n         do\r\n            commit=$(jq -r &quot;.[$j]|.commit&quot; $orgs+$i.json)\r\n            author=$(jq -r &quot;.[$j]|.author&quot; $orgs+$i.json)\r\n            file=$(jq -r &quot;.[$j]|.file&quot; $orgs+$i.json)\r\n            repo=$(jq -r &quot;.[$j]|.repo&quot; $orgs+$i.json)\r\n            if [ &quot;${commit}&quot; != &quot;null&quot; ]; then\r\n\r\n            echo &quot;\\&quot;$repo\\&quot;,&quot; &quot;\\&quot;$file\\&quot;,&quot; &quot;\\&quot;$author\\&quot;,&quot; &quot;\\&quot;$commit\\&quot;,&quot;&gt;&gt; \r\n            gitleaks-scan-results.csv\r\n            else\r\n            echo &quot;No leaks found&quot;\r\n            fi\r\n            \r\n\r\n          done\r\n\r\n\r\n        done\r\n\r\n    done &lt; $File\r\n\r\n\r\n  [1]: https://i.sstatic.net/opwJi.jpg",
        "link": "https://stackoverflow.com/questions/57464276/syntax-error-operand-expected-error-token-is",
        "title": "syntax error: operand expected (error token is &quot;&lt;&quot;)"
    },
    {
        "tags": [
            "json",
            "parsing",
            "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": 1565688785,
                "post_id": 57474828,
                "comment_id": 101421716,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 47525,
                    "reputation": 5271,
                    "user_id": 140823,
                    "user_type": "registered",
                    "accept_rate": 74,
                    "profile_image": "https://www.gravatar.com/avatar/f3dc06f587d1ff4c7366b102bfda9204?s=256&d=identicon&r=PG",
                    "display_name": "monch1962",
                    "link": "https://stackoverflow.com/users/140823/monch1962"
                },
                "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": 1565688913,
                "post_id": 57474828,
                "comment_id": 101421786,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1565691587,
                "last_edit_date": 1565691587,
                "creation_date": 1565690877,
                "answer_id": 57475547,
                "question_id": 57474828,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This will give you output that is not quite what you posted, but should be good enough, given that JavaScript does not distinguish `foo.bar` and `foo[&quot;bar&quot;]`.\r\n\r\n    jq -r &#39;\r\n      . as $data |\r\n      [path(.. | \r\n        select(type != &quot;object&quot; and type != &quot;array&quot;)\r\n      )] |\r\n      map(\r\n        . as $path |\r\n        map(&quot;[&quot; + (. | tojson) + &quot;]&quot;) |\r\n        join(&quot;&quot;) |\r\n        &quot;request\\(.) = \\($data | getpath($path) | tojson)&quot;\r\n      ) |\r\n      join(&quot; &amp;&amp; &quot;)\r\n    &#39; &lt; test.json\r\n\r\nOutput:\r\n\r\n    request[&quot;username&quot;] = &quot;billy&quot; &amp;&amp;\r\n    request[&quot;hero&quot;][&quot;something&quot;] = &quot;goeshere&quot; &amp;&amp;\r\n    request[&quot;bumper&quot;][&quot;bumper2&quot;][&quot;bumper3&quot;] = &quot;splodge&quot; &amp;&amp;\r\n    request[&quot;morgan&quot;][0][&quot;abc&quot;] = 123 &amp;&amp;\r\n    request[&quot;morgan&quot;][1] = 2 &amp;&amp;\r\n    request[&quot;morgan&quot;][2] = 4 &amp;&amp;\r\n    request[&quot;morgan&quot;][3][&quot;def&quot;] = 567 &amp;&amp;\r\n    request[&quot;password&quot;] = &quot;issilly&quot;\r\n\r\nExplanation: `..` gives us all values; but we want only the leaf values, so we filter out those that are arrays or objects. Then we get the array of paths using `[path()]`: this will be an array of arrays of path steps, like this: `[[&quot;username&quot;], [&quot;hero&quot;, &quot;something&quot;], [&quot;bumper&quot;, &quot;bumper2&quot;, &quot;bumper3&quot;], [&quot;morgan&quot;, 0, &quot;abc&quot;]... ]` etc. Now for each path, we need to enclose each path step in brackets to get something that JavaScript can understand. `tojson` will give the exact thing that the brackets need, so that string keys of objects get quoted but the integral keys of arrays don&#39;t. We can now put together the equality expression: the left side needs a `request` prepended to the brackety path we constructed, while we can use `getpath` to get the value that should be on the right hand side (again using `tojson` to get the correct literal).",
                "title": "jq - parsing complex JSON into a string"
            },
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1565765493,
                "last_edit_date": 1565765493,
                "creation_date": 1565690954,
                "answer_id": 57475576,
                "question_id": 57474828,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`paths(scalars)` outputs arrays representing paths to strings and numbers in `.`, and using `getpath` you can get values at those paths. So all you need is a function that converts path representations to path expressions, like:\r\n```\r\ndef pr2pe:\r\n  reduce .[] as $n ([];\r\n    if $n|type == &quot;string&quot;\r\n    then . + [$n]\r\n    elif $n|type == &quot;number&quot; and length\r\n    then .[-1] += &quot;[\\($n)]&quot;\r\n    else error(&quot;invalid path representation&quot;)\r\n    end) | join(&quot;.&quot;);\r\n[ paths(scalars) as $p\r\n  | &quot;\\($p | pr2pe) == \\(getpath($p) | tojson)&quot; ]\r\n| join(&quot; &amp;&amp; &quot;)\r\n```\r\nSee it on [jqplay](https://jqplay.org/s/rBIMcCEl0w)",
                "title": "jq - parsing complex JSON into a string"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1565765493,
        "creation_date": 1565688495,
        "last_edit_date": 1565688590,
        "question_id": 57474828,
        "body_markdown": "I&#39;m trying to use `jq` to parse JSON that looks something like:\r\n\r\n\r\n    {\r\n    \t&quot;username&quot;: &quot;billy&quot;,\r\n    \t&quot;hero&quot;: {\r\n    \t\t&quot;something&quot;: &quot;goeshere&quot;\r\n    \t},\r\n    \t&quot;bumper&quot;: {\r\n    \t\t&quot;bumper2&quot;: {\r\n    \t\t\t&quot;bumper3&quot;: &quot;splodge&quot;\r\n    \t\t}\r\n    \t},\r\n    \t&quot;morgan&quot;: [{\r\n    \t\t&quot;abc&quot;: 123\r\n    \t}, 2, 4, {\r\n    \t\t&quot;def&quot;: 567\r\n    \t}],\r\n    \t&quot;password&quot;: &quot;issilly&quot;\r\n    }\r\n\r\ninto\r\n\r\n    request.username == &#39;billy&#39; &amp;&amp; request.hero.something == &#39;goeshere&#39; &amp;&amp; request.bumper.bumper2.bumper3 == &#39;splodge&#39; &amp;&amp; request.morgan[0].abc == 123 &amp;&amp; request.morgan[1] == 2 &amp;&amp; request.morgan[2] == 4 &amp;&amp; request.morgan[3].def == 567 &amp;&amp; request.password == &#39;issilly&#39;\r\n\r\nSo far I&#39;ve got to\r\n\r\n    jq &#39;. | to_entries[] | &quot;request.\\(.key) == &#39;\\(.value)&#39;&quot;&#39;\r\n\r\nwhich gets me part of the way there, but I can&#39;t work out how to &quot;walk down&quot; into the deep-nested elements, nor how to join the strings produced into a single line delimited with &#39; &amp;&amp; &#39;",
        "link": "https://stackoverflow.com/questions/57474828/jq-parsing-complex-json-into-a-string",
        "title": "jq - parsing complex JSON into a string"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": -1,
                "last_activity_date": 1565690997,
                "creation_date": 1565690997,
                "answer_id": 57475582,
                "question_id": 57475419,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I figured it out myself \r\n\r\nThe correct command is \r\n\r\n    echo $(jq &#39;.data[] | select(.vulnerable_configuration_cpe_2_2 | contains([&quot;2.4.38&quot;]))&#39; search1.json) | jq -r &#39;. | &quot;\\(.summary)&quot;&#39;\r\n\r\nAfter `jq -r`  there should be a `.` and not `.[]`",
                "title": "Transforming json to table using JQ gives &quot;Cannot index string error&quot;"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1565690997,
        "creation_date": 1565690413,
        "last_edit_date": 1565690803,
        "question_id": 57475419,
        "body_markdown": "Output of the following command \r\n\r\n    jq &#39;.data[] | select(.vulnerable_configuration_cpe_2_2 | contains([&quot;2.4.38&quot;]))&#39; search1.json\r\n\r\ngives me \r\n\r\n    {\r\n      &quot;Modified&quot;: &quot;2019-06-11T17:29:00.647000&quot;,\r\n      &quot;Published&quot;: &quot;2019-06-11T17:29:00.630000&quot;,\r\n      &quot;cvss&quot;: &quot;5.0&quot;,\r\n      &quot;cwe&quot;: &quot;CWE-399&quot;,\r\n      &quot;id&quot;: &quot;CVE-2019-0220&quot;,\r\n      &quot;last-modified&quot;: &quot;2019-06-25T06:15:10.627000&quot;,\r\n      &quot;reason&quot;: &quot;Text search&quot;,\r\n      &quot;references&quot;: [\r\n        &quot;http://lists.opensuse.org/opensuse-security-announce/2019-04/msg00051.html&quot;\r\n      ],\r\n      &quot;summary&quot;: &quot;A vulnerability was found in Apache HTTP Server 2.4.0 to 2.4.38. When the path component of a request URL contains multiple consecutive slashes (&#39;/&#39;), directives such as LocationMatch and RewriteRule must account for duplicates in regular expressions while other aspects of the servers processing will implicitly collapse them.&quot;,\r\n      &quot;vulnerable_configuration&quot;: [\r\n        &quot;cpe:2.3:a:apache:http_server:2.4.0&quot;,\r\n        &quot;cpe:2.3:a:apache:http_server:2.4.1&quot;,\r\n        &quot;cpe:2.3:a:apache:http_server:2.4.2&quot;,\r\n        &quot;cpe:2.3:a:apache:http_server:2.4.3&quot;,\r\n        &quot;cpe:2.3:a:apache:http_server:2.4.4&quot;,\r\n        &quot;cpe:2.3:a:apache:http_server:2.4.6&quot;,\r\n        &quot;cpe:2.3:a:apache:http_server:2.4.7&quot;,\r\n        &quot;cpe:2.3:a:apache:http_server:2.4.8&quot;,\r\n        &quot;cpe:2.3:a:apache:http_server:2.4.9&quot;,\r\n        &quot;cpe:2.3:a:apache:http_server:2.4.10&quot;,\r\n        &quot;cpe:2.3:a:apache:http_server:2.4.12&quot;,\r\n        &quot;cpe:2.3:a:apache:http_server:2.4.14&quot;,\r\n        &quot;cpe:2.3:a:apache:http_server:2.4.16&quot;,\r\n        &quot;cpe:2.3:a:apache:http_server:2.4.17&quot;,\r\n        &quot;cpe:2.3:a:apache:http_server:2.4.18&quot;,\r\n        &quot;cpe:2.3:a:apache:http_server:2.4.19&quot;,\r\n        &quot;cpe:2.3:a:apache:http_server:2.4.20&quot;,\r\n        &quot;cpe:2.3:a:apache:http_server:2.4.21&quot;,\r\n        &quot;cpe:2.3:a:apache:http_server:2.4.22&quot;,\r\n        &quot;cpe:2.3:a:apache:http_server:2.4.23&quot;,\r\n        &quot;cpe:2.3:a:apache:http_server:2.4.24&quot;,\r\n        &quot;cpe:2.3:a:apache:http_server:2.4.25&quot;,\r\n        &quot;cpe:2.3:a:apache:http_server:2.4.26&quot;,\r\n        &quot;cpe:2.3:a:apache:http_server:2.4.27&quot;,\r\n        &quot;cpe:2.3:a:apache:http_server:2.4.28&quot;,\r\n        &quot;cpe:2.3:a:apache:http_server:2.4.29&quot;,\r\n        &quot;cpe:2.3:a:apache:http_server:2.4.30&quot;,\r\n        &quot;cpe:2.3:a:apache:http_server:2.4.32&quot;,\r\n        &quot;cpe:2.3:a:apache:http_server:2.4.33&quot;,\r\n        &quot;cpe:2.3:a:apache:http_server:2.4.34&quot;,\r\n        &quot;cpe:2.3:a:apache:http_server:2.4.35&quot;,\r\n        &quot;cpe:2.3:a:apache:http_server:2.4.36&quot;,\r\n        &quot;cpe:2.3:a:apache:http_server:2.4.37&quot;,\r\n        &quot;cpe:2.3:a:apache:http_server:2.4.38&quot;,\r\n        &quot;cpe:2.3:o:opensuse:leap:15.0&quot;,\r\n        &quot;cpe:2.3:o:opensuse:leap:42.3&quot;,\r\n        &quot;cpe:2.3:o:debian:debian_linux:8.0&quot;,\r\n        &quot;cpe:2.3:o:debian:debian_linux:9.0&quot;,\r\n        &quot;cpe:2.3:o:fedoraproject:fedora:28&quot;,\r\n        &quot;cpe:2.3:o:fedoraproject:fedora:29&quot;,\r\n        &quot;cpe:2.3:o:fedoraproject:fedora:30&quot;,\r\n        &quot;cpe:2.3:o:canonical:ubuntu_linux:14.04:-:-:-:lts&quot;,\r\n        &quot;cpe:2.3:o:canonical:ubuntu_linux:16.04:-:-:-:lts&quot;,\r\n        &quot;cpe:2.3:o:canonical:ubuntu_linux:18.04:-:-:-:lts&quot;,\r\n        &quot;cpe:2.3:o:canonical:ubuntu_linux:18.10&quot;\r\n      ],\r\n      &quot;vulnerable_configuration_cpe_2_2&quot;: [\r\n        &quot;cpe:/a:apache:http_server:2.4.0&quot;,\r\n        &quot;cpe:/a:apache:http_server:2.4.1&quot;,\r\n        &quot;cpe:/a:apache:http_server:2.4.2&quot;,\r\n        &quot;cpe:/a:apache:http_server:2.4.3&quot;,\r\n        &quot;cpe:/a:apache:http_server:2.4.4&quot;,\r\n        &quot;cpe:/a:apache:http_server:2.4.6&quot;,\r\n        &quot;cpe:/a:apache:http_server:2.4.7&quot;,\r\n        &quot;cpe:/a:apache:http_server:2.4.8&quot;,\r\n        &quot;cpe:/a:apache:http_server:2.4.9&quot;,\r\n        &quot;cpe:/a:apache:http_server:2.4.10&quot;,\r\n        &quot;cpe:/a:apache:http_server:2.4.12&quot;,\r\n        &quot;cpe:/a:apache:http_server:2.4.14&quot;,\r\n        &quot;cpe:/a:apache:http_server:2.4.16&quot;,\r\n        &quot;cpe:/a:apache:http_server:2.4.17&quot;,\r\n        &quot;cpe:/a:apache:http_server:2.4.18&quot;,\r\n        &quot;cpe:/a:apache:http_server:2.4.19&quot;,\r\n        &quot;cpe:/a:apache:http_server:2.4.20&quot;,\r\n        &quot;cpe:/a:apache:http_server:2.4.21&quot;,\r\n        &quot;cpe:/a:apache:http_server:2.4.22&quot;,\r\n        &quot;cpe:/a:apache:http_server:2.4.23&quot;,\r\n        &quot;cpe:/a:apache:http_server:2.4.24&quot;,\r\n        &quot;cpe:/a:apache:http_server:2.4.25&quot;,\r\n        &quot;cpe:/a:apache:http_server:2.4.26&quot;,\r\n        &quot;cpe:/a:apache:http_server:2.4.27&quot;,\r\n        &quot;cpe:/a:apache:http_server:2.4.28&quot;,\r\n        &quot;cpe:/a:apache:http_server:2.4.29&quot;,\r\n        &quot;cpe:/a:apache:http_server:2.4.30&quot;,\r\n        &quot;cpe:/a:apache:http_server:2.4.32&quot;,\r\n        &quot;cpe:/a:apache:http_server:2.4.33&quot;,\r\n        &quot;cpe:/a:apache:http_server:2.4.34&quot;,\r\n        &quot;cpe:/a:apache:http_server:2.4.35&quot;,\r\n        &quot;cpe:/a:apache:http_server:2.4.36&quot;,\r\n        &quot;cpe:/a:apache:http_server:2.4.37&quot;,\r\n        &quot;cpe:/a:apache:http_server:2.4.38&quot;,\r\n        &quot;cpe:/o:opensuse:leap:15.0&quot;,\r\n        &quot;cpe:/o:opensuse:leap:42.3&quot;,\r\n        &quot;cpe:/o:debian:debian_linux:8.0&quot;,\r\n        &quot;cpe:/o:debian:debian_linux:9.0&quot;,\r\n        &quot;cpe:/o:fedoraproject:fedora:28&quot;,\r\n        &quot;cpe:/o:fedoraproject:fedora:29&quot;,\r\n        &quot;cpe:/o:fedoraproject:fedora:30&quot;,\r\n        &quot;cpe:/o:canonical:ubuntu_linux:14.04::~~lts~~~&quot;,\r\n        &quot;cpe:/o:canonical:ubuntu_linux:16.04::~~lts~~~&quot;,\r\n        &quot;cpe:/o:canonical:ubuntu_linux:18.04::~~lts~~~&quot;,\r\n        &quot;cpe:/o:canonical:ubuntu_linux:18.10&quot;\r\n      ]\r\n    }\r\n    {\r\n      &quot;Modified&quot;: &quot;2019-04-08T17:29:00.860000&quot;,\r\n      &quot;Published&quot;: &quot;2019-04-08T17:29:00.843000&quot;,\r\n      &quot;cvss&quot;: &quot;6.0&quot;,\r\n      &quot;cwe&quot;: &quot;CWE-362&quot;,\r\n      &quot;id&quot;: &quot;CVE-2019-0217&quot;,\r\n      &quot;last-modified&quot;: &quot;2019-05-13T23:29:03.847000&quot;,\r\n      &quot;reason&quot;: &quot;Text search&quot;,\r\n      &quot;references&quot;: [\r\n        &quot;http://lists.opensuse.org/opensuse-security-announce/2019-04/msg00051.html&quot;\r\n      ],\r\n      &quot;summary&quot;: &quot;In Apache HTTP Server 2.4 release 2.4.38 and prior, a race condition in mod_auth_digest when running in a threaded server could allow a user with valid credentials to authenticate using another username, bypassing configured access control restrictions.&quot;,\r\n      &quot;vulnerable_configuration&quot;: [\r\n        &quot;cpe:2.3:a:apache:http_server:2.4.38&quot;,\r\n        &quot;cpe:2.3:o:debian:debian_linux:8.0&quot;,\r\n        &quot;cpe:2.3:o:debian:debian_linux:9.0&quot;,\r\n        &quot;cpe:2.3:o:fedoraproject:fedora:29&quot;,\r\n        &quot;cpe:2.3:o:fedoraproject:fedora:30&quot;,\r\n        &quot;cpe:2.3:o:canonical:ubuntu_linux:12.04:-:-:-:esm&quot;,\r\n        &quot;cpe:2.3:o:canonical:ubuntu_linux:14.04:-:-:-:lts&quot;,\r\n        &quot;cpe:2.3:o:canonical:ubuntu_linux:16.04:-:-:-:lts&quot;,\r\n        &quot;cpe:2.3:o:canonical:ubuntu_linux:18.04:-:-:-:lts&quot;,\r\n        &quot;cpe:2.3:o:canonical:ubuntu_linux:18.10&quot;,\r\n        &quot;cpe:2.3:o:redhat:enterprise_linux:7.0&quot;,\r\n        &quot;cpe:2.3:o:opensuse:leap:15.0&quot;,\r\n        &quot;cpe:2.3:o:opensuse:leap:42.3&quot;\r\n      ],\r\n      &quot;vulnerable_configuration_cpe_2_2&quot;: [\r\n        &quot;cpe:/a:apache:http_server:2.4.38&quot;,\r\n        &quot;cpe:/o:debian:debian_linux:8.0&quot;,\r\n        &quot;cpe:/o:debian:debian_linux:9.0&quot;,\r\n        &quot;cpe:/o:fedoraproject:fedora:29&quot;,\r\n        &quot;cpe:/o:fedoraproject:fedora:30&quot;,\r\n        &quot;cpe:/o:canonical:ubuntu_linux:12.04::~~esm~~~&quot;,\r\n        &quot;cpe:/o:canonical:ubuntu_linux:14.04::~~lts~~~&quot;,\r\n        &quot;cpe:/o:canonical:ubuntu_linux:16.04::~~lts~~~&quot;,\r\n        &quot;cpe:/o:canonical:ubuntu_linux:18.04::~~lts~~~&quot;,\r\n        &quot;cpe:/o:canonical:ubuntu_linux:18.10&quot;,\r\n        &quot;cpe:/o:redhat:enterprise_linux:7.0&quot;,\r\n        &quot;cpe:/o:opensuse:leap:15.0&quot;,\r\n        &quot;cpe:/o:opensuse:leap:42.3&quot;\r\n      ]\r\n    }\r\n\r\n\r\nI just want to display all the possible fields in a simple table on the command line but I am not able to achieve it. \r\nI tried the following command \r\n\r\n    echo $(jq &#39;.data[] | select(.vulnerable_configuration_cpe_2_2 | contains([&quot;2.4.38&quot;]))&#39; search1.json) | jq -r &#39;.[] | &quot;\\(.summary)&quot;&#39;\r\n\r\nbut it gives me error \r\n\r\n    jq: error (at &lt;stdin&gt;:1): Cannot index string with string &quot;summary&quot;\r\n\r\n\r\n\r\nI already researched about this and tried modifying this command but it sometimes gives me compilation error. I am sure I am making very stupid mistake somewhere\r\n\r\nExpected Output\r\n\r\n    ID CWE  CVSS  Summary\r\n    xyz xyz xyz    xyzxyzxyz\r\n\r\n",
        "link": "https://stackoverflow.com/questions/57475419/transforming-json-to-table-using-jq-gives-cannot-index-string-error",
        "title": "Transforming json to table using JQ gives &quot;Cannot index string error&quot;"
    },
    {
        "tags": [
            "json",
            "shell",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1565698587,
                "creation_date": 1565698587,
                "answer_id": 57477568,
                "question_id": 57476555,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Assuming that in the result you expect the `environments` object to include both `staging` and `production`, you could use this `jq` command:\r\n\r\n    &lt;file jq &#39;.environments |= (.[] |= {images : (.apps|map(.[]))})&#39;\r\n    {\r\n      &quot;environments&quot;: {\r\n        &quot;staging&quot;: {\r\n          &quot;images&quot;: [\r\n            &quot;image1&quot;\r\n          ]\r\n        },\r\n        &quot;production&quot;: {\r\n          &quot;images&quot;: [\r\n            &quot;image2&quot;,\r\n            &quot;image3&quot;\r\n          ]\r\n        }\r\n      }\r\n    }\r\n\r\n\r\nThis replaces the content of the `environments` object with the a new inner `images` object that contains the list images referred by `apps` and `image`. \r\n\r\nThe array of images is built using the jq builtin `map()` function.",
                "title": "How can I aggregate sub-values into arrays with jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1565698587,
        "creation_date": 1565694734,
        "last_edit_date": 1565696401,
        "question_id": 57476555,
        "body_markdown": "I&#39;m new to `jq` and try to extract the values of the `images` keys into a new key, so that\r\n\r\n```js\r\n{\r\n  &quot;environments&quot;: {\r\n    &quot;staging&quot;: {\r\n      &quot;apps&quot;: {\r\n        &quot;web&quot;: {\r\n          &quot;image&quot;: &quot;image1&quot;\r\n        }\r\n      }\r\n    },\r\n    &quot;production&quot;: {\r\n      &quot;apps&quot;: {\r\n        &quot;web&quot;: {\r\n          &quot;image&quot;: &quot;image2&quot;\r\n        },\r\n        &quot;admin&quot;: {\r\n          &quot;image&quot;: &quot;image3&quot;\r\n        }\r\n      }\r\n    }\r\n  }\r\n}\r\n```\r\n\r\nbecomes something like this:\r\n\r\n```js\r\n{\r\n  &quot;environments&quot;: {\r\n    &quot;staging&quot;: {\r\n      &quot;images&quot;: [\r\n        &quot;image1&quot;\r\n      ]\r\n    }\r\n  },\r\n  &quot;production&quot;: {\r\n    &quot;images&quot;: [\r\n      &quot;image2&quot;,\r\n      &quot;image3&quot;\r\n    ]\r\n  }\r\n}\r\n```\r\n\r\nI&#39;ve been fiddling around with `jq` for a while now, could anyone give me a hint?\r\n",
        "link": "https://stackoverflow.com/questions/57476555/how-can-i-aggregate-sub-values-into-arrays-with-jq",
        "title": "How can I aggregate sub-values into arrays with jq?"
    },
    {
        "tags": [
            "json",
            "bash",
            "azure-devops",
            "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": 1565715315,
                "post_id": 57477317,
                "comment_id": 101435817,
                "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": 1565715478,
                "post_id": 57477317,
                "comment_id": 101435903,
                "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": 1565715506,
                "post_id": 57477317,
                "comment_id": 101435923,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 15535508,
                    "reputation": 445,
                    "user_id": 11207803,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/-FJ4WGmO0jKs/AAAAAAAAAAI/AAAAAAAAAAA/ACHi3rellG-NbGxyx1QYHIwx94nRxx6j2g/mo/s256-rj/photo.jpg",
                    "display_name": "AK123",
                    "link": "https://stackoverflow.com/users/11207803/ak123"
                },
                "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": 1565716102,
                "post_id": 57477317,
                "comment_id": 101436152,
                "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": 1565716202,
                "post_id": 57477317,
                "comment_id": 101436199,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 1,
        "last_activity_date": 1565714323,
        "creation_date": 1565697622,
        "last_edit_date": 1565714323,
        "question_id": 57477317,
        "body_markdown": "I have to replace a value in a json file with the value of a bash variable.\r\nThis is the sample json.\r\n\r\n    {   &quot;swagger&quot;: &quot;2.0&quot;,   &quot;info&quot;: {\r\n      &quot;title&quot;: &quot;DataSyncGtest&quot;,\r\n      &quot;version&quot;: &quot;2.0&quot;,\r\n      &quot;description&quot;: &quot;Lorem,ipsum,dorem&quot;   },   &quot;host&quot;: &quot;stg.api.realogyfg.com&quot;,   &quot;basePath&quot;: &quot;/v2/xxx/yyy/Newproxytest&quot; \r\n    }\r\n\r\nI used the below command and was able to replace the value of the basePath(Thanks to @Cyrus for pointing me with the right answers that helped). \r\nCommand:\r\n\r\n    foo=/v1/proxytest\r\n    cat $NAME | jq --arg foo &quot;$foo&quot; &#39;.basePath = $foo&#39;  &gt; test.json\r\n\r\nBut am doing this from a bash task in Azure DevOps and it adds the below instead of just the value of the variable. I&#39;m not sure how this can be avoided.\r\n\r\n    {\r\n      &quot;swagger&quot;: &quot;2.0&quot;,\r\n      &quot;info&quot;: {\r\n        &quot;title&quot;: &quot;DataSyncGtest&quot;,\r\n        &quot;version&quot;: &quot;2.0&quot;,\r\n        &quot;description&quot;: &quot;blah&quot;\r\n      },\r\n      &quot;host&quot;: &quot;stg.api.realogyfg.com&quot;,\r\n      &quot;basePath&quot;: &quot;C:/Program Files/Git/v1/proxytest&quot;,\r\n    }",
        "link": "https://stackoverflow.com/questions/57477317/replacing-value-in-a-json-file-using-jq-azure-devops-bash-task-adds-random-data",
        "title": "Replacing value in a json file using jq Azure DevOps Bash task adds random data"
    },
    {
        "tags": [
            "json",
            "filter",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1565708845,
                "last_edit_date": 1565708845,
                "creation_date": 1565707867,
                "answer_id": 57480315,
                "question_id": 57480055,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This should do it:\r\n```\r\n[..|objects|.commit.committer//empty]\r\n```\r\n\r\n- [Recursive Descent: `..`](https://stedolan.github.io/jq/manual/#RecursiveDescent:..),\r\n- [`objects`](https://stedolan.github.io/jq/manual/#arrays,objects,iterables,booleans,numbers,normals,finites,strings,nulls,values,scalars),\r\n- [Alternative Operator: `//`](https://stedolan.github.io/jq/manual/#Alternativeoperator://),\r\n- [`empty`](https://stedolan.github.io/jq/manual/#empty).",
                "title": "jq: Filter by node at arbitrary place"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1565788118,
                "last_edit_date": 1565788118,
                "creation_date": 1565707893,
                "answer_id": 57480319,
                "question_id": 57480055,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The function you&#39;re looking for is `..` (that is an alias to the `recurse` function).\r\n\r\nYou can use it like this:\r\n\r\n    curl -s &#39;https://api.github.com/repos/stedolan/jq/commits?per_page=5&#39; \\\r\n       |jq &#39;map(..|.commit?.committer//empty)&#39; \r\n\r\nThe `..` function goes recursively through the whole JSON path returning every single element.\r\n\r\nThe `.commit?` looks for fields with name `commit` and drop the other.\r\n\r\nThe last part selects the `committer` object and do not show `null` if there isn&#39;t any.",
                "title": "jq: Filter by node at arbitrary place"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1666590595,
        "creation_date": 1565707050,
        "last_edit_date": 1666590595,
        "question_id": 57480055,
        "body_markdown": "JSONPath has an expression to filter by node at arbitrary place `$..node`, which like `//node` in `xpath`. Is there any way to do that in `jq`?\r\n\r\nUsing https://stedolan.github.io/jq/tutorial/#result5 as example\r\n\r\n`$ curl -s &#39;https://api.github.com/repos/stedolan/jq/commits?per_page=5&#39;`\r\n\r\nHere is the data &amp; result for JSONPath `$..commit.committer`:\r\n\r\n[![enter image description here][1]][1]\r\n\r\nHow to do the same in (/translate to) `jq`?\r\n\r\n  [1]: https://i.sstatic.net/iPDVV.png",
        "link": "https://stackoverflow.com/questions/57480055/jq-filter-by-node-at-arbitrary-place",
        "title": "jq: Filter by node at arbitrary place"
    },
    {
        "tags": [
            "json",
            "jq",
            "jmespath"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1565752730,
                "creation_date": 1565752730,
                "answer_id": 57487763,
                "question_id": 57481891,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "**UPDATE :**\r\n\r\nThe solution is to use ***values(@)***.\r\n\r\nReference link \r\nhttps://github.com/jmespath/jmespath.site/issues/24\r\n\r\n\r\nSo one of the possible solution for the above ask is \r\n\r\n```\r\npeople.values(@)[?starts_with(First,`J`)].last\r\n\r\n```\r\n\r\nSo for any variable key , we can use values(@) to filter projections further down the structure.",
                "title": "JSON parsing using String Condition with JMESPATH"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1566293000,
        "creation_date": 1565713809,
        "last_edit_date": 1566293000,
        "question_id": 57481891,
        "body_markdown": "I am facing an issue with parsing a json using Jmespath based on a string condition. I would want to get values of a key based on condition on string value of another key. Both of them are in same hierarchy of a given dictionary. However , the parent key of the dictionary is a variable.I am familiar with jq but jmespath is new to me. I am using it , as the current project depends on it. Hence no much choice on changing the parser.\r\n\r\nSample Json below :-\r\n\r\n```\r\n{\r\n  &quot;people&quot;: {\r\n    &quot;a&quot;: {&quot;First&quot;:&quot;James&quot;, &quot;last&quot;: &quot;1&quot;},\r\n    &quot;b&quot;: {&quot;First&quot;:&quot;Jacob&quot;, &quot;last&quot;: &quot;2&quot;},\r\n    &quot;c&quot;: {&quot;First&quot;:&quot;Jayden&quot;, &quot;last&quot;: &quot;3&quot;},\r\n    &quot;d&quot;: {&quot;First&quot;:&quot;different&quot;, &quot;last&quot; : &quot;4&quot;}\r\n  }\r\n}\r\n```\r\n\r\nI would want to get the last&#39;s value where First&#39;s value starts with &quot;J&quot;.\r\n\r\nI have tried referring to articles provided in official site at http://jmespath.org/tutorial.html. However , most of them concentrate on a standard key structure and not much on a variable key dictionary structure. Hence am unable to write a jmespath query for a given json.\r\n\r\nThe jq equivalent for achieving the intended result is given below :-\r\n```\r\n.people | .[] | select (.First | startswith(&quot;J&quot;)) | .last\r\n```\r\nThe closest jmespath query , that I could logically arrive at based on my understanding is  :-\r\n\r\n```\r\npeople.*[?starts_with(First,`J`)].last\r\n```\r\n\r\nHowever , the above query returns blank result.\r\n\r\nExpected output is \r\n\r\n```\r\n &quot;d&quot;,&quot;e&quot;,&quot;f&quot;\r\n```\r\n\r\nI am unable to understand where I am going wrong. \r\nIt would be nice if someone can point me to a good article or help me find the solution to the above issue.\r\n\r\nThanks alot",
        "link": "https://stackoverflow.com/questions/57481891/json-parsing-using-string-condition-with-jmespath",
        "title": "JSON parsing using String Condition with JMESPATH"
    },
    {
        "tags": [
            "json",
            "key",
            "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"
                },
                "reply_to_user": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1565763197,
                "post_id": 57488844,
                "comment_id": 101448424,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "reply_to_user": {
                    "account_id": 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": 1565763517,
                "post_id": 57488844,
                "comment_id": 101448552,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "reply_to_user": {
                    "account_id": 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": 1565763882,
                "post_id": 57488844,
                "comment_id": 101448680,
                "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": 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": 1565764280,
                "post_id": 57488844,
                "comment_id": 101448813,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 10,
                "is_accepted": true,
                "score": 10,
                "last_activity_date": 1565763471,
                "creation_date": 1565763471,
                "answer_id": 57489062,
                "question_id": 57488844,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "There are several possible interpretations of the Q.\r\n\r\nA simple approach that will solve the simplest interpretation would be to use:\r\n\r\n    map_values(del(.summary))\r\n\r\nIf you want to eliminate the &quot;summary&quot; field wherever it occurs, no matter how deeply nested, then I&#39;d use `walk/1`, e.g.\r\n\r\n    walk(if type == &quot;object&quot; then del(.summary) else . end)\r\n\r\n",
                "title": "Deleting a field in nested objects in JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 6,
        "last_activity_date": 1565818775,
        "creation_date": 1565762131,
        "last_edit_date": 1565768763,
        "question_id": 57488844,
        "body_markdown": "I have a JSON lines file with `summary` fields and other fields.  I would like to delete all of the summary fields using JQ.  This is my input:\r\n\r\n    {&quot;object1&quot;: {&quot;summary&quot;:&quot;Some summary I want removing&quot;, &quot;keepMe&quot;:&quot;please&quot;}}\r\n    {&quot;object2&quot;: {&quot;summary&quot;:&quot;Delete me too!&quot;, &quot;keepMe&quot;:&quot;pretty please&quot;}}\r\n\r\nand this is the desired output:\r\n\r\n    {&quot;object1&quot;: {&quot;keepMe&quot;:&quot;please&quot;}}\r\n    {&quot;object2&quot;: {&quot;keepMe&quot;:&quot;pretty please&quot;}}",
        "link": "https://stackoverflow.com/questions/57488844/deleting-a-field-in-nested-objects-in-jq",
        "title": "Deleting a field in nested objects in JQ"
    },
    {
        "tags": [
            "string",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1565792260,
                "creation_date": 1565792260,
                "answer_id": 57496523,
                "question_id": 57496298,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`abcdefghi` is not a valid JSON string, but `&quot;abcdefghi&quot;` is:\r\n\r\n    $ jq &#39;.[2:4]&#39; &lt;&lt;&lt; &#39;&quot;abcdefghi&quot;&#39;\r\n    &quot;cd&quot;\r\n\r\nIf you look at the [jq play example][1] linked from the manual, you&#39;ll see the double quoted input.\r\n\r\n\r\n  [1]: https://jqplay.org/jq?q=.%5B2%3A4%5D&amp;j=%22abcdefghi%22",
                "title": "Error in jq manual `jq &#39;.[2:4]&#39; &lt;&lt;&lt; abcdefghi`?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1565805767,
        "creation_date": 1565791462,
        "last_edit_date": 1565805767,
        "question_id": 57496298,
        "body_markdown": "The manual says\r\n\r\n```\r\njq &#39;.[2:4]&#39;\r\n   &quot;abcdefghi&quot;\r\n=&gt; &quot;cd&quot;\r\n```\r\n\r\nBut a run of `jq` prints this:\r\n\r\n```\r\n$ jq &#39;.[2:4]&#39; &lt;&lt;&lt; abcdefghi\r\nparse error: Invalid numeric literal at line 2, column 0\r\n```\r\n\r\n Is the manual wrong? Or there is a bug in the program?",
        "link": "https://stackoverflow.com/questions/57496298/error-in-jq-manual-jq-24-abcdefghi",
        "title": "Error in jq manual `jq &#39;.[2:4]&#39; &lt;&lt;&lt; abcdefghi`?"
    },
    {
        "tags": [
            "docker",
            "dockerfile",
            "jq",
            "aws-cli",
            "hasura"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 467927,
                    "reputation": 4427,
                    "user_id": 873601,
                    "user_type": "registered",
                    "accept_rate": 89,
                    "profile_image": "https://i.sstatic.net/u1Onm.jpg?s=256",
                    "display_name": "Vishal Biyani",
                    "link": "https://stackoverflow.com/users/873601/vishal-biyani"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1565792462,
                "post_id": 57496552,
                "comment_id": 101462923,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 12695509,
                    "reputation": 1019,
                    "user_id": 9224067,
                    "user_type": "registered",
                    "accept_rate": 83,
                    "profile_image": "https://www.gravatar.com/avatar/59f1703060c144de8b186c3c6b1fc938?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "thotam",
                    "link": "https://stackoverflow.com/users/9224067/thotam"
                },
                "reply_to_user": {
                    "account_id": 467927,
                    "reputation": 4427,
                    "user_id": 873601,
                    "user_type": "registered",
                    "accept_rate": 89,
                    "profile_image": "https://i.sstatic.net/u1Onm.jpg?s=256",
                    "display_name": "Vishal Biyani",
                    "link": "https://stackoverflow.com/users/873601/vishal-biyani"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1565792560,
                "post_id": 57496552,
                "comment_id": 101462980,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2324284,
                    "reputation": 1908,
                    "user_id": 2039150,
                    "user_type": "registered",
                    "accept_rate": 75,
                    "profile_image": "https://i.sstatic.net/i2oUI.jpg?s=256",
                    "display_name": "Md Hasan Ibrahim",
                    "link": "https://stackoverflow.com/users/2039150/md-hasan-ibrahim"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1565794994,
                "post_id": 57496552,
                "comment_id": 101464347,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 12695509,
                    "reputation": 1019,
                    "user_id": 9224067,
                    "user_type": "registered",
                    "accept_rate": 83,
                    "profile_image": "https://www.gravatar.com/avatar/59f1703060c144de8b186c3c6b1fc938?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "thotam",
                    "link": "https://stackoverflow.com/users/9224067/thotam"
                },
                "reply_to_user": {
                    "account_id": 2324284,
                    "reputation": 1908,
                    "user_id": 2039150,
                    "user_type": "registered",
                    "accept_rate": 75,
                    "profile_image": "https://i.sstatic.net/i2oUI.jpg?s=256",
                    "display_name": "Md Hasan Ibrahim",
                    "link": "https://stackoverflow.com/users/2039150/md-hasan-ibrahim"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1565796807,
                "post_id": 57496552,
                "comment_id": 101465377,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 6,
                "is_accepted": true,
                "score": 6,
                "last_activity_date": 1565881117,
                "creation_date": 1565881117,
                "answer_id": 57511662,
                "question_id": 57496552,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I was able to customize Hasura Docker Image with the help of Hasura Team support.\r\n\r\nHere is the link to github issue: https://github.com/hasura/graphql-engine/issues/2729\r\n\r\nDockerfile:\r\n```\r\nFROM hasura/graphql-engine:v1.0.0-beta.4 as base\r\n\r\nFROM python:3.7-slim-stretch\r\n\r\nRUN apt-get -y update \\\r\n    &amp;&amp; apt-get install -y --no-install-recommends libpq-dev jq \\\r\n    &amp;&amp; rm -rf /var/lib/apt/lists/* \\\r\n    &amp;&amp; rm -rf /usr/share/doc/ \\\r\n    &amp;&amp; rm -rf /usr/share/man/ \\\r\n    &amp;&amp; rm -rf /usr/share/locale/ \\\r\n    &amp;&amp; pip install awscli\r\n\r\n# copy hausra binary from base container\r\nCOPY --from=base /bin/graphql-engine /bin/graphql-engine\r\n\r\nCOPY entrypoint.sh /entrypoint.sh\r\nRUN chmod +x /entrypoint.sh\r\nCMD [&quot;/entrypoint.sh&quot;]\r\n```\r\nentrypoint.sh:\r\n\r\n```\r\n#!/bin/bash\r\nset -e\r\n\r\nDB_HOST=${DB_HOST:-postgres}\r\nDB_PORT=${DB_PORT:-5432}\r\nAWS_REGION=${AWS_REGION:-us-east-1}\r\nDB_PASSWORD_ENCYPTED=${DB_PASSWORD_ENCYPTED:-false}\r\n\r\nif [ -z &quot;${DB_NAME}&quot; ]; then\r\n   echo &quot;Must provide DB_NAME environment variable. Exiting....&quot;\r\n   exit 1\r\nfi\r\n\r\nif [ -z &quot;${DB_USER}&quot; ]; then\r\n   echo &quot;Must provide DB_USER environment variable. Exiting....&quot;\r\n   exit 1\r\nfi\r\n\r\nif [ -z &quot;${DB_PASSWORD}&quot; ]; then\r\n   echo &quot;Must provide DB_PASSWORD environment variable. Exiting....&quot;\r\n   exit 1\r\nfi\r\n\r\nif [ ${DB_PASSWORD_ENCYPTED} == &quot;true&quot; ]\r\nthen\r\n    echo &quot;loading KMS credentials&quot;\r\n    decrypted_value_base64=$( \\\r\n        aws --region ${AWS_REGION} kms decrypt \\\r\n          --ciphertext-blob fileb://&lt;(echo &quot;${DB_PASSWORD}&quot; | base64 -d) \\\r\n          --query Plaintext \\\r\n          --output text\r\n    )\r\n    decrypted_value=$(echo $decrypted_value_base64 | base64 -d)\r\n    export HASURA_GRAPHQL_DATABASE_URL=postgres://${DB_USER}:${decrypted_value}@${DB_HOST}:${DB_PORT}/${DB_NAME}\r\nelse\r\n    export HASURA_GRAPHQL_DATABASE_URL=postgres://${DB_USER}:${DB_PASSWORD}@${DB_HOST}:${DB_PORT}/${DB_NAME}\r\nfi\r\n\r\n/bin/graphql-engine  serve\r\n```\r\n",
                "title": "Customize Hasura Docker Image"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1565881117,
        "creation_date": 1565792355,
        "last_edit_date": 1565796767,
        "question_id": 57496552,
        "body_markdown": "I have a need to install awscli and jq library in Hasura Docker Image. I tried to use yum, apt-get or apk commands to install the dependencies, but none of them worked. \r\n\r\nDocker Image: https://hub.docker.com/r/hasura/graphql-engine/\r\n\r\nhow to install these dependencies in Hasura Docker Image? Any help is appreciated.\r\n\r\nDockerfile:\r\n\r\n    FROM hasura/graphql-engine:latest\r\n\r\n    COPY entrypoint.sh /entrypoint.sh\r\n    RUN chmod +x /entrypoint.sh\r\n\r\n    CMD [&quot;./entrypoint.sh&quot;]\r\n\r\nentrypoint.sh:\r\n\r\n``` \r\n#!/bin/sh\r\nset -o errexit -o nounset -o pipefail\r\n\r\nDB_HOST=${DB_HOST:-postgres}\r\nDB_PORT=${DB_PORT:-5432}\r\n\r\nif [ -z &quot;${DB_NAME}&quot; ]; then\r\n   echo &quot;Must provide DB_NAME environment variable. Exiting....&quot;\r\n   exit 1\r\nfi\r\n\r\nif [ -z &quot;${DB_USER}&quot; ]; then\r\n   echo &quot;Must provide DB_USER environment variable. Exiting....&quot;\r\n   exit 1\r\nfi\r\n\r\nif [ -z &quot;${DB_PASSWORD}&quot; ]; then\r\n   echo &quot;Must provide DB_PASSWORD environment variable. Exiting....&quot;\r\n   exit 1\r\nfi\r\n\r\nexport HASURA_GRAPHQL_DATABASE_URL=postgres://${DB_USER}:${DB_PASSWORD}@${DB_HOST}:${DB_PORT}/${DB_NAME}\r\n\r\n\r\n/bin/graphql-engine  serve\r\n```\r\n\r\n**DB_PASSWORD** is encrypted with KMS, so i want to use aws cli to decrypt the password in entrypoint.sh file before setting the Environment Variable: **HASURA_GRAPHQL_DATABASE_URL**",
        "link": "https://stackoverflow.com/questions/57496552/customize-hasura-docker-image",
        "title": "Customize Hasura Docker Image"
    },
    {
        "tags": [
            "jq",
            "multipart-alternative"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1565806124,
                "last_edit_date": 1565806124,
                "creation_date": 1565800190,
                "answer_id": 57498681,
                "question_id": 57498621,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use alternate operator (`//`):\r\n```\r\n$ jq &#39;.[] | .a//.b&#39; &lt;&lt;&lt; &#39;[{&quot;a&quot;: 1},  {&quot;b&quot;: 2}]&#39;\r\n1\r\n2\r\n```",
                "title": "How to perform `or` in jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1565806124,
        "creation_date": 1565799941,
        "last_edit_date": 1565805158,
        "question_id": 57498621,
        "body_markdown": "I got the following results.\r\n\r\n```\r\n$ jq &#39;.[].a,.[].b&#39; &lt;&lt;&lt; &#39;[{&quot;a&quot;: 1},  {&quot;b&quot;: 2}]&#39;\r\n1\r\nnull\r\nnull\r\n2\r\n$ jq &#39;.[] | select(.a or .b)&#39; &lt;&lt;&lt; &#39;[{&quot;a&quot;: 1},  {&quot;b&quot;: 2}]&#39;\r\n{\r\n  &quot;a&quot;: 1\r\n}\r\n{\r\n  &quot;b&quot;: 2\r\n}\r\n```\r\n\r\n\r\nBut I want to search either &quot;a&quot; and &quot;b&quot; and the output that I would like is this.\r\n\r\n```\r\n1\r\n2\r\n```\r\n\r\n\r\nWhat is the proper way to perform this `or` operation? Thanks.",
        "link": "https://stackoverflow.com/questions/57498621/how-to-perform-or-in-jq",
        "title": "How to perform `or` in jq?"
    },
    {
        "tags": [
            "json",
            "jenkins",
            "jenkins-pipeline",
            "jq",
            "jenkins-groovy"
        ],
        "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": 1565826330,
                "post_id": 57503166,
                "comment_id": 101475369,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9419261,
                    "reputation": 1154,
                    "user_id": 7006096,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/9493579e0b544f4f26870f48ba13a6b8?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "nevosial",
                    "link": "https://stackoverflow.com/users/7006096/nevosial"
                },
                "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": 1565828555,
                "post_id": 57503166,
                "comment_id": 101475743,
                "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": 1565831101,
                "post_id": 57503166,
                "comment_id": 101476109,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1565830748,
                "creation_date": 1565830748,
                "answer_id": 57503717,
                "question_id": 57503166,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This was solved by writing a helper function that uses the JsonSurplerClassic() to convert the string to json.\r\n\r\n    def make_json(string_val){\r\n       def jsonmaker = new JsonSlurperClassic()\r\n       def jsonval = jsonmaker.parseText(string_val)\r\n       println jsonval.getClass()\r\n       return jsonval\r\n    }\r\n\r\n**Notes:**\r\n\r\n - This helper is using `JsonSlurperClassic()` as it creates a hashmap\r\n        and avoids the jenkins `NotSerializableException` exception if we\r\n        use the `JsonSurpler()`\r\n - Secondly calling this helper solved the jenkins exception error rather than writing it inside the `withAWS...` block.\r\n\r\nFollowing worked :\r\n\r\n```\r\nwithAWS(credentials: aws_env_credential){\r\n    efs_details = sh(\r\n    script: &quot;aws efs describe-file-systems --region=&#39;${aws_region_for_cluster}&#39; | jq --arg efs_name ${efs_name} &#39;.[] | .[] | select(.Name==$efs_name)&#39;&quot;,\r\n    encoding: &#39;UTF-8&#39;,\r\n    returnStdout: true\r\n    )\r\n    efs_details_json = make_json(efs_details)\r\n    }\r\n  \r\n```\r\n\r\nCan now use the dot operators,\r\n```\r\nefs_details_json.name\r\nefs_details_json.OwnerId\r\n...\r\n```\r\n\r\nHope this helps other(me in future) to save time for more non-trivial items.\r\n \r\n\r\n \r\n\r\n \r\n\r\n \r\n\r\n ",
                "title": "Using jq with Jenkins pipeline"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1751720640,
        "creation_date": 1565824846,
        "question_id": 57503166,
        "body_markdown": "In my use case i&#39;m running a pipeline which calls aws cli via the withAWS plugin. I use jq to get the needed data, Now the sh returns the output as String. How do i convert this output to json object ?\r\n\r\n    withAWS(credentials: aws_env_credential){\r\n        efs_details = sh(\r\n        script: &quot;aws efs describe-file-systems --region=&#39;${aws_region_for_cluster}&#39; | jq --arg efs_name ${efs_name} &#39;.[] | .[] | select(.Name==$efs_name)&#39;&quot;,\r\n        encoding: &#39;UTF-8&#39;,\r\n        returnStdout: true\r\n        )  \r\n\r\nOutput:\r\nefs_details:\r\n\r\n    {\r\n     &quot;OwnerId: &quot;2142342325&quot;,\r\n     &quot;name&quot;: &quot;my_volume&quot;,\r\n     &quot;encrypted&quot;: true,\r\n     ...\r\n    }\r\n\r\n\r\nhere `efs_details` is a `java.lang.String` type.\r\n\r\nQ: How do i convert this output to json so that i can use the dot operator. (example `efs_details.name`)",
        "link": "https://stackoverflow.com/questions/57503166/using-jq-with-jenkins-pipeline",
        "title": "Using jq with Jenkins pipeline"
    },
    {
        "tags": [
            "json",
            "export-to-csv",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1565887001,
                "last_edit_date": 1565887001,
                "creation_date": 1565836631,
                "answer_id": 57504245,
                "question_id": 57504189,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With your sample JSON, the invocation:\r\n\r\n\r\n    jq -r &#39;\r\n      .results[]\r\n      | [.name, .DOB, .Enrollmentdate ]\r\n      | @csv&#39;\r\n\r\nproduces:\r\n```\r\n&quot;smith Jones&quot;,&quot;1992-03-26&quot;,&quot;2013-08-24&quot;\r\n&quot;Jacob Mathew&quot;,&quot;1993-03-26&quot;,&quot;2014-10-02&quot;\r\n&quot;Anita Rodrigues&quot;,&quot;1994-03-26&quot;,&quot;2015-02-19&quot;\r\n```\r\n\r\nIf you don&#39;t want the (in this case) superfluous quotation marks, you could replace `@csv` by `join(&quot;,&quot;)` but it would be better to write a simple filter to take care of values with commas, etc.\r\n \r\n## Headers\r\nIf the first result has the keys in the correct order, you could get away with:\r\n```\r\n  (.results[0] | keys_unsorted),\r\n  (.results[]\r\n  | [.name, .DOB, .Enrollmentdate ])\r\n  | @csv\r\n```\r\n\r\nBut it would probably be better to use a bit of jq magic along the lines of the following:\r\n\r\n```\r\n  (.results[0] | keys_unsorted) as $headers\r\n  | $headers,\r\n    (.results[]\r\n     | [getpath($headers[]|[.])])\r\n  | @csv\r\n```\r\n ",
                "title": "Parse json output using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1565887001,
        "creation_date": 1565836029,
        "last_edit_date": 1565837003,
        "question_id": 57504189,
        "body_markdown": "Firstly,thank you so much for your support.\r\n\r\nI have trouble parsing a json output into csv format. I was able to get some kind of output but that does not meet the expectation.\r\n\r\n    \r\n\r\nCurl Command output \r\n\r\n    {\r\n        &quot;results&quot;: [{\r\n                &quot;name&quot;: &quot;smith Jones&quot;,\r\n                &quot;DOB&quot;: &quot;1992-03-26&quot;,\r\n                &quot;Enrollmentdate&quot;: &quot;2013-08-24&quot;\r\n    \r\n            },\r\n    \r\n            {\r\n                &quot;name&quot;: &quot;Jacob Mathew&quot;,\r\n                &quot;DOB&quot;: &quot;1993-03-26&quot;,\r\n                &quot;Enrollmentdate&quot;: &quot;2014-10-02&quot;\r\n            },\r\n    \r\n            {\r\n                &quot;name&quot;: &quot;Anita Rodrigues&quot;,\r\n                &quot;DOB&quot;: &quot;1994-03-26&quot;,\r\n                &quot;Enrollmentdate&quot;: &quot;2015-02-19&quot;\r\n            }\r\n        ]\r\n    }\r\n\r\nJQ commond used\r\n\r\n    &lt;curl-command&gt;|jq &#39;.results | map(.name), map(.DOB), map(.Enrollmentdate) | @csv&#39; &gt;file.csv\r\n\r\n\r\nMy Output\r\n\r\n    smith jones, Jacob Mathew, Anita Rodrigues\r\n    1992-03-26, 1993-03-26, 1994-03-26\r\n    2013-08-24, 2014-10-02, 2015-02-19 \r\n\r\n\r\nThis might not be csv exactly but below is the expected output.\r\n\r\n    Name                 DOB             Enrollmentdate\r\n    smith jones,       1992-03-26,        2013-08-24\r\n    jacob Mathew,      1993-03-26,        2014-10-02\r\n    Anitha Rodrigues,  1994-03-26,        2015-02-19",
        "link": "https://stackoverflow.com/questions/57504189/parse-json-output-using-jq",
        "title": "Parse json output using jq"
    },
    {
        "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": 1,
                "creation_date": 1565881957,
                "post_id": 57510859,
                "comment_id": 101491889,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "reply_to_user": {
                    "account_id": 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": 1565906371,
                "post_id": 57510859,
                "comment_id": 101501303,
                "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": 1565983770,
                "post_id": 57510859,
                "comment_id": 101526283,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 141904,
                    "reputation": 2321,
                    "user_id": 349268,
                    "user_type": "registered",
                    "accept_rate": 78,
                    "profile_image": "https://i.sstatic.net/nPuwD.jpg?s=256",
                    "display_name": "rs79",
                    "link": "https://stackoverflow.com/users/349268/rs79"
                },
                "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": 1566408057,
                "post_id": 57510859,
                "comment_id": 101650133,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1663855471,
                "last_edit_date": 1663855471,
                "creation_date": 1663528554,
                "answer_id": 73765758,
                "question_id": 57510859,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The following jq invocation seems to give your expected output:\r\n\r\n```\r\njq -sc &#39;.[]\r\n  | group_by(.)[]\r\n  | select(length &gt; 1)\r\n  | { key: first|tostring, value: length }&#39;\r\n```\r\n\r\nOutput:\r\n\r\n```json\r\n{&quot;key&quot;:&quot;{\\&quot;key2\\&quot;:\\&quot;value2\\&quot;}&quot;,&quot;value&quot;:2}\r\n```",
                "title": "Checking for duplicate values within JSON array elements"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1663855471,
        "creation_date": 1565877698,
        "question_id": 57510859,
        "body_markdown": "I have the following test.json file:\r\n\r\n    [{&quot;key1&quot;:&quot;value1&quot;},{&quot;key2&quot;:&quot;value2&quot;},{&quot;key2&quot;:&quot;value2&quot;}]\r\n    [{&quot;key1&quot;:&quot;value1&quot;},{&quot;key2&quot;:&quot;value2&quot;}]\r\n\r\nIn this, I need to check for duplication only within the array element.\r\n\r\nSo far, I&#39;ve tried \r\n\r\n    cat test.json | jq -n &#39;reduce (inputs|.[]|tostring) as $id ({}; .[$id] += 1) | to_entries[] | select(.value &gt; 1)&#39;\r\n\r\nThis outputs the following: \r\n\r\n    {&quot;key&quot;: &quot;{\\&quot;key1\\&quot;:\\&quot;value1\\&quot;}&quot;,&quot;value&quot;: 2}\r\n    {&quot;key&quot;: &quot;{\\&quot;key2\\&quot;:\\&quot;value2\\&quot;}&quot;,&quot;value&quot;: 3}\r\n\r\nI just need to report\r\n\r\n    {&quot;key&quot;: &quot;{\\&quot;key2\\&quot;:\\&quot;value2\\&quot;}&quot;,&quot;value&quot;: 2}\r\n\r\nEssentially, `&quot;key2&quot;:&quot;value2&quot;` is duplicated only within the array and not across the array elements\r\n",
        "link": "https://stackoverflow.com/questions/57510859/checking-for-duplicate-values-within-json-array-elements",
        "title": "Checking for duplicate values within JSON array elements"
    },
    {
        "tags": [
            "arrays",
            "json",
            "bash",
            "nested",
            "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": 1565878974,
                "post_id": 57510887,
                "comment_id": 101490436,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1565888062,
                "creation_date": 1565888062,
                "answer_id": 57513284,
                "question_id": 57510887,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "1. Using your pastebin JSON as input, and commenting-out the line beginning with `//` and the line beginning with `read`, your script actually runs to completion.\r\n\r\n2. Since `comments` is an array, writing `.comments[]` as you have done is a bit risky, as .comments might not have exactly one element.  It would be less risky to write `.comments[0]`, if that is in accordance with your requirements.\r\n\r\n3. Your script invokes jq five times, but it would not take much effort to modify it so that jq was only called once. For some ideas on how this could be done, see e.g. https://stackoverflow.com/questions/41966417/extract-2-values-from-json-object-and-use-as-variables-in-loop-using-jq-and-bash\r\n\r\n",
                "title": "How to get JQ name/value pair from nested (array?) response?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1566001423,
        "creation_date": 1565877814,
        "last_edit_date": 1566001423,
        "question_id": 57510887,
        "body_markdown": "I am looping through a JSON response file and succeed to store Name/Value pairs per iteration. I fail though due to my inexperience to correctly adjust my filter to access a nested array, part of the response. I need some guidance setting the correct JQ filter\r\n\r\nThe purpose is to loop through the response of a WEB-API curl command. In my case issues created in SonarQube and based of the existence of a specific comment, to create a JIRA ticket or not (not part of example).\r\n\r\n```bash\r\n#!/usr/bin/env bash\r\nSQIssues=$(curl --user user:pass https://sonarqube.domain.nl/api/issues/search?additionalFields=comments&amp;statuses=OPEN&amp;types=BUG&amp;branch=master&amp;componentKeys=project)\r\nfor k in $(jq &#39;.issues | keys | .[]&#39; &lt;&lt;&lt; &quot;$SQIssues&quot;); do\r\n        key=$(jq -r &quot;.issues[$k].key&quot; &lt;&lt;&lt; &quot;$SQIssues&quot;);\r\n        status=$(jq -r &quot;.issues[$k].status&quot; &lt;&lt;&lt; &quot;$SQIssues&quot;);\r\n\t\t// TWO LINES BELOW NOT-OK\r\n        comuser=$(jq -r &quot;.issues[$k] | .comments[].login&quot; &lt;&lt;&lt; &quot;$SQIssues&quot;);\r\n        com=$(jq -r &quot;.issues[$k] .comments[].markdown&quot; &lt;&lt;&lt; &quot;$SQIssues&quot;);\r\n        echo key=&quot;$key&quot; and status=&quot;$status&quot; and comment=&quot;$com&quot; by user=&quot;$comuser&quot;;\r\n        read -n 1 -s -r -p &quot;Press any key to continue&quot;;\r\ndone\r\n```\r\nReponse (KEY and STATUS are grabbed correctly):\r\n```\r\nPress any key to continuekey=AWySAdI5-U8iL73rOJWx; and status=OPEN and comment= by user=\r\nPress any key to continuekey=AWyMy9EK-U8iL73rOI-c; and status=OPEN and comment= by user=\r\nPress any key to continuekey=AWyMy9Er-U8iL73rOI-d; and status=OPEN and comment= by user=\r\n```\r\n\r\nI succeed to get the N/V pairs on a specific level. I fail to get the N/V pairs from the &quot;comments&quot; array existing on the same level as e.g. &quot;key&quot; or &quot;status&quot;\r\n\r\nOK =\r\n```\r\nISSUES\r\n-- KEY=xx\r\n-- STATUS=xx\r\n```\r\nNOK = (n/v under comments, one level deeper)\r\n```\r\nISSUES\r\n-- Comments\r\n--- KEY=xx\r\n--- MARKDOWN=xx\r\n```\r\n\r\nI assume &quot;comments&quot; is an array. I try to store e.g. markdown value during my loop.\r\n\r\nExample SQ response body I am trying to work with (sample input) &quot;**$SQIssues**&quot;\r\nThis is a snippit from the complete response, posted on pastebin: https://pastebin.com/MNubhfWM\r\n```json\r\n{\r\nkey: &quot;AWtQSFvOvmpNDcmJ7zeY&quot;,\r\nrule: &quot;javascript:S930&quot;,\r\nseverity: &quot;CRITICAL&quot;,\r\ncomponent: &quot;path/to/file.js&quot;,\r\nproject: &quot;project-name&quot;,\r\nline: 350,\r\nhash: &quot;9a8c7b5d9121757995511514602d1fd3&quot;,\r\ntextRange: {},\r\nflows: [],\r\nstatus: &quot;OPEN&quot;,\r\nmessage: &quot;This function expects no arguments, but 1 was provided.&quot;,\r\neffort: &quot;10min&quot;,\r\ndebt: &quot;10min&quot;,\r\nauthor: &quot;user@domain.nl&quot;,\r\ntags: [],\r\ncomments: [\r\n{\r\nkey: &quot;AWxxXwIoRqbStspvKH2w&quot;,\r\nlogin: &quot;lmolenaar&quot;,\r\nhtmlText: &quot;&lt;a href=&quot;https://jira.domain.nl/browse/xxx-30093&quot; target=&quot;_blank&quot;&gt;https://jira.domain.nl/browse/xxx-30093&lt;/a&gt;&quot;,\r\nmarkdown: &quot;https://jira.domain.nl/browse/xxx-30093&quot;,\r\nupdatable: true,\r\ncreatedAt: &quot;2019-08-08T15:15:47+0200&quot;\r\n}\r\n],\r\ncreationDate: &quot;2019-06-04T11:33:28+0200&quot;,\r\nupdateDate: &quot;2019-08-08T15:15:47+0200&quot;,\r\ntype: &quot;BUG&quot;,\r\norganization: &quot;default-organization&quot;,\r\nfromHotspot: false\r\n},\r\n```\r\nFor the above input I try to store comments:login and comments:markdown",
        "link": "https://stackoverflow.com/questions/57510887/how-to-get-jq-name-value-pair-from-nested-array-response",
        "title": "How to get JQ name/value pair from nested (array?) response?"
    },
    {
        "tags": [
            "json",
            "bash",
            "shell",
            "null",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 13,
                "is_accepted": true,
                "score": 12,
                "last_activity_date": 1594485119,
                "last_edit_date": 1594485119,
                "creation_date": 1565912923,
                "answer_id": 57517465,
                "question_id": 57517345,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; Where is the error?\r\n\r\nReplace\r\n\r\n    [ -z &quot;${VAR2}&quot; ]\r\n\r\nwith\r\n\r\n    [ &quot;${VAR2}&quot; = &quot;null&quot; ]\r\n\r\nbecause `jq` returns string `null` if `var2` is not found in JSON file.\r\n\r\n---\r\nOr use `--exit-status`:\r\n\r\n    if echo &quot;$JSON_INPUT&quot; | jq --exit-status &#39;.var2&#39; &gt;/dev/null; then \r\n      echo &quot;exists&quot;\r\n    else\r\n      echo &quot;does not exist&quot;\r\n    fi\r\n",
                "title": "How to check jq result is null or not?"
            },
            {
                "up_vote_count": 5,
                "is_accepted": false,
                "score": 5,
                "last_activity_date": 1565946604,
                "last_edit_date": 1565946604,
                "creation_date": 1565918133,
                "answer_id": 57517866,
                "question_id": 57517345,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt;  I want to check whether a property exists or not. If it exists I always want to get the first element in the array ...\r\n\r\nThe condition can best be expressed as:\r\n\r\n    if has(&quot;var2&quot;)\r\n\r\nso since you seem to want VAR2 to be null if the condition is not met, you could write:\r\n\r\n    VAR2=$(jq &#39;if has(&quot;var2&quot;) then .[&quot;var2&quot;][0] else null end&#39;)\r\n\r\nIf the condition is not met, then we would find:\r\n\r\n    echo &quot;$VAR2&quot;\r\n    null\r\n\r\nThere is a small problem, here, though: for example, what if the array&#39;s first value is `null`?\r\n\r\nSo a more discriminating approach would be to write:\r\n\r\n     VAR2=$(jq &#39;if has(&quot;var2&quot;) then .[&quot;var2&quot;][0] else empty end&#39;)\r\n\r\nEven if neither of these approaches is exactly what you want, they illustrate that putting as much of the logic inside the jq program as possible yields a tidy, easy-to-understand, and efficient solution.",
                "title": "How to check jq result is null or not?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 10,
        "last_activity_date": 1594485119,
        "creation_date": 1565911781,
        "last_edit_date": 1565954547,
        "question_id": 57517345,
        "body_markdown": "I&#39;m using jq to parse some JSON. I want to check whether a property exists or not. If it exists I always want to get the first element in the array. Based on this I want to use `if then ... else`.\r\n\r\nMy code looks like this:\r\n\r\n    JSON_INPUT=&#39;{&quot;var1&quot;:[{&quot;foo&quot;:&quot;bar&quot;}],&quot;var2&quot;:[{&quot;fooooo&quot;:&quot;baaaaar&quot;}]}&#39;\r\n    VAR2=$(echo $JSON_INPUT | jq  &#39;.[&quot;var2&quot;] | .[0]&#39;)\r\n    if [ -z &quot;${VAR2}&quot; ]\r\n    then\r\n        echo &quot;does not exist&quot;\r\n        # do some stuff...\r\n    else\r\n        echo &quot;exist&quot;\r\n        # do some stuff...\r\n    fi\r\n\r\nThe JSON_INPUT may contain `var2` but must not. If it does not exist `VAR2` will be null. But I&#39;m not able to check for this null value. Where is the error?",
        "link": "https://stackoverflow.com/questions/57517345/how-to-check-jq-result-is-null-or-not",
        "title": "How to check jq result is null or not?"
    },
    {
        "tags": [
            "json",
            "constructor",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 8646336,
                    "reputation": 772,
                    "user_id": 6473417,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/66f032990f236c991616a311fd4167f4?s=256&d=identicon&r=PG",
                    "display_name": "jdpjamesp",
                    "link": "https://stackoverflow.com/users/6473417/jdpjamesp"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1565951049,
                "post_id": 57522841,
                "comment_id": 101512396,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 16518794,
                    "reputation": 85,
                    "user_id": 11935518,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/c6d473d9e5d4bdaf895f86c634b38ace?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "fengnix",
                    "link": "https://stackoverflow.com/users/11935518/fengnix"
                },
                "reply_to_user": {
                    "account_id": 8646336,
                    "reputation": 772,
                    "user_id": 6473417,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/66f032990f236c991616a311fd4167f4?s=256&d=identicon&r=PG",
                    "display_name": "jdpjamesp",
                    "link": "https://stackoverflow.com/users/6473417/jdpjamesp"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1565951980,
                "post_id": 57522841,
                "comment_id": 101512813,
                "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": 1565952625,
                "post_id": 57522841,
                "comment_id": 101513082,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1565952490,
                "creation_date": 1565952490,
                "answer_id": 57523292,
                "question_id": 57522841,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Assuming tels.txt has the telephone numbers exactly as you want them, one per line, you could write:\r\n\r\n    jq -R &#39;{method: &quot;POST&quot;, url: &quot;http://:6060&quot;, body: {phoneNo: .}}&#39; tels.txt\r\n\r\nNotice there is no need to invoke jq twice. Indeed, invoking jq twice in a row (`jq ... | jq ...`) is usually suboptimal.",
                "title": "How to read a file line by line and then output all lines compounded with sth in jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1565953750,
        "creation_date": 1565950406,
        "last_edit_date": 1565953750,
        "question_id": 57522841,
        "body_markdown": "If we need to read dynamic parameters from a static file and then generate one target (url) for each line of the file, how to use jq to implement it?\r\nI mean, we use jq to read a file and then process its contents line by line; the output for each line is a distinct url generated with a line respectively.\r\n\r\nCould anyone please provide one or several examples? Thank you very much!\r\n\r\nFor example, there is a file called tels.txt which contains numerous phone no:\r\n13512345678\r\n13712345600\r\n17212215600\r\n13512345889\r\n18912345678\r\n13912345678\r\n18612345999\r\n\r\njq --slurpfile phoneNos tels.txt &#39;.phoneNo=$phoneNos&#39;  | jq -cM &#39;{method: &quot;POST&quot;, url: &quot;http://:6060&quot;, body: {phoneNo: .} | @json}&#39;\r\n\r\nI want to generate output like {method: &quot;POST&quot;, url: &quot;http://:6060&quot;, body: {phoneNo: 13512345678}} for each line in the above file, but when executing the the jq commandline as the above, got nothing.\r\n\r\nMy question is how the commandline should be, thx",
        "link": "https://stackoverflow.com/questions/57522841/how-to-read-a-file-line-by-line-and-then-output-all-lines-compounded-with-sth-in",
        "title": "How to read a file line by line and then output all lines compounded with sth in jq?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 12200326,
                    "reputation": 315,
                    "user_id": 8904736,
                    "user_type": "registered",
                    "profile_image": "https://lh4.googleusercontent.com/-qYzXl-PnKB0/AAAAAAAAAAI/AAAAAAAAD0Q/tJLszEs7z1Y/s256-rj/photo.jpg",
                    "display_name": "Jerry Thomas",
                    "link": "https://stackoverflow.com/users/8904736/jerry-thomas"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1566038036,
                "post_id": 57534926,
                "comment_id": 101535773,
                "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": 0,
                "creation_date": 1566044497,
                "post_id": 57534926,
                "comment_id": 101537040,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 12200326,
                    "reputation": 315,
                    "user_id": 8904736,
                    "user_type": "registered",
                    "profile_image": "https://lh4.googleusercontent.com/-qYzXl-PnKB0/AAAAAAAAAAI/AAAAAAAAD0Q/tJLszEs7z1Y/s256-rj/photo.jpg",
                    "display_name": "Jerry Thomas",
                    "link": "https://stackoverflow.com/users/8904736/jerry-thomas"
                },
                "reply_to_user": {
                    "account_id": 57200,
                    "reputation": 158728,
                    "user_id": 171318,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/ePRKy.jpg?s=256",
                    "display_name": "hek2mgl",
                    "link": "https://stackoverflow.com/users/171318/hek2mgl"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1566046246,
                "post_id": 57534926,
                "comment_id": 101537383,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1566199975,
                "last_edit_date": 1566199975,
                "creation_date": 1566039491,
                "answer_id": 57535629,
                "question_id": 57534926,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It&#39;s a lot more easier to achieve this using multiple `reduce`s, like:\r\n```\r\ndef split_data($parent; $ids; $arr_cols):\r\n    ($arr_cols | map([.])) as $p\r\n    | reduce .[] as $in ({}; .[$parent] += [$in | delpaths($p)]\r\n        | (reduce $ids[] as $k ({}; . + {($k): $in[$k]}) as $s\r\n        | reduce $arr_cols[] as $k (.; .[$k] += [$in[$k][] + $s])\r\n    );\r\n\r\nsplit_data(&quot;person&quot;; [&quot;name&quot;, &quot;year&quot;]; [&quot;phones&quot;, &quot;email&quot;])\r\n```",
                "title": "Splitting nested arrays as separate entities"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1566126201,
                "last_edit_date": 1566126201,
                "creation_date": 1566122778,
                "answer_id": 57543498,
                "question_id": 57534926,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a straightforward solution to the generic problem (it uses `reduce` only once, in a helper function).  To understand it, it might be helpful to see it as an abstraction of this concrete solution:\r\n```\r\n  { person: [.[] | {name, year, city, zip} ]}\r\n+ { phones: [.[] | ({name, year} + .phones[]) ]}\r\n+ { email:  [.[] | ({name, year} + .email[]) ]}\r\n```\r\n\r\n## Helper function\r\n\r\nLet&#39;s first define a helper function for constructing an object by selecting a set of keys:\r\n\r\n```\r\ndef pick($ary):\r\n  . as $in\r\n  | reduce $ary[] as $k ({};\r\n      . + {($k): $in[$k]});\r\n```\r\n\r\n## split_data\r\n\r\nHere finally is the function that takes as arguments the $parent, $ids, and columns of interest. The main complication is ensuring that the supplemental keys (&quot;city&quot; and &quot;zip&quot;) are dealt with in the proper order.\r\n \r\n```\r\ndef split_data($parent; $ids; $arr_cols):\r\n  (.[0]|keys_unsorted - $arr_cols - $ids) as $extra\r\n  | { ($parent): [.[] | pick($ids + $extra)] }\r\n  + ([$arr_cols[] as $k\r\n     | {($k): [.[] | pick($ids) + .[$k][]] }] | add) ;\r\n```\r\n\r\nThe invocation:\r\n```\r\nsplit_data(&quot;person&quot;; [&quot;name&quot;, &quot;year&quot;]; [&quot;phones&quot;, &quot;email&quot;])\r\n```\r\nproduces the desired result.\r\n\r\n",
                "title": "Splitting nested arrays as separate entities"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1566199975,
        "creation_date": 1566033260,
        "last_edit_date": 1566037991,
        "question_id": 57534926,
        "body_markdown": "I have some JSON data which contains attributes and some array elements. I would like to push a given set of fields into the array elements and then separate the arrays as separate entities. \r\n\r\nSource data looks like this\r\n```json\r\n[\r\n  {\r\n    &quot;phones&quot;: [\r\n      {\r\n        &quot;phone&quot;: &quot;555-555-1234&quot;,\r\n        &quot;type&quot;: &quot;home&quot;\r\n      },\r\n      {\r\n        &quot;phone&quot;: &quot;555-555-5678&quot;,\r\n        &quot;type&quot;: &quot;mobile&quot;\r\n      }\r\n    ],\r\n    &quot;email&quot;: [\r\n      {\r\n        &quot;email&quot;: &quot;a@b.com&quot;,\r\n        &quot;type&quot;: &quot;work&quot;\r\n      },\r\n      {\r\n        &quot;email&quot;: &quot;x@c.com&quot;,\r\n        &quot;type&quot;: &quot;home&quot;\r\n      }\r\n    ],\r\n    &quot;name&quot;: &quot;john doe&quot;,\r\n    &quot;year&quot;: &quot;2012&quot;,\r\n    &quot;city&quot;: &quot;cupertino&quot;,\r\n    &quot;zip&quot;: &quot;555004&quot;\r\n  },\r\n  {\r\n    &quot;phones&quot;: [\r\n      {\r\n        &quot;phone&quot;: &quot;555-666-1234&quot;,\r\n        &quot;type&quot;: &quot;home&quot;\r\n      },\r\n      {\r\n        &quot;phone&quot;: &quot;555-666-5678&quot;,\r\n        &quot;type&quot;: &quot;mobile&quot;\r\n      }\r\n    ],\r\n    &quot;email&quot;: [\r\n      {\r\n        &quot;email&quot;: &quot;a@b.com&quot;,\r\n        &quot;type&quot;: &quot;work&quot;\r\n      },\r\n      {\r\n        &quot;email&quot;: &quot;x@c.com&quot;,\r\n        &quot;type&quot;: &quot;home&quot;\r\n      }\r\n    ],\r\n    &quot;name&quot;: &quot;jane doe&quot;,\r\n    &quot;year&quot;: &quot;2000&quot;,\r\n    &quot;city&quot;: &quot;los angeles&quot;,\r\n    &quot;zip&quot;: &quot;555004&quot;\r\n  }\r\n]\r\n```\r\n\r\nI expect a result like this\r\n```json\r\n{\r\n  &quot;person&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;john doe&quot;,\r\n      &quot;year&quot;: &quot;2012&quot;,\r\n      &quot;city&quot;: &quot;cupertino&quot;,\r\n      &quot;zip&quot;: &quot;555004&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;jane doe&quot;,\r\n      &quot;year&quot;: &quot;2000&quot;,\r\n      &quot;city&quot;: &quot;los angeles&quot;,\r\n      &quot;zip&quot;: &quot;555004&quot;\r\n    }\r\n  ],\r\n  &quot;phones&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;john doe&quot;,\r\n      &quot;year&quot;: &quot;2012&quot;,\r\n      &quot;phone&quot;: &quot;555-555-1234&quot;,\r\n      &quot;type&quot;: &quot;home&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;john doe&quot;,\r\n      &quot;year&quot;: &quot;2012&quot;,\r\n      &quot;phone&quot;: &quot;555-555-5678&quot;,\r\n      &quot;type&quot;: &quot;mobile&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;jane doe&quot;,\r\n      &quot;year&quot;: &quot;2000&quot;,\r\n      &quot;phone&quot;: &quot;555-666-1234&quot;,\r\n      &quot;type&quot;: &quot;home&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;jane doe&quot;,\r\n      &quot;year&quot;: &quot;2000&quot;,\r\n      &quot;phone&quot;: &quot;555-666-5678&quot;,\r\n      &quot;type&quot;: &quot;mobile&quot;\r\n    }\r\n  ],\r\n  &quot;email&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;john doe&quot;,\r\n      &quot;year&quot;: &quot;2012&quot;,\r\n      &quot;email&quot;: &quot;a@b.com&quot;,\r\n      &quot;type&quot;: &quot;work&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;john doe&quot;,\r\n      &quot;year&quot;: &quot;2012&quot;,\r\n      &quot;email&quot;: &quot;x@c.com&quot;,\r\n      &quot;type&quot;: &quot;home&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;jane doe&quot;,\r\n      &quot;year&quot;: &quot;2000&quot;,\r\n      &quot;email&quot;: &quot;a@b.com&quot;,\r\n      &quot;type&quot;: &quot;work&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;jane doe&quot;,\r\n      &quot;year&quot;: &quot;2000&quot;,\r\n      &quot;email&quot;: &quot;x@c.com&quot;,\r\n      &quot;type&quot;: &quot;home&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nI have been able to get the desired result, but I can&#39;t make it work in a generic way. \r\n\r\n[experiment on jqterm](https://jqterm.com/06f73b6a1ff837586e68085f7542b022?query=def%20split_child%28field%3B%20ids%29%3A%0A%20%20map%28%0A%20%20%20%20%28getpath%28%5Bfield%5D%29%7Carrays%5B%5D%20%2F%2F%20null%29%20as%20%24d%20%0A%20%20%20%20%7C%20with_entries%28%0A%20%20%20%20%20.%20as%20%24data%20%0A%20%20%20%20%20%7C%20select%28ids%7Ccontains%28%5B%24data.key%5D%29%29%0A%20%20%29%20%2B%20%24d%20%29%3B%0A%0A%0A%5B%22phones%22%2C%20%22email%22%5D%20as%20%24children%20%0A%7C%20%5B%22name%22%2C%20%22year%22%5D%20as%20%24ids%0A%7C%7Bperson%3A%20map%28with_entries%28%0A%20%20%20%20%20.%20as%20%24data%20%7C%20select%28%24children%7Ccontains%28%5B%24data.key%5D%29%7Cnot%29%0A%20%20%29%29%7D%0A%20%2B%20%7B%22phones%22%3A%20split_child%28%24children%5B0%5D%3B%24ids%29%7D%0A%20%2B%20%7B%22email%22%3A%20split_child%28%24children%5B1%5D%3B%24ids%29%7D%0A%20%20&amp;raw=true)\r\n\r\nThe code below achieves the job, but I would like to pass the array of columns to be injected into the child arrays, the name of the primary result and an array containing the array field names. \r\n\r\n```jq\r\n[&quot;phones&quot;, &quot;email&quot;] as $children \r\n| [&quot;name&quot;, &quot;year&quot;] as $ids\r\n|{person: map(with_entries(\r\n     . as $data | select($children|contains([$data.key])|not)\r\n  ))}\r\n + {&quot;phones&quot;: split_child($children[0];$ids)}\r\n + {&quot;email&quot;: split_child($children[1];$ids)}\r\n  \r\n```",
        "link": "https://stackoverflow.com/questions/57534926/splitting-nested-arrays-as-separate-entities",
        "title": "Splitting nested arrays as separate entities"
    },
    {
        "tags": [
            "json",
            "bash",
            "merge",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1566126804,
                "last_edit_date": 1566126804,
                "creation_date": 1566120590,
                "answer_id": 57543262,
                "question_id": 57542944,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "1. &quot;Slurping&quot; (whether using `-s` or `--slurpfile`) is sometimes necessary but rarely desirable, because of the memory requirements.  So here&#39;s a solution that takes advantage of the fact that your multiGET produces a stream:\r\n```\r\nmultiGET | jq -n --argjson objects &#39;[{&quot;name&quot;:&quot;foo&quot;},{&quot;name&quot;:&quot;bar&quot;}]&#39; &#39;\r\n  $objects\r\n  | [foreach inputs as $in (-1; .+1; \r\n      . as $ix\r\n      | $objects[$ix] + ($in | del(.ref)))]\r\n&#39;\r\n```\r\n\r\n2. Here&#39;s a functional approach that might be appropriate if your stream was in fact already packaged as an array:\r\n\r\n```\r\nmultiGET | jq -s --argjson objects &#39;[{&quot;name&quot;:&quot;foo&quot;},{&quot;name&quot;:&quot;bar&quot;}]&#39; &#39;\r\n  [$objects, map(del(.ref))]\r\n  | transpose\r\n  | map(add)\r\n&#39;\r\n```\r\n\r\n3. If the `$objects` array is in a file or too big for the command line, I&#39;d suggest using `--argfile`, even though it is technically deprecated.\r\n\r\n4. If the $objects array is in a file, and if you want to avoid `--argfile`, you could still avoid slurping, e.g. by using the fact that unless `-n` is used, jq will automatically read one JSON entity from `stdin`:\r\n```\r\n(echo &#39;[{&quot;name&quot;:&quot;foo&quot;},{&quot;name&quot;:&quot;bar&quot;}]&#39;;\r\n multiGET) | jq &#39;\r\n   . as $objects\r\n   | [foreach inputs as $in (-1; .+1;\r\n        . as $ix | $objects[$ix] + $in | del(.ref))] \r\n&#39;\r\n```\r\n",
                "title": "Map arrays to objects with no common fields"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1566217775,
                "last_edit_date": 1566217775,
                "creation_date": 1566121117,
                "answer_id": 57543314,
                "question_id": 57542944,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Get jq to read `file` before stdin, so that the first entity in `file` will be `.` and you can get everything else using `inputs`.\r\n```\r\n$ multiGET | jq -c &#39;. as $objects\r\n| [ foreach (inputs | {arr}) as $x (-1; .+1;\r\n    . as $i | $objects[$i] + $x\r\n) ]&#39; file -\r\n[{&quot;name&quot;:&quot;foo&quot;,&quot;arr&quot;:[&quot;alpha&quot;]},{&quot;name&quot;:&quot;bar&quot;,&quot;arr&quot;:[&quot;bravo&quot;]}]\r\n```",
                "title": "Map arrays to objects with no common fields"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1566217775,
        "creation_date": 1566117399,
        "last_edit_date": 1566128683,
        "question_id": 57542944,
        "body_markdown": "How might one use `jq-1.5-1-a5b5cbe` to join a filtered set of arrays from STDIN to a set of objects which contains no common fields, assuming that all elements will be in predictable order? \r\n\r\nStandard Input (pre-slurpfile; generated by multiple GETs):\r\n```\r\n{&quot;ref&quot;:&quot;objA&quot;,&quot;arr&quot;:[&quot;alpha&quot;]}\r\n{&quot;ref&quot;:&quot;objB&quot;,&quot;arr&quot;:[&quot;bravo&quot;]}\r\n```\r\nExisting File:\r\n```\r\n[{&quot;name&quot;:&quot;foo&quot;},{&quot;name&quot;:&quot;bar&quot;}]\r\n```\r\nDesired Output:\r\n```\r\n[{&quot;name&quot;:&quot;foo&quot;,&quot;arr&quot;:[&quot;alpha&quot;]},{&quot;name&quot;:&quot;bar&quot;,&quot;arr&quot;:[&quot;bravo&quot;]}]\r\n```\r\nCurrent Bash:\r\n```\r\n$ multiGET | jq --slurpfile stdin /dev/stdin &#39;.[].arr = $stdin[].arr&#39; file\r\n[\r\n  {\r\n    &quot;name&quot;: &quot;foo&quot;,\r\n    &quot;arr&quot;: [\r\n      &quot;alpha&quot;\r\n    ]\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;bar&quot;,\r\n    &quot;arr&quot;: [\r\n      &quot;alpha&quot;\r\n    ]\r\n  }\r\n]\r\n[\r\n  {\r\n    &quot;name&quot;: &quot;foo&quot;,\r\n    &quot;arr&quot;: [\r\n      &quot;bravo&quot;\r\n    ]\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;bar&quot;,\r\n    &quot;arr&quot;: [\r\n      &quot;bravo&quot;\r\n    ]\r\n  }\r\n]\r\n```\r\n\r\nSidenote: I wasn&#39;t sure when to use pretty/compact JSON in this question; please comment with your opinion on best practice.",
        "link": "https://stackoverflow.com/questions/57542944/map-arrays-to-objects-with-no-common-fields",
        "title": "Map arrays to objects with no common fields"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1566185026,
                "creation_date": 1566185026,
                "answer_id": 57550125,
                "question_id": 57549136,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "An expression of the form:\r\n\r\n    reduce STREAM as ...\r\n\r\nreduces the given stream, whereas the compound expression:\r\n\r\n    STREAM | reduce . as ...\r\n\r\ninvokes `reduce` once for each item in the stream, and for each invocation, `.` is that item. \r\n\r\n----\r\nIf the concept of streams is unclear in this context, you might be interested to read a stream-oriented introduction to jq that I wrote:\r\nhttps://github.com/pkoppstein/jq/wiki/A-Stream-oriented-Introduction-to-jq",
                "title": "Why does &quot;reduce&quot; not reduce in jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1566185026,
        "creation_date": 1566171856,
        "question_id": 57549136,
        "body_markdown": "### tl;dr\r\nIn the language of `jq`, why is\r\n```\r\n$ jq --compact-output reduce (1,2,3,4) as $i ([]; . + [$i])\r\n[1,2,3,4]\r\n```\r\nnot the same as\r\n```\r\n$ jq --compact-output (1,2,3,4) | reduce . as $i ([]; . + [$i])\r\n[1]\r\n[2]\r\n[3]\r\n[4]\r\n```\r\n\r\n### Full question and discussion\r\nI have a somewhat theoretical question in that I have figured out a way to get the transformation I want, but still I do not understand completely why my first attempt failed and I would like an explanation.\r\n\r\nInteractive example at [jqPlay][1]\r\n\r\nI have input\r\n```\r\n{\r\n  &quot;data&quot;: {\r\n    &quot;k1&quot;: &quot;v1&quot;\r\n  },\r\n  &quot;item&quot;: {\r\n    &quot;data&quot;: {\r\n      &quot;k2&quot;: &quot;v2&quot;\r\n    }\r\n  }, \r\n  &quot;list&quot;: {\r\n    &quot;item&quot;: {\r\n      &quot;data&quot;: {\r\n        &quot;k3&quot;: &quot;v3&quot;,\r\n        &quot;k4&quot;: &quot;v4&quot;\r\n      }\r\n    }\r\n  }\r\n}\r\n```\r\nand I want to collect into a single array all of the values of all of the keys that are immediate children of a &quot;data&quot; key. So the output I want is\r\n```\r\n[&quot;v1&quot;,&quot;v2&quot;,&quot;v3&quot;,&quot;v4&quot;]\r\n```\r\nI eventually figured out that this works\r\n```\r\njq --compact-output &#39;[.. | .data? | select(.) | to_entries | .[].value]&#39;\r\n```\r\n\r\nMy question is, why could I not get it to work with `reduce`? I originally tried\r\n```\r\n.. | .data? | select(.) | to_entries | .[].value | reduce . as $v ([]; . + [$v])\r\n```\r\nbut that gave me\r\n```\r\n[&quot;v1&quot;]\r\n[&quot;v2&quot;]\r\n[&quot;v3&quot;]\r\n[&quot;v4&quot;]\r\n```\r\ninstead. My question is why? `reduce` is supposed to iterate over multiple values, but what kind of multiple values does it iterate over and what kind are treated as separate inputs to separate `reduce` statements?\r\n\r\nI guess my fundamental confusion is when is `.` (dot) an expression with 4 results and when is it 4 expressions? Or if `.` is always a an expression with 1 result, how do you collect 4 results back into 1, which is what `reduce` is all about? Is the array operator the only way?\r\n\r\n\r\n  [1]: https://jqplay.org/s/N0eE52b3c_\r\n  [2]: https://stedolan.github.io/jq/manual/v1.6/",
        "link": "https://stackoverflow.com/questions/57549136/why-does-reduce-not-reduce-in-jq",
        "title": "Why does &quot;reduce&quot; not reduce in jq"
    },
    {
        "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": 1566183150,
                "post_id": 57549904,
                "comment_id": 101562609,
                "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": 1566183242,
                "post_id": 57549904,
                "comment_id": 101562626,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 15535508,
                    "reputation": 445,
                    "user_id": 11207803,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/-FJ4WGmO0jKs/AAAAAAAAAAI/AAAAAAAAAAA/ACHi3rellG-NbGxyx1QYHIwx94nRxx6j2g/mo/s256-rj/photo.jpg",
                    "display_name": "AK123",
                    "link": "https://stackoverflow.com/users/11207803/ak123"
                },
                "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": 1566184002,
                "post_id": 57549904,
                "comment_id": 101562720,
                "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": 1566191157,
                "post_id": 57549904,
                "comment_id": 101563842,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 15535508,
                    "reputation": 445,
                    "user_id": 11207803,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/-FJ4WGmO0jKs/AAAAAAAAAAI/AAAAAAAAAAA/ACHi3rellG-NbGxyx1QYHIwx94nRxx6j2g/mo/s256-rj/photo.jpg",
                    "display_name": "AK123",
                    "link": "https://stackoverflow.com/users/11207803/ak123"
                },
                "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": 1566192745,
                "post_id": 57549904,
                "comment_id": 101564193,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1566186772,
                "last_edit_date": 1566186772,
                "creation_date": 1566184489,
                "answer_id": 57550081,
                "question_id": 57549904,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You want `--slurpfile`, and you need to escape `/agents/delta` part of the path with quotes:\r\n\r\n    $ jq --slurpfile newval insert.json &#39;.paths.&quot;/agents/delta&quot;.get.parameters += $newval&#39; main.json\r\n    {\r\n      &quot;swagger&quot;: &quot;2.0&quot;,\r\n      &quot;paths&quot;: {\r\n        &quot;/agents/delta&quot;: {\r\n          &quot;get&quot;: {\r\n            &quot;description&quot;: &quot;lorem ipsum doram&quot;,\r\n            &quot;operationId&quot;: &quot;getagentdelta&quot;,\r\n            &quot;summary&quot;: &quot;GetAgentDelta&quot;,\r\n            &quot;tags&quot;: [\r\n              &quot;Agents&quot;\r\n            ],\r\n            &quot;parameters&quot;: [\r\n              {\r\n                &quot;name&quot;: &quot;since&quot;,\r\n                &quot;in&quot;: &quot;query&quot;,\r\n                &quot;description&quot;: &quot;Format - date-time (as date-time in RFC3339). The time from which you need changes from. You should use the format emitted by Date&#39;s toJSON method (for example, 2017-04-23T18:25:43.511Z). If a timestamp older than a week is passed, a business rule violation will be thrown which will require the client to change the from date. As a best-practice, for a subsequent call to this method, send the timestamp when you &lt;b&gt;started&lt;/b&gt; the previous delta call (instead of when you completed processing the response or the max of the lastUpdateOn timestamps of the returned records). This will ensure that you do not miss any changes that occurred while you are processing the response from this method&quot;,\r\n                &quot;required&quot;: true,\r\n                &quot;type&quot;: &quot;string&quot;\r\n              },\r\n              {\r\n                &quot;name&quot;: &quot;Authorization&quot;,\r\n                &quot;description&quot;: &quot;This parameter represents the Authorization token obtained from the OKTA Authorization server. It is the Bearer token provided to authorize the consumer. Usage Authorization : Bearer token&quot;,\r\n                &quot;in&quot;: &quot;header&quot;,\r\n                &quot;required&quot;: true,\r\n                &quot;type&quot;: &quot;string&quot;\r\n              }\r\n            ]\r\n          }\r\n        }\r\n      }\r\n    }\r\n\r\n---\r\n\r\nAnd here&#39;s one that first removes any existing Authorization objects from the parameters before inserting the new one into every parameters array, and doesn&#39;t depend on an the exact path:\r\n\r\n    jq --slurpfile newval add.json &#39;.paths |= walk(\r\n      if type == &quot;object&quot; and has(&quot;parameters&quot;) then\r\n         .parameters |= map(select(.name != &quot;Authorization&quot;)) + $newval\r\n      else\r\n         .\r\n      end)&#39; main.json\r\n",
                "title": "Replace and add json within another json"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1566466210,
        "creation_date": 1566182174,
        "last_edit_date": 1566466210,
        "question_id": 57549904,
        "body_markdown": "I have a Main json file.\r\n\r\n    {\r\n      &quot;swagger&quot;: &quot;2.0&quot;,\r\n        &quot;paths&quot;: {\r\n        &quot;/agents/delta&quot;: {\r\n          &quot;get&quot;: {\r\n            &quot;description&quot;: &quot;lorem ipsum doram&quot;,\r\n            &quot;operationId&quot;: &quot;getagentdelta&quot;,\r\n            &quot;summary&quot;: &quot;GetAgentDelta&quot;,\r\n            &quot;tags&quot;: [\r\n              &quot;Agents&quot;\r\n            ],\r\n            &quot;parameters&quot;: [\r\n              {\r\n                &quot;name&quot;: &quot;since&quot;,\r\n                &quot;in&quot;: &quot;query&quot;,\r\n                &quot;description&quot;: &quot;Format - date-time (as date-time in RFC3339). The time from which you need changes from. You should use the format emitted by Date&#39;s toJSON method (for example, 2017-04-23T18:25:43.511Z). If a timestamp older than a week is passed, a business rule violation will be thrown which will require the client to change the from date. As a best-practice, for a subsequent call to this method, send the timestamp when you &lt;b&gt;started&lt;/b&gt; the previous delta call (instead of when you completed processing the response or the max of the lastUpdateOn timestamps of the returned records). This will ensure that you do not miss any changes that occurred while you are processing the response from this method&quot;,\r\n                &quot;required&quot;: true,\r\n                &quot;type&quot;: &quot;string&quot;\r\n              }\r\n            ]\r\n    \t\t}\r\n    \t\t}\r\n    \t\t}\r\n    \t\t}\r\n\r\nAnd I have a smaller json file.\r\n\r\n    { \r\n                                                                      &quot;name&quot;: &quot;Authorization&quot;,\r\n                      &quot;description&quot;: &quot;This parameter represents the Authorization token obtained from the OKTA Authorization server. It is the Bearer token provided to authorize the consumer. Usage Authorization : Bearer token&quot;,\r\n                      &quot;in&quot;: &quot;header&quot;,\r\n                      &quot;required&quot;: true,\r\n                      &quot;type&quot;: &quot;string&quot;\r\n                   }\r\n\r\nNow I need to add the contents of the smaller json file into the Main.Json file in the parameters array.\r\n\r\nI tried the below command\r\n\r\n    cat test.json | jq --argfile sub Sub.json &#39;.paths./agents/delta.get.parameters[ ] += $sub.{}&#39; &gt; test1.json\r\n\r\nBut I get the below error:\r\n\r\n    jq: error: syntax error, unexpected &#39;{&#39;, expecting FORMAT or QQSTRING_START (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n    .paths += $sub.{}               \r\n    jq: 1 compile error\r\n    cat: write error: Broken pipe\r\n\r\nI tried this command.\r\n\r\n    cat test.json | jq &#39;.paths./agents/delta.get.parameters[ ] | = (.+ [{ &quot;name&quot;: &quot;Authorization&quot;, &quot;description&quot;: &quot;This parameter represents the Authorization token obtained from the OKTA Authorization server. It is the Bearer token provided to authorize the consumer. Usage Authorization : Bearer token&quot;, &quot;in&quot;: &quot;header&quot;,  &quot;required&quot;: true,  &quot;type&quot;: &quot;string&quot; }] )&#39; &gt; test1.json\r\n\r\nAnd I get no error and no output either. How do I get around this?\r\nI would have to add the contents of the smaller json file directly first. And then at a later stage,  search if it already had `name: Authorization` and it&#39;s other parameters, and then remove and replace the whole `name: Authorization` piece with the actual contents of the smaller.json, under each path that starts with &#39;/xx/yyy&#39;.\r\n\r\nEdited to add:\r\nFor the last part of the question, I could not use the walk function, since I have jq 1.5 and since am using the bash task within Azure DevOps, I can&#39;t update the jq installation file with the walk function.\r\nMeanwhile I found the use of something similar to wildcard in jq, and was wondering why I can&#39;t use it in this way.\r\n\r\n    jq --slurpfile newval auth.json &#39;.paths | .. | objects | .get.parameters += $newval&#39; test.json &gt; test1.json\r\n\r\nCan anyone please point out the issue in the above command? It did not work, and am not sure why..",
        "link": "https://stackoverflow.com/questions/57549904/replace-and-add-json-within-another-json",
        "title": "Replace and add json within another json"
    },
    {
        "tags": [
            "json",
            "jq",
            "default-value"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 16530872,
                    "reputation": 13,
                    "user_id": 11944136,
                    "user_type": "registered",
                    "profile_image": "https://lh5.googleusercontent.com/-gbOhEhwJpJ8/AAAAAAAAAAI/AAAAAAAAAAA/ACHi3rdZoCvcTa868SNKRIKaRUphGlbUhw/s256-rj/photo.jpg",
                    "display_name": "Sagar Patel",
                    "link": "https://stackoverflow.com/users/11944136/sagar-patel"
                },
                "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": 1566188923,
                "post_id": 57549929,
                "comment_id": 101563408,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1566185966,
                "creation_date": 1566185966,
                "answer_id": 57550214,
                "question_id": 57549929,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "One way to provide a default value is often to use the `//` &quot;alternative&quot; operator.  Building on the foundations you&#39;ve laid, you could write:\r\n\r\n    .array[]\r\n    | {id, \r\n       &quot;goodConversation&quot;: \r\n         ((.conversations[]\r\n          | select(.type == &quot;good&quot;)\r\n          | .conversation) // null) }\r\n\r\nIf there is more than one &quot;good&quot; conversation, however, this may not be exactly what you want.  If it&#39;s not, then consider using `first`, e.g.:\r\n\r\n    .array[]\r\n    | {id,\r\n       &quot;goodConversation&quot;:\r\n         ( first(.conversations[]\r\n                 | select(.type == &quot;good&quot;)\r\n                 | .conversation) // null)}\r\n\r\n\r\n",
                "title": "Is there a way to use default in object construction with jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1566380081,
        "creation_date": 1566182640,
        "last_edit_date": 1566189176,
        "question_id": 57549929,
        "body_markdown": "I want to filter and assign a value from array based on a condition, and use default in case if array does not have the matched object. \r\n\r\nHere is a sample object: \r\n\r\n```\r\n{\r\n    &quot;array&quot; : [\r\n            {   \r\n                &quot;id&quot;: &quot;A&quot;,\r\n                &quot;conversations&quot;: [   \r\n                    {\r\n                    &quot;conversation&quot;: &quot;1&quot;,\r\n                    &quot;type&quot;: &quot;good&quot;\r\n                    },\r\n                    {\r\n                    &quot;conversation&quot;: &quot;2&quot;, \r\n                    &quot;type&quot;: &quot;bad&quot;\r\n                    }\r\n                ]\r\n            \r\n            },\r\n            {   \r\n                &quot;id&quot;: &quot;B&quot;,\r\n                &quot;conversations&quot;: [   \r\n                    {\r\n                    &quot;conversation&quot;: &quot;3&quot;,\r\n                    &quot;type&quot;: &quot;good&quot;\r\n                    },\r\n                    {\r\n                    &quot;conversation&quot;: &quot;4&quot;, \r\n                    &quot;type&quot;: &quot;bad&quot;\r\n                    }\r\n                ]\r\n            \r\n            },\r\n            {   \r\n                &quot;id&quot;: &quot;C&quot;,\r\n                &quot;conversations&quot;: [   \r\n                    {\r\n                    &quot;conversation&quot;: &quot;5&quot;,\r\n                    &quot;type&quot;: &quot;bad&quot;\r\n                    },\r\n                    {\r\n                    &quot;conversation&quot;: &quot;6&quot;, \r\n                    &quot;type&quot;: &quot;bad&quot;\r\n                    }\r\n                ]\r\n            \r\n            }\r\n        ]\r\n}\r\n```\r\n\r\nRequired output:\r\n\r\n```\r\n{\r\n  &quot;id&quot;: &quot;A&quot;,\r\n  &quot;goodConversation&quot;: &quot;1&quot;\r\n}\r\n{\r\n  &quot;id&quot;: &quot;B&quot;,\r\n  &quot;goodConversation&quot;: &quot;3&quot;\r\n},\r\n{\r\n  &quot;id&quot;: &quot;C&quot;,\r\n  &quot;goodConversation&quot;: null\r\n}\r\n```\r\n\r\necho of my input:\r\n```\r\necho &#39;{&quot;array&quot;:[{&quot;id&quot;:&quot;A&quot;,&quot;conversations&quot;:[{&quot;conversation&quot;:&quot;1&quot;,&quot;type&quot;:&quot;good&quot;},{&quot;conversation&quot;:&quot;2&quot;,&quot;type&quot;:&quot;bad&quot;}]},{&quot;id&quot;:&quot;B&quot;,&quot;conversations&quot;:[{&quot;conversation&quot;:&quot;3&quot;,&quot;type&quot;:&quot;good&quot;},{&quot;conversation&quot;:&quot;4&quot;,&quot;type&quot;:&quot;bad&quot;}]},{&quot;id&quot;:&quot;C&quot;,&quot;conversations&quot;:[{&quot;conversation&quot;:&quot;5&quot;,&quot;type&quot;:&quot;bad&quot;},{&quot;conversation&quot;:&quot;6&quot;,&quot;type&quot;:&quot;bad&quot;}]}]}&#39;\r\n```\r\n\r\n\r\nI tried running following `jq`\r\n\r\n```\r\njq &#39;.array[] | {id, &quot;goodConversation&quot;: .conversations[] | select(.type == &quot;good&quot;) | .conversation}&#39;\r\n```\r\n\r\nActual output:\r\n```\r\n{\r\n  &quot;id&quot;: &quot;A&quot;,\r\n  &quot;goodConversation&quot;: &quot;1&quot;\r\n}\r\n{\r\n  &quot;id&quot;: &quot;B&quot;,\r\n  &quot;goodConversation&quot;: &quot;3&quot;\r\n}\r\n```\r\n\r\nsince the object with id: &quot;C&quot; does not have any good conversation the whole object gets filtered out. Is there a way to create the output object which contains &quot;C&quot; with `null` as value?\r\n\r\n**Clarification**:\r\n\r\n* &quot;conversations&quot; will have at most one good conversation.\r\n* I am using jq 1.5",
        "link": "https://stackoverflow.com/questions/57549929/is-there-a-way-to-use-default-in-object-construction-with-jq",
        "title": "Is there a way to use default in object construction with jq?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1566235814,
                "post_id": 57558872,
                "comment_id": 101584621,
                "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": 1566237327,
                "post_id": 57558872,
                "comment_id": 101585242,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1566238768,
                "last_edit_date": 1566238768,
                "creation_date": 1566238128,
                "answer_id": 57561925,
                "question_id": 57558872,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It may be that one cannot achieve in jq what you think you want, but the following comes close:\r\n\r\n```\r\ndef etl( array; cond; result):\r\n  array[]\r\n  | if cond then result else empty end ;\r\n\r\n{conflictsInPeriod: map(\r\n  . as $parent\r\n  | etl(.events;\r\n       ( ($parent.workorder.startDate | dateDaysAgo(12*7) ) &lt; .endDate)\r\n       and\r\n       (.vendorId == $parent.workorder.vendorId);\r\n       {\r\n         event:.id,\r\n         wo_sd: $parent.workorder.startDate[:10],\r\n         workorder_id: $parent.workorder.id\r\n       }\r\n    )\r\n  )\r\n}\r\n```\r\n\r\n",
                "title": "Bind Parent/sibling properties in JQ to use in dynamic conditionals"
            },
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1566257228,
                "creation_date": 1566257228,
                "answer_id": 57565022,
                "question_id": 57558872,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Maybe this is closer to what you&#39;re looking for:\r\n\r\n```\r\ndef etl(keyname; arrayname; cond; result):\r\n  def etl:\r\n    . as $parent\r\n    | .[arrayname][]\r\n    | { parent: $parent, child: .}\r\n    | select(cond) | result;\r\n\r\n  {(keyname): map(etl)}\r\n ;\r\n\r\n## Invocation:\r\netl(&quot;conflictsInPeriod&quot;;\r\n    &quot;events&quot;;\r\n    ( (.parent.workorder.startDate | dateDaysAgo(12*7) ) &lt; .child.endDate)\r\n      and\r\n      (.child.vendorId == .parent.workorder.vendorId);\r\n   {\r\n     event: .child.id,\r\n     wo_sd: .parent.workorder.startDate[:10],\r\n     workorder_id: .parent.workorder.id\r\n   }\r\n)\r\n```\r\n\r\nNotice how the conditions are written in relation to `.parent` and `.child` rather than `$parent` and `.`.",
                "title": "Bind Parent/sibling properties in JQ to use in dynamic conditionals"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1566301990,
        "creation_date": 1566225209,
        "last_edit_date": 1566301990,
        "question_id": 57558872,
        "body_markdown": "I want to create a JQ function that allows me to \r\nto filter an array in the JSON tree, based on parent&#39;s / sibling properties;\r\n\r\n1 - I want to wrap function but i can&#39;t due to the scope of parent;\r\n2 - I want to invoke that function but with other properties;\r\n\r\n\r\n\r\nSome dummy Data:\r\n```\r\n[\r\n {\r\n        &quot;storeId&quot;: &quot;s2&quot;,\r\n        &quot;storehouseInfo&quot;: {\r\n            &quot;id&quot;: &quot;025453&quot;,\r\n            &quot;name&quot;: &quot;00211 NW, OR&quot;,\r\n            &quot;maxPallets&quot;: 10\r\n        },\r\n        &quot;workorder&quot;:{\r\n            &quot;id&quot;: &quot;w2s2&quot;,\r\n            &quot;startDate&quot;: &quot;2019-09-06T10:00:00.000Z&quot;,\r\n            &quot;vendorId&quot;:&quot;v2&quot;\r\n        },\r\n        &quot;events&quot;: [    \r\n            {\r\n                &quot;id&quot;: &quot;e4&quot;,\r\n                &quot;storeId&quot;: &quot;s2&quot;,\r\n                &quot;vendorId&quot;: &quot;v1&quot;,\r\n                &quot;startDate&quot;: &quot;2019-09-05T10:00:00.000Z&quot;,\r\n                &quot;endDate&quot;: &quot;2019-09-14T00:00:00.000Z&quot;,\r\n                &quot;palletsUsed&quot;: 5\r\n            },\r\n            {\r\n                &quot;id&quot;: &quot;e5&quot;,\r\n                &quot;storeId&quot;: &quot;s2&quot;,\r\n                &quot;vendorId&quot;: &quot;v2&quot;,\r\n                &quot;startDate&quot;: &quot;2019-09-05T00:00:00.000Z&quot;,\r\n                &quot;endDate&quot;: &quot;2019-09-14T00:00:00.000Z&quot;,\r\n                &quot;palletsUsed&quot;: 5\r\n            },\r\n            {\r\n                &quot;id&quot;: &quot;e10&quot;,\r\n                &quot;storeId&quot;: &quot;s2&quot;,\r\n                &quot;vendorId&quot;: &quot;v1&quot;,\r\n                &quot;startDate&quot;: &quot;2019-09-06T10:00:00.000Z&quot;,\r\n                &quot;endDate&quot;: &quot;2019-09-14T00:00:00.000Z&quot;,\r\n                &quot;palletsUsed&quot;: 5\r\n            },\r\n            {\r\n                &quot;id&quot;: &quot;e11&quot;,\r\n                &quot;storeId&quot;: &quot;s2&quot;,\r\n                &quot;vendorId&quot;: &quot;v2&quot;,\r\n                &quot;startDate&quot;: &quot;2019-09-06T00:00:00.000Z&quot;,\r\n                &quot;endDate&quot;: &quot;2019-09-14T00:00:00.000Z&quot;,\r\n                &quot;palletsUsed&quot;: 5\r\n            },\r\n            {\r\n                &quot;id&quot;: &quot;e12&quot;,\r\n                &quot;storeId&quot;: &quot;s2&quot;,\r\n                &quot;vendorId&quot;: &quot;v2&quot;,\r\n                &quot;startDate&quot;: &quot;2019-09-06T10:00:00.000Z&quot;,\r\n                &quot;endDate&quot;: &quot;2019-09-14T00:00:00.000Z&quot;,\r\n                &quot;palletsUsed&quot;: 5\r\n            }\r\n        ]\r\n    },\r\n]\r\n```\r\n\r\nCurrent working function:\r\n```\r\n. | map( . as $parent | \r\n         .\r\n         + \r\n         {\r\n            &quot;conflictsInPeriod&quot;:\r\n             [.events[] | (\r\n                 getFieldsThatCheckConditionInArray(\r\n                 # conditions\r\n                 ( \r\n                    ( ($parent.workorder.startDate | dateDaysAgo(12*7) ) &lt; .endDate)\r\n                                and\r\n                    (.vendorId == $parent.workorder.vendorId)\r\n                  );\r\n                  # props  we want to return\r\n                 {\r\n                     event:.id,\r\n                     wo_sd: $parent.workorder.startDate[:10],\r\n                     workorder_id: $parent.workorder.id\r\n                 })   \r\n             )]\r\n          }\r\n       )    \r\n```\r\n\r\nSome aux functions:\r\n```\r\ndef generateConflictArray(arrayName;arrayToCheck;conflictToCheck):\r\n        map( . +\r\n                {\r\n                    (arrayName): [arrayToCheck | (conflictToCheck)]\r\n                }\r\n        );\r\n\r\ndef getFieldsThatCheckConditionInArray(condition;returnValues) :\r\n        if (condition) then (returnValues) else empty end; \r\n\r\n```\r\n\r\nDesired Function CALL:\r\n\r\n```\r\n . | generateConflictArray(\r\n        &quot;conflictsInPeriod&quot;;\r\n        .events[];\r\n        getFieldsThatCheckConditionInArray(\r\n          # conditions\r\n          ( \r\n                ( ($parent.workorder.startDate | dateDaysAgo(12*7) ) &lt; .endDate)\r\n                                and\r\n                   (.vendorId == $parent.workorder.vendorId)\r\n          );\r\n           # props we want to return\r\n           {\r\n               event:.id,\r\n               event_endDate:.endDate,\r\n               wo_sd: $parent.workorder.startDate[:10],\r\n               workorder_id: $parent.workorder.id\r\n           })   \r\n        )\r\n```  \r\n\r\nDesired Output (All the array data, + newly created array &quot; &quot;conflictsInPeriod&quot;&quot;, **inside each element of the array**):\r\n\r\n```\r\n[\r\n{\r\n &quot;conflictsInPeriod&quot;:[\r\n      {\r\n        &quot;event&quot;: &quot;e5&quot;,\r\n        &quot;workorder_sd&quot;: &quot;2019-09-06&quot;,\r\n        &quot;workorder_id&quot;: &quot;w2s2&quot;\r\n      },\r\n      {\r\n        &quot;event_id&quot;: &quot;e11&quot;,\r\n        &quot;workorder_sd&quot;: &quot;2019-09-06&quot;,\r\n        &quot;workorder_id&quot;: &quot;w2s2&quot;\r\n      },\r\n      {\r\n        &quot;event_id&quot;: &quot;e12&quot;,\r\n        &quot;workorder_sd&quot;: &quot;2019-09-06&quot;,\r\n        &quot;workorder_id&quot;: &quot;w2s2&quot;\r\n      }\r\n]\r\n}\r\n]\r\n...\r\n```\r\n",
        "link": "https://stackoverflow.com/questions/57558872/bind-parent-sibling-properties-in-jq-to-use-in-dynamic-conditionals",
        "title": "Bind Parent/sibling properties in JQ to use in dynamic conditionals"
    },
    {
        "tags": [
            "linux",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1566257501,
                "last_edit_date": 1566257501,
                "creation_date": 1566252606,
                "answer_id": 57564496,
                "question_id": 57564439,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you remove `map` then you will get a stream of the specified values. It might make more sense, though, to write  something along the following lines:\r\n```\r\n.Cars[]\r\n| [.Name, .ID, (if .CrashTested == &quot;true&quot; then &quot;yes&quot; elif .CrashTested == &quot;false&quot; then &quot;no&quot; else &quot;unknown&quot; end)]\r\n| @csv \r\n```\r\n\r\nor:\r\n\r\n```\r\ndef yn:\r\n  if . == true or . == &quot;true&quot; then &quot;yes&quot;\r\n  elif . == false or . == &quot;false&quot; then &quot;no&quot;\r\n  else &quot;unknown&quot;\r\n  end;\r\n  \r\n.Cars[]\r\n| [.Name, .ID, (.CrashTested | yn) ]\r\n```",
                "title": "how to use if else to rewrite output in jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 4,
        "last_activity_date": 1566346803,
        "creation_date": 1566252113,
        "last_edit_date": 1566253350,
        "question_id": 57564439,
        "body_markdown": "I am trying to change it so that when CrashTested is `false`, then it outputs **no** and when `true`, then **yes**\r\n\r\n**Here is the json:**\r\n```\r\n{\r\n    &quot;Cars&quot;: [\r\n        {   &quot;Name&quot;: &quot;Toyota Prius&quot;,\r\n            &quot;ID&quot;: 1,\r\n            &quot;CrashTested&quot;: &quot;false&quot;\r\n},\r\n\r\n        {   &quot;Name&quot;: &quot;Honda Accord&quot;,\r\n            &quot;ID&quot;: 2,\r\n            &quot;CrashTested&quot;: &quot;true&quot;\r\n},\r\n        {   &quot;Name&quot;: &quot;VW Beetle&quot;,\r\n            &quot;ID&quot;: 3,\r\n            &quot;CrashTested&quot;: &quot;false&quot;\r\n},\r\n\r\n        {   &quot;Name&quot;: &quot;Acura TL&quot;,\r\n            &quot;ID&quot;: 4,\r\n            &quot;CrashTested&quot;: &quot;true&quot;\r\n},\r\n\r\n        {   &quot;Name&quot;: &quot;Dodge Charger&quot;,\r\n            &quot;ID&quot;: 5,\r\n            &quot;CrashTested&quot;: &quot;false&quot;\r\n},\r\n        {   &quot;Name&quot;: &quot;Ford Focus&quot;,\r\n            &quot;ID&quot;: 6,\r\n            &quot;CrashTested&quot;: &quot;true&quot;\r\n}\r\n   ]\r\n}\r\n```\r\n\r\n**I have tried the following:**\r\n```\r\n$ jq -r &#39;.Cars[] | .Name, .ID, map(if .CrashTested == &quot;true&quot; then &quot;yes&quot; elif .CrashTested == &quot;false&quot; then &quot;no&quot; else &quot;unknown&quot; end)&#39; &lt; cars.json\r\nToyota Prius\r\n1\r\njq: error (at &lt;stdin&gt;:31): Cannot index string with string &quot;CrashTested&quot;\r\n```\r\n\r\n**I&#39;m trying to get the following output:**\r\n```\r\n&quot;Toyota Prius&quot;\r\n1\r\n&quot;no&quot;\r\n&quot;Honda Accord&quot;\r\n2\r\n&quot;yes&quot;\r\n...\r\n```\r\n\r\nI&#39;m on jq version **jq-1.5-1**\r\n\r\nShould I be using map() or going about this a different way?",
        "link": "https://stackoverflow.com/questions/57564439/how-to-use-if-else-to-rewrite-output-in-jq",
        "title": "how to use if else to rewrite output in jq"
    },
    {
        "tags": [
            "bash",
            "jq",
            "git-bash"
        ],
        "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": 1566275717,
                "post_id": 57566308,
                "comment_id": 101594588,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4663062,
                    "reputation": 89888,
                    "user_id": 3776858,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Cagbk.jpg?s=256",
                    "display_name": "Cyrus",
                    "link": "https://stackoverflow.com/users/3776858/cyrus"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1566276097,
                "post_id": 57566308,
                "comment_id": 101594667,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 16442183,
                    "reputation": 81,
                    "user_id": 11878113,
                    "user_type": "registered",
                    "profile_image": "https://lh4.googleusercontent.com/-xk0QmMc8cLs/AAAAAAAAAAI/AAAAAAAAAAA/ACHi3rc0FC4njp6NC3ixAg6LQZAQACOoMQ/s256-rj/photo.jpg",
                    "display_name": "Woods",
                    "link": "https://stackoverflow.com/users/11878113/woods"
                },
                "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": 1566276985,
                "post_id": 57566308,
                "comment_id": 101594859,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 16442183,
                    "reputation": 81,
                    "user_id": 11878113,
                    "user_type": "registered",
                    "profile_image": "https://lh4.googleusercontent.com/-xk0QmMc8cLs/AAAAAAAAAAI/AAAAAAAAAAA/ACHi3rc0FC4njp6NC3ixAg6LQZAQACOoMQ/s256-rj/photo.jpg",
                    "display_name": "Woods",
                    "link": "https://stackoverflow.com/users/11878113/woods"
                },
                "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": 1566277727,
                "post_id": 57566308,
                "comment_id": 101595008,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4663062,
                    "reputation": 89888,
                    "user_id": 3776858,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Cagbk.jpg?s=256",
                    "display_name": "Cyrus",
                    "link": "https://stackoverflow.com/users/3776858/cyrus"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1566278384,
                "post_id": 57566308,
                "comment_id": 101595142,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1566282492,
                "last_edit_date": 1566282492,
                "creation_date": 1566281700,
                "answer_id": 57567628,
                "question_id": 57566308,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "There&#39;s something fishy here. If you are using `inputs` and getting anything like the results as shown, then:\r\n\r\na) you would have to be using the `-n` command-line option;\r\n\r\nb) you would almost certainly be using jq version 1.5 or later, but I&#39;ve verified that these versions (in conjunction with bash) definitely do not produce the extraneous double-quotation mark.\r\n\r\nHere is a typical transcript, using the input as shown but with one tab per line:\r\n```\r\n$ jq-1.5 -n -R &#39;\r\n[inputs | split(&quot;\\t&quot;) | {&quot;FruitOrVeg&quot;:.[0],&quot;Good?&quot;:.[1]}]&#39; input.tsv\r\n[\r\n  {\r\n    &quot;FruitOrVeg&quot;: &quot;V&quot;,\r\n    &quot;Good?&quot;: &quot;Apple is good for you&quot;\r\n  },\r\n  {\r\n    &quot;FruitOrVeg&quot;: &quot;A&quot;,\r\n    &quot;Good?&quot;: &quot;Broccoli is good for you&quot;\r\n  }\r\n]\r\n```",
                "title": "Format strings to JSON with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1566282492,
        "creation_date": 1566271305,
        "last_edit_date": 1566274639,
        "question_id": 57566308,
        "body_markdown": "Might be easy enough for someone who has experience with jq. I am novice. I am learning jq with bash to create json arrays. \r\nI want to generate json array with jq in bash. \r\n\r\nI have my file named fileForV:\r\n\r\n    V    Apple is good for you\r\n    A    Broccoli is good for you\r\nNote: The space is a tab. \r\n\r\nI have:\r\n\r\n    jq -R &#39;[inputs | \r\n    split(&quot;\\t&quot;) | \r\n    {&quot;FruitOrVeg&quot;:.[0],&quot;Good?&quot;:.[1]}]&#39;&lt;&lt;EOF fileForV EOF\r\n\r\nI get: \r\n\r\n    [\r\n      {\r\n       &quot;FruitOrVeg&quot;: &quot;A&quot;,\r\n       &quot;Good?&quot;: &quot;Apple is good for you&quot;\r\n      },\r\n      {\r\n       &quot;FruitOrVeg&quot;: &quot;V&quot;,\r\n       &quot;Good?&quot;: &quot;Broccoli is good for you\\&quot;&quot;\r\n      }\r\n    ]\r\n\r\nWhy do I get \\&quot;&quot; at the end?\r\n\r\nShould be:\r\n\r\n    [\r\n      {\r\n       &quot;FruitOrVeg&quot;: &quot;A&quot;,\r\n       &quot;Good?&quot;: &quot;Apple is good for you&quot;\r\n      },\r\n      {\r\n       &quot;FruitOrVeg&quot;: &quot;V&quot;,\r\n       &quot;Good?&quot;: &quot;Broccoli is good for you&quot;\r\n      }\r\n    ]",
        "link": "https://stackoverflow.com/questions/57566308/format-strings-to-json-with-jq",
        "title": "Format strings to JSON with jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1566348948,
                "creation_date": 1566348948,
                "answer_id": 57583149,
                "question_id": 57570621,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Your first query works perfectly well with the given JSON sample.  Perhaps you&#39;re invoking jq incorrectly.  If you have the jq program in a file, say select.jq, you&#39;d invoke jq like so:\r\n\r\n    jq -f select.jq sample.json\r\n\r\nIf that doesn&#39;t help, then try:\r\n\r\n    jq empty sample.json\r\n\r\nIf that fails, there might be something wrong with the encoding of the JSON.\r\n\r\n",
                "title": "JQ: key selection from numeric objects"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1566403813,
                "creation_date": 1566403813,
                "answer_id": 57595588,
                "question_id": 57570621,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I&#39;m not sure I understand what you want.\r\n\r\nYour first attempt works for me, but generates one output for JSON value in the input.  That is, I created a file named `so.json` and put in it your JSON from above:\r\n```\r\n{\r\n  &quot;alliances_info&quot;: {\r\n    &quot;744085325458334213&quot;: {\r\n      &quot;emblem&quot;: 3,\r\n⋮\r\n}\r\n```\r\nWhen I run your program , I get:\r\n```\r\n$ jq &#39;.alliances_info | .[] |  [{alliance_name: .name, alliance_count: .member_count, alliance_level: .level, alliance_power: .military_might, alliance_tag: .tag, alliance_slogan: .slogan, alliance_id: .id}]&#39; so.json\r\n[\r\n  {\r\n    &quot;alliance_name&quot;: &quot;wellwell&quot;,\r\n    &quot;alliance_count&quot;: 1,\r\n    &quot;alliance_level&quot;: 1,\r\n    &quot;alliance_power&quot;: 1035,\r\n    &quot;alliance_tag&quot;: &quot;MELL&quot;,\r\n    &quot;alliance_slogan&quot;: &quot;&quot;,\r\n    &quot;alliance_id&quot;: 744085325458334200\r\n  }\r\n]\r\n[\r\n  {\r\n    &quot;alliance_name&quot;: &quot;Brave&quot;,\r\n⋮\r\n]\r\n```\r\n\r\nIf you want an array at all, you probably want one array containing all the alliances like this:\r\n\r\n```\r\n$ jq &#39;.alliances_info | [ .[] | { alliance_name: .name, alliance_id: .id } ]&#39; so.json\r\n[\r\n  {\r\n    &quot;alliance_name&quot;: &quot;wellwell&quot;,\r\n    &quot;alliance_id&quot;: 744085325458334200\r\n  },\r\n  {\r\n    &quot;alliance_name&quot;: &quot;Brave&quot;,\r\n    &quot;alliance_id&quot;: 744128593839678000\r\n  },\r\n  {\r\n    &quot;alliance_name&quot;: &quot;Queen&quot;,\r\n    &quot;alliance_id&quot;: 746034084459209200\r\n  },\r\n  {\r\n    &quot;alliance_name&quot;: &quot;Phoenix Inc&quot;,\r\n    &quot;alliance_id&quot;: 750446471312466400\r\n  },\r\n  {\r\n    &quot;alliance_name&quot;: &quot;Australia&quot;,\r\n    &quot;alliance_id&quot;: 750446518934594000\r\n  }\r\n]\r\n```\r\n\r\nStarting from the left, \r\n- `.alliances_info` looks in its input object for the field named &quot;alliances_info&quot; and outputs its value\r\n- the `|` next says take the output from the left-hand side and pass those as inputs to the right-hand side.\r\n- right after that first `|`, I have a `[ &#171;jq expressions&#187; ]` which tells `jq` to create one JSON array output for each input; the elements of that array are the outputs of that inner `&#171;jq expressions&#187;`\r\n- that inner expression starts with `.[]` which means to produce one output for each JSON value (ignoring the keys) in the input object. For us, that will be the objects named `&quot;744085325458334213&quot;`, `&quot;744128593839677958&quot;`, …\r\n- The next `|` uses those objects as input and for each, generates a JSON object `{ alliance_name: .name, alliance_id: .id }`\r\n\r\nThat&#39;s why I end up with one JSON array containing 5 JSON objects.\r\n\r\nAs far as I can tell, you are mostly just renaming a bunch of the fields. For that, you could just do something like this:\r\n\r\n```\r\n$ jq --argjson renameMap &#39;{ &quot;name&quot;: &quot;alliance_name&quot;, &quot;member_count&quot;: &quot;alliance_count&quot;, &quot;level&quot;: &quot;alliance_level&quot;, &quot;military_might&quot;: &quot;alliance_power&quot;, &quot;tag&quot;: &quot;alliance_tag&quot;, &quot;slog&quot;: &quot;alliance_slogan&quot;}&#39; &#39;.alliances_info |= ( . | [ to_entries[] | ( .value |= ( . | [ to_entries[] | ( .key |= ( if $renameMap[.] then $renameMap[.] else . end ) ) ] | from_entries ) ) ] | from_entries )&#39; so.json \r\n{\r\n  &quot;alliances_info&quot;: {\r\n    &quot;744085325458334213&quot;: {\r\n      &quot;emblem&quot;: 3,\r\n      &quot;alliance_name&quot;: &quot;wellwell&quot;,\r\n      &quot;alliance_count&quot;: 1,\r\n      &quot;alliance_level&quot;: 1,\r\n      &quot;alliance_power&quot;: 1035,\r\n      &quot;public&quot;: false,\r\n      &quot;alliance_tag&quot;: &quot;MELL&quot;,\r\n      &quot;slogan&quot;: &quot;&quot;,\r\n      &quot;id&quot;: 744085325458334200\r\n    },\r\n    &quot;744128593839677958&quot;: {\r\n      &quot;emblem&quot;: 0,\r\n      &quot;alliance_name&quot;: &quot;Brave&quot;,\r\n      &quot;alliance_count&quot;: 1,\r\n      &quot;alliance_level&quot;: 1,\r\n      &quot;alliance_power&quot;: 1035,\r\n      &quot;public&quot;: false,\r\n      &quot;alliance_tag&quot;: &quot;GABA&quot;,\r\n      &quot;slogan&quot;: &quot;&quot;,\r\n      &quot;id&quot;: 744128593839678000\r\n    },\r\n⋮\r\n  },\r\n  &quot;server_version&quot;: &quot;v7.190.4-master.000000006&quot;\r\n}\r\n\r\n",
                "title": "JQ: key selection from numeric objects"
            },
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1566806377,
                "creation_date": 1566806377,
                "answer_id": 57653920,
                "question_id": 57570621,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "well i am a idiot (to be here totally clear). I found the reason (and this is normally a nobrainer...). I read the input from a file and the funny thing is that the file is Unicode but no UTF8. after recoding the command is working fine. Thanks for the help.\r\n\r\nBR\r\nTimo",
                "title": "JQ: key selection from numeric objects"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1566806377,
        "creation_date": 1566293414,
        "question_id": 57570621,
        "body_markdown": "I use jq 1.6 in a Windows 10 PowerShell enviroment and trying to select keys from  coincidentally numeric json objects.\r\n\r\nJson exampel:\r\n \r\n        {  \r\n       &quot;alliances_info&quot;:{  \r\n          &quot;744085325458334213&quot;:{  \r\n             &quot;emblem&quot;:3,\r\n             &quot;name&quot;:&quot;wellwell&quot;,\r\n             &quot;member_count&quot;:1,\r\n             &quot;level&quot;:1,\r\n             &quot;military_might&quot;:1035,\r\n             &quot;public&quot;:false,\r\n             &quot;tag&quot;:&quot;MELL&quot;,\r\n             &quot;slogan&quot;:&quot;&quot;,\r\n             &quot;id&quot;:744085325458334213\r\n          },\r\n          &quot;744128593839677958&quot;:{  \r\n             &quot;emblem&quot;:0,\r\n             &quot;name&quot;:&quot;Brave&quot;,\r\n             &quot;member_count&quot;:1,\r\n             &quot;level&quot;:1,\r\n             &quot;military_might&quot;:1035,\r\n             &quot;public&quot;:false,\r\n             &quot;tag&quot;:&quot;GABA&quot;,\r\n             &quot;slogan&quot;:&quot;&quot;,\r\n             &quot;id&quot;:744128593839677958\r\n          },\r\n          &quot;746034084459209223&quot;:{  \r\n             &quot;emblem&quot;:0,\r\n             &quot;name&quot;:&quot;Queen&quot;,\r\n             &quot;member_count&quot;:1,\r\n             &quot;level&quot;:1,\r\n             &quot;military_might&quot;:1035,\r\n             &quot;public&quot;:false,\r\n             &quot;tag&quot;:&quot;QUE&quot;,\r\n             &quot;slogan&quot;:&quot;&quot;,\r\n             &quot;id&quot;:746034084459209223\r\n          },\r\n          &quot;750446471312466445&quot;:{  \r\n             &quot;emblem&quot;:0,\r\n             &quot;name&quot;:&quot;Phoenix Inc&quot;,\r\n             &quot;member_count&quot;:35,\r\n             &quot;level&quot;:6,\r\n             &quot;military_might&quot;:453369,\r\n             &quot;public&quot;:true,\r\n             &quot;tag&quot;:&quot;PHOI&quot;,\r\n             &quot;slogan&quot;:&quot;&quot;,\r\n             &quot;id&quot;:750446471312466445\r\n          },\r\n          &quot;750446518934594062&quot;:{  \r\n             &quot;emblem&quot;:11,\r\n             &quot;name&quot;:&quot;Australia&quot;,\r\n             &quot;member_count&quot;:44,\r\n             &quot;level&quot;:8,\r\n             &quot;military_might&quot;:957211,\r\n             &quot;public&quot;:true,\r\n             &quot;tag&quot;:&quot;AUST&quot;,\r\n             &quot;slogan&quot;:&quot;Go Australia&quot;,\r\n             &quot;id&quot;:750446518934594062\r\n          }\r\n       },\r\n       &quot;server_version&quot;:&quot;v7.190.4-master.000000006&quot;\r\n    }\r\n\r\n\r\nI tried several jq commands:\r\n\r\n    .alliances_info | .[] |  [{alliance_name: .name, alliance_count: .member_count, alliance_level: .level, alliance_power: .military_might, alliance_tag: .tag, alliance_slogan: .slogan, alliance_id: .id}]\r\n\r\nor\r\n\r\n    .alliances_info | .. | objects |  [{alliance_name: .name, alliance_c\r\n    ount: .member_count, alliance_level: .level, alliance_power: .military_might, alliance_tag: .tag, alliance_slogan: .slog\r\n    an, alliance_id: .id}]\r\n\r\n\r\nBut Always get a jq error: parse error: Invalid numeric literal at line 1, column 3\r\n\r\nI renounce on the object Building in the first command (and built only a Array) it works. But i need that objects. Any tips?\r\n\r\nBR\r\nTimo\r\n",
        "link": "https://stackoverflow.com/questions/57570621/jq-key-selection-from-numeric-objects",
        "title": "JQ: key selection from numeric objects"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1566296034,
                "last_edit_date": 1566296034,
                "creation_date": 1566294934,
                "answer_id": 57571083,
                "question_id": 57570967,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Don&#39;t use single quotes while defining `search_command` and enclose it in double quotes while referencing, like:\r\n```\r\nsearch_command=&quot;.defines[] | select(.id==$current_id)&quot;\r\nout_json=&quot;$(jq &quot;$search_command&quot; source.json)&quot;\r\n```",
                "title": "How to call jq in bash to store returned value in variable"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1566315798,
                "creation_date": 1566315798,
                "answer_id": 57577244,
                "question_id": 57570967,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "As with any other language, don&#39;t use string interpolation to define a command. Pass `current_id` as an argument to a *static* filter.\r\n\r\n    search_command=&#39;.defines[] | select(.id==$x)&#39;\r\n    out_json=$(jq --argjson x &quot;$current_id&quot; &quot;$search_command&quot; source.json)",
                "title": "How to call jq in bash to store returned value in variable"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": -1,
        "last_activity_date": 1584127317,
        "creation_date": 1566294601,
        "question_id": 57570967,
        "body_markdown": "I am trying to read json file and get a single object out of it, by reading that object into bash script variable.\r\n\r\nHere how I was hoping to do that:\r\n\r\n    search_command=&quot;&#39;.defines[] | select(.id==$current_id)&#39;&quot;\r\n    echo $search_command\r\n    out_json=`jq $search_command source.json`\r\n\r\nwhere `current_id` is a variable with previously read id value. When I run this script, the output of the &quot;debugging echo&quot; is of expected value:\r\n\r\n    &#39;.defines[] | select(.id==2)&#39;\r\nbut after that, I get this message:\r\n\r\n    jq: error: syntax error, unexpected INVALID_CHARACTER, expecting $end (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n    &#39;.defines[]\r\n    jq: 1 compile error\r\n\r\nWhen I make a direct call in terminal with same parameters using:\r\n\r\n    jq &#39;.defines[] | select(.id==2)&#39; source.json\r\nI see desired output.\r\n\r\nI am quite new to bash scripting, so I can only guess that it&#39;s not jq part that is the source of problem, but the way I am trying to call it in bash. I&#39;ve tried removing spaces inside the `search_command`, but that did not change much (this time error message had full contents of `search_command` in it, so I am guessing that this one is more valid, but still not valid enough).",
        "link": "https://stackoverflow.com/questions/57570967/how-to-call-jq-in-bash-to-store-returned-value-in-variable",
        "title": "How to call jq in bash to store returned value in variable"
    },
    {
        "tags": [
            "json",
            "batch-processing",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2248857,
                    "reputation": 87,
                    "user_id": 1981815,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/hUYgg.jpg?s=256",
                    "display_name": "dabbl0r",
                    "link": "https://stackoverflow.com/users/1981815/dabbl0r"
                },
                "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": 1566297844,
                "post_id": 57571424,
                "comment_id": 101604160,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": -1,
                "last_activity_date": 1566325078,
                "last_edit_date": 1566325078,
                "creation_date": 1566303845,
                "answer_id": 57573607,
                "question_id": 57571424,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I think you are looking for [hasOwnProperty()][1]\r\n\r\nfor example:\r\n\r\n    var value;\r\n    if(applications.gecko.hasOwnProperty(&#39;id&#39;))\r\n       value = applications.gecko.id;\r\n    else\r\n       value = &#39;error&#39;;\r\n\r\n  [1]: https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Object/hasOwnProperty",
                "title": "&quot;Ternary logic&quot; for returned value: foo, bar or error"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1566327438,
                "last_edit_date": 1566327438,
                "creation_date": 1566304296,
                "answer_id": 57573738,
                "question_id": 57571424,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use a combination of the `?` &quot;error suppression&quot; and `//` &quot;alternative` operators :\r\n\r\n    jq -n --slurpfile variantA yourFirstFile --slurpfile variantB yourSecondFile \\\r\n    &#39;(\r\n      ($variantA[0].browser_specific_settings.gecko.id)?, \r\n      ($variantB[0].applications.gecko.id)?\r\n    ) // &quot;error&quot;&#39;\r\n\r\nThis will output the id from the first file and/or the id from the second file if any of the two exist, avoiding to raise errors when they don&#39;t, and output `error` instead if none of them can be found.\r\n\r\nThe command can be shortened as follows if it makes sense in your context :\r\n\r\n    jq -n --slurpfile variantA yourFirstFile --slurpfile variantB yourSecondFile \\\r\n    &#39;(($variantA[0].browser_specific_settings, $variantB[0].applications) | .gecko.id)? // &quot;error&quot;&#39;\r\n",
                "title": "&quot;Ternary logic&quot; for returned value: foo, bar or error"
            },
            {
                "up_vote_count": 10,
                "is_accepted": false,
                "score": 10,
                "last_activity_date": 1566307610,
                "last_edit_date": 1566307610,
                "creation_date": 1566304660,
                "answer_id": 57573863,
                "question_id": 57571424,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use a filter as below that could work with both your sample JSON content provided\r\n\r\n    jq &#39;.. | if type == &quot;object&quot; and has(&quot;id&quot;) then .id else empty end&#39;\r\n\r\nSee them live [jqplay - VariantA](https://jqplay.org/s/NMilHWWc33) and [jqplay - VariantB](https://jqplay.org/s/BIY2qgj4CW)\r\n\r\n**Note**: This only gets the value of `.id` when it is present, see others answers ([oguz ismail&#39;s](https://stackoverflow.com/a/57573926/5291015)) for displaying `error` when the object does not contain the required field.\r\n",
                "title": "&quot;Ternary logic&quot; for returned value: foo, bar or error"
            },
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1566384956,
                "last_edit_date": 1566384956,
                "creation_date": 1566304867,
                "answer_id": 57573926,
                "question_id": 57571424,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```lang-none\r\n(.. | objects | select(has(&quot;id&quot;))).id // &quot;error&quot;\r\n```\r\nThis will work with multiple files and files containing multiple separate entities.\r\n\r\n&lt;sub&gt;[jqplay demo](https://jqplay.org/s/y14Dmo-0XF)&lt;/sub&gt;",
                "title": "&quot;Ternary logic&quot; for returned value: foo, bar or error"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1566360465,
                "last_edit_date": 1566360465,
                "creation_date": 1566359949,
                "answer_id": 57584248,
                "question_id": 57571424,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; I need the id values (*gecko.id so to speak) or error if there is none:\r\n\r\nIn accordance with your notation `&quot;*gecko.id&quot;`, here are two solutions, the first interpreting the &quot;*&quot; as a single unknown key (or index), the second interpreting it (more or less) as any number of keys or indices:\r\n\r\n```\r\n.[] | .gecko.id // &quot;error&quot;\r\n```\r\n\r\n```\r\n.. | objects | select(has(&quot;gecko&quot;)) | (.gecko.id // &quot;error&quot;)\r\n```\r\n\r\nIf you don&#39;t really care about whether there&#39;s a &quot;gecko&quot; key, you might wish to consider:\r\n\r\n```    \r\nfirst(.. | objects | select(has(&quot;id&quot;)).id ) // &quot;error&quot;\r\n```\r\n",
                "title": "&quot;Ternary logic&quot; for returned value: foo, bar or error"
            }
        ],
        "is_answered": true,
        "answer_count": 5,
        "score": 5,
        "last_activity_date": 1566384956,
        "creation_date": 1566296209,
        "last_edit_date": 1566305534,
        "question_id": 57571424,
        "body_markdown": "I&#39;ve got two different JSON structures to retrieve a specific object value from, basically something like this\r\n\r\n    {\r\n        &quot;one&quot;: {\r\n            &quot;foo&quot;: {\r\n                &quot;bar&quot;: &quot;baz&quot;\r\n            }\r\n        }\r\n    }\r\n\r\nand another like that\r\n\r\n    {\r\n        &quot;two&quot;: {\r\n            &quot;foo&quot;: {\r\n                &quot;bar&quot;: &quot;qux&quot;\r\n            }\r\n        }\r\n    }\r\n\r\nI&#39;d like to return the `bar` value in both cases plus an additional return variant `error` in case neither case 1&#160;-&#160;`baz` - nor case 2&#160;-&#160;`qux` - matches anything (i.e. matches `null`).\r\n\r\nIs there a simple way to do that with just jq 1.6?\r\n\r\n**Update:**\r\nHere are snippets of actual JSON files:\r\n\r\n    /* manifest.json, variant A */\r\n    {\r\n        &quot;browser_specific_settings&quot;: {\r\n            &quot;gecko&quot;: {\r\n                &quot;id&quot;: &quot;{95ad7b39-5d3e-1029-7285-9455bcf665c0}&quot;,\r\n                &quot;strict_min_version&quot;: &quot;68.0&quot;\r\n            }\r\n        }\r\n    }\r\n\r\n    /* manifest.json, variant B */\r\n    {\r\n        &quot;applications&quot;: {\r\n            &quot;gecko&quot;: {\r\n                &quot;id&quot;: &quot;j30D-3YFPUvj9u9izFoPSjlNYZfF22xS@foobar&quot;,\r\n                &quot;strict_min_version&quot;: &quot;53.0&quot;\r\n            }\r\n        }\r\n    }\r\n\r\nI need the `id` values (*gecko.id so to speak) or `error` if there is none:\r\n\r\n    {95ad7b39-5d3e-1029-7285-9455bcf665c0}\r\n    j30D-3YFPUvj9u9izFoPSjlNYZfF22xS@foobar\r\n    error",
        "link": "https://stackoverflow.com/questions/57571424/ternary-logic-for-returned-value-foo-bar-or-error",
        "title": "&quot;Ternary logic&quot; for returned value: foo, bar or error"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3377285,
                    "reputation": 21,
                    "user_id": 2835192,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/49b6b8dc2d5c00093dfc7b182ce765b3?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "user2835192",
                    "link": "https://stackoverflow.com/users/2835192/user2835192"
                },
                "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": 1566309114,
                "post_id": 57573760,
                "comment_id": 101610679,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1566342711,
                "creation_date": 1566342711,
                "answer_id": 57582586,
                "question_id": 57573760,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Rather than tying yourself up in knots, it would I think be better to build on the reusable component that&#39;s already been developed and tested:\r\n```\r\ndef etl(keyname; arrayname; cond; result):\r\n  def etl:\r\n    . as $parent\r\n    | .[arrayname][]\r\n    | { parent: $parent, child: .}\r\n    | select(cond) | result;\r\n {(keyname): map(etl)}\r\n ;\r\n```\r\n\r\nHere&#39;s one way to do so:\r\n```\r\ndef add(arrayname):\r\n  etl(arrayname;\r\n    &quot;events&quot;;\r\n    ( (.parent.workorder.startDate | dateDaysAgo(12*7) ) &lt; .child.endDate)\r\n      and\r\n      (.child.vendorId == .parent.workorder.vendorId);\r\n   {\r\n     event: .child.id,\r\n     wo_sd: .parent.workorder.startDate[:10],\r\n     workorder_id: .parent.workorder.id\r\n   }\r\n  )\r\n  ;\r\n\r\n[add(&quot;conflictsInPeriod&quot;) + .[]]\r\n```\r\n\r\nWith `etl` you have a reusable component that allows numerous variations while keeping things simple. ",
                "title": "JQ using an ETL, to create an inner array, in a JSON Array"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1566342711,
        "creation_date": 1566304361,
        "last_edit_date": 1566309606,
        "question_id": 57573760,
        "body_markdown": "I need to update an inner array, with an ETL;\r\n\r\nI want to create a new property in an array&#39;s element in the JSON tree\r\n\r\n## Something like\r\n```\r\n    def insideETL(keyname; arrayname; cond; result):\r\n      def etl:\r\n        . as $parent\r\n        | .[arrayname][]\r\n        | { parent: $parent, child: .}\r\n        | select(cond) | result;\r\n    \r\n      map ( . \r\n            +\r\n            {(keyname): map(etl)}\r\n          )\r\n    ;\r\n\r\n```\r\n\r\n\r\n## From a previous [question](https://stackoverflow.com/a/57565022/2835192) \r\nHad almost the needed result, but i do have the need to create more than one array, in each item of the **Main JSON array**; \r\n\r\n\r\nData to filter\r\n```\r\n[\r\n {\r\n        &quot;storeId&quot;: &quot;s2&quot;,\r\n        &quot;storehouseInfo&quot;: {\r\n            &quot;id&quot;: &quot;025453&quot;,\r\n            &quot;name&quot;: &quot;00211 NW, OR&quot;,\r\n            &quot;maxPallets&quot;: 10\r\n        },\r\n        &quot;workorder&quot;:{\r\n            &quot;id&quot;: &quot;w2s2&quot;,\r\n            &quot;startDate&quot;: &quot;2019-09-06T10:00:00.000Z&quot;,\r\n            &quot;vendorId&quot;:&quot;v2&quot;\r\n        },\r\n        &quot;events&quot;: [    \r\n            {\r\n                &quot;id&quot;: &quot;e4&quot;,\r\n                &quot;storeId&quot;: &quot;s2&quot;,\r\n                &quot;vendorId&quot;: &quot;v1&quot;,\r\n                &quot;startDate&quot;: &quot;2019-09-05T10:00:00.000Z&quot;,\r\n                &quot;endDate&quot;: &quot;2019-09-14T00:00:00.000Z&quot;,\r\n                &quot;palletsUsed&quot;: 5\r\n            },\r\n            {\r\n                &quot;id&quot;: &quot;e5&quot;,\r\n                &quot;storeId&quot;: &quot;s2&quot;,\r\n                &quot;vendorId&quot;: &quot;v2&quot;,\r\n                &quot;startDate&quot;: &quot;2019-09-05T00:00:00.000Z&quot;,\r\n                &quot;endDate&quot;: &quot;2019-09-14T00:00:00.000Z&quot;,\r\n                &quot;palletsUsed&quot;: 5\r\n            },\r\n            {\r\n                &quot;id&quot;: &quot;e10&quot;,\r\n                &quot;storeId&quot;: &quot;s2&quot;,\r\n                &quot;vendorId&quot;: &quot;v1&quot;,\r\n                &quot;startDate&quot;: &quot;2019-09-06T10:00:00.000Z&quot;,\r\n                &quot;endDate&quot;: &quot;2019-09-14T00:00:00.000Z&quot;,\r\n                &quot;palletsUsed&quot;: 5\r\n            },\r\n            {\r\n                &quot;id&quot;: &quot;e11&quot;,\r\n                &quot;storeId&quot;: &quot;s2&quot;,\r\n                &quot;vendorId&quot;: &quot;v2&quot;,\r\n                &quot;startDate&quot;: &quot;2019-09-06T00:00:00.000Z&quot;,\r\n                &quot;endDate&quot;: &quot;2019-09-14T00:00:00.000Z&quot;,\r\n                &quot;palletsUsed&quot;: 5\r\n            },\r\n            {\r\n                &quot;id&quot;: &quot;e12&quot;,\r\n                &quot;storeId&quot;: &quot;s2&quot;,\r\n                &quot;vendorId&quot;: &quot;v2&quot;,\r\n                &quot;startDate&quot;: &quot;2019-09-06T10:00:00.000Z&quot;,\r\n                &quot;endDate&quot;: &quot;2019-09-14T00:00:00.000Z&quot;,\r\n                &quot;palletsUsed&quot;: 5\r\n            }\r\n        ]\r\n    },\r\n]\r\n```\r\n\r\nDesired invocation\r\n```\r\n.| \r\n  insideETL(&quot;conflictsInPeriod&quot;;\r\n    &quot;events&quot;;\r\n    ( (.parent.workorder.startDate | dateDaysAgo(12*7) ) &lt; .child.endDate)\r\n      and\r\n      (.child.vendorId == .parent.workorder.vendorId);\r\n   {\r\n     event: .child.id,\r\n     wo_sd: .parent.workorder.startDate[:10],\r\n     workorder_id: .parent.workorder.id\r\n   }\r\n)\r\n```\r\n\r\nDesired output\r\n```\r\n    [\r\n        {\r\n            // our newly added array \r\n            &quot;conflictsInPeriod&quot;:[\r\n                {\r\n                    &quot;event&quot;:&quot;e5&quot;,\r\n                    &quot;workorder_sd&quot;:&quot;2019-09-06&quot;,\r\n                    &quot;workorder_id&quot;:&quot;w2s2&quot;\r\n                },\r\n                {\r\n                    &quot;event_id&quot;:&quot;e11&quot;,\r\n                    &quot;workorder_sd&quot;:&quot;2019-09-06&quot;,\r\n                    &quot;workorder_id&quot;:&quot;w2s2&quot;\r\n                },\r\n                {\r\n                    &quot;event_id&quot;:&quot;e12&quot;,\r\n                    &quot;workorder_sd&quot;:&quot;2019-09-06&quot;,\r\n                    &quot;workorder_id&quot;:&quot;w2s2&quot;\r\n                }\r\n            ],\r\n            // all the other previous information in the Item\r\n            &quot;storeId&quot;:&quot;s2&quot;,\r\n            &quot;storehouseInfo&quot;:{\r\n                &quot;id&quot;:&quot;025453&quot;,\r\n                &quot;name&quot;:&quot;00211 NW, OR&quot;,\r\n                &quot;maxPallets&quot;:10\r\n            },\r\n            &quot;workorder&quot;:{\r\n                &quot;id&quot;:&quot;w2s2&quot;,\r\n                &quot;startDate&quot;:&quot;2019-09-06T10:00:00.000Z&quot;,\r\n                &quot;vendorId&quot;:&quot;v2&quot;\r\n            },\r\n            &quot;events&quot;:[\r\n                // ...  All the events data\r\n            ]\r\n        }\r\n    ]\r\n``` \r\n\r\nHope it is clear, If it is needed any clarification... please comment.",
        "link": "https://stackoverflow.com/questions/57573760/jq-using-an-etl-to-create-an-inner-array-in-a-json-array",
        "title": "JQ using an ETL, to create an inner array, in a JSON Array"
    },
    {
        "tags": [
            "json",
            "dictionary",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1566321130,
                "creation_date": 1566321130,
                "answer_id": 57578591,
                "question_id": 57578108,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```\r\n# First remove the subkeys that are not truthy:\r\nmap_values(with_entries(select(.value)))\r\n# ... then remove the empty dictionaries:\r\n| with_entries(select(.value|length &gt; 0))\r\n```\r\n\r\nAdd seasoning to taste.",
                "title": "Extracting data using JQ"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1566544397,
                "creation_date": 1566544397,
                "answer_id": 57621442,
                "question_id": 57578108,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Another jq script:\r\n\r\n    &lt;file jq &#39;del(..|select(. == false))&#39;\r\n\r\nThis recursively goes to all nodes (operator `..`) and deletes all elements whose value would be `false`.\r\n\r\nIf needed, you can change the criteria in the `select` with something else than `false`, for example `&quot;Failure&quot;`.",
                "title": "Extracting data using JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1566544397,
        "creation_date": 1566319132,
        "last_edit_date": 1566322875,
        "question_id": 57578108,
        "body_markdown": "I am trying to use jq to extract data from JSON fields that contain a specific value.\r\n\r\nThis is the JSON that I&#39;m working with:\r\n\r\n    {\r\n      &quot;thing1&quot;: {\r\n        &quot;a&quot;: false,\r\n        &quot;b&quot;: true,\r\n        &quot;c&quot;: false,\r\n        &quot;d&quot;: false\r\n      },\r\n      &quot;thing2&quot;: {\r\n        &quot;a&quot;: true,\r\n        &quot;b&quot;: true,\r\n        &quot;c&quot;: true,\r\n        &quot;d&quot;: true\r\n      },\r\n      &quot;thing3&quot;: {\r\n        &quot;a&quot;: true,\r\n        &quot;b&quot;: false,\r\n        &quot;c&quot;: false,\r\n        &quot;d&quot;: false\r\n      }\r\n    }\r\n\r\nI want to retain the objects that contain `&quot;true&quot;` values, and to remove keys whose value is not `true`.\r\n\r\n\r\nI don&#39;t have much experience with JQ, nor how to properly structure json data. If this means restructuring the primary JSON data, I&#39;m open to do that as well.  \r\n\r\nHere is the result I&#39;m trying to achieve:\r\n\r\n    {\r\n      &quot;thing1&quot;: {\r\n        &quot;b&quot;: true\r\n      },\r\n      &quot;thing2&quot;: {\r\n        &quot;a&quot;: true,\r\n        &quot;b&quot;: true,\r\n        &quot;c&quot;: true,\r\n        &quot;d&quot;: true\r\n      },\r\n      &quot;thing3&quot;: {\r\n        &quot;a&quot;: true\r\n      }\r\n    }\r\n",
        "link": "https://stackoverflow.com/questions/57578108/extracting-data-using-jq",
        "title": "Extracting data using JQ"
    },
    {
        "tags": [
            "jq",
            "keyword"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1566355748,
                "last_edit_date": 1566355748,
                "creation_date": 1566340980,
                "answer_id": 57582378,
                "question_id": 57582199,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This was fixed in more recent versions of jq. I can do this:\r\n\r\n    $ jq --version\r\n    jq-1.6-1-g2f2d05b\r\n    $ jq .end &lt;&lt;&lt; &#39;{&quot;start&quot;: 10, &quot;end&quot;: 20}&#39;\r\n    20\r\n\r\nYour second attempt failed because the shell removes the double quotes. You have to protect them by quoting the whole thing:\r\n\r\n    jq &#39;.[&quot;end&quot;]&#39;\r\n\r\n----\r\n\r\nThe relevant issue that describes your initial problem is [Reserved words should not generate errors when used as object keys][1]; the fix was in [this commit][2], and it looks like it was in jq since [version 1.5rc2][3].\r\n\r\n\r\n  [1]: https://github.com/stedolan/jq/issues/794\r\n  [2]: https://github.com/stedolan/jq/commit/11f084f9a71ac5feacb563096aa68deb57a3bc41\r\n  [3]: https://github.com/stedolan/jq/releases/tag/jq-1.5rc2",
                "title": "Can&#39;t print a field called &quot;end&quot; using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1566355748,
        "creation_date": 1566339631,
        "last_edit_date": 1566350641,
        "question_id": 57582199,
        "body_markdown": "I&#39;m trying to print out a field called &quot;end&quot; from a json file using `jq` but am running into the following error:\r\n\r\n```\r\n$ echo &#39;{&quot;start&quot;: 10, &quot;end&quot;: 20}` &gt; /tmp/out.json\r\n$ jq .start /tmp/out.json\r\n10\r\n$ jq .end /tmp/out.json\r\nerror: syntax error, unexpected end, expecting $end\r\n.end\r\n ^^^\r\n1 compile error\r\n```\r\n\r\nThis issue (https://github.com/stedolan/jq/issues/256) suggests using `.[&quot;end&quot;]` as the selector but that doesn&#39;t seem to work either.\r\n\r\n```\r\n$ jq .[&quot;end&quot;] /tmp/out.json\r\nerror: syntax error, unexpected end\r\n.[end]\r\n  ^^^\r\n1 compile error\r\n```\r\n\r\nAny ideas?",
        "link": "https://stackoverflow.com/questions/57582199/cant-print-a-field-called-end-using-jq",
        "title": "Can&#39;t print a field called &quot;end&quot; using jq"
    },
    {
        "tags": [
            "xml",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1566370589,
                "creation_date": 1566370589,
                "answer_id": 57586053,
                "question_id": 57585761,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "A simple (hackish) solution would be to add one more invocation of jq along the lines of:\r\n\r\n    jq -s . deploy.json | sponge deploy.json\r\n\r\nIt might be worth your while, though, to think about how to eliminate the bash loop altogether, perhaps using an XML-to-JSON transmogrifier, or maybe better yet an XML wrapper for jq, such as https://github.com/kislyuk/yq.",
                "title": "Constructing a syntax correct JSON file via BASH while loop"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1566380364,
                "creation_date": 1566380364,
                "answer_id": 57588723,
                "question_id": 57585761,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I suggest to only ouptut the relevant value from inside the loop and have `jq` work on the output of the loop. It is made easier if you have the loop output correct JSON (strings must be enclosed in double quotes), as the combination of --raw-input and --slurp that is otherwise necessary requires splitting the input around \\n.\r\n\r\n    while read_dom; do\r\n        if [[ $ELEMENT == &quot;Key&quot; ]] &amp;&amp; [[ $STRING == *&quot;string&quot;* ]]; then\r\n            if ! grep -Fxq &quot;{\\&quot;name\\&quot;:\\&quot;${STRING}\\&quot;,\\&quot;value\\&quot;:\\&quot;${STRING}\\&quot;}&quot; deploy.json; then\r\n                echo &quot;\\&quot;${STRING}\\&quot;&quot;\r\n            fi\r\n        fi\r\n    done &lt; input.txt | jq --slurp &#39;map({ key: ., value: .})&#39;\r\n\r\nIn that code the loop outputs something like that :\r\n\r\n    &quot;someName1&quot;\r\n    &quot;someName2&quot;\r\n    &quot;someName3&quot;\r\n\r\nThen the `jq` command which receives that input works on an array of those JSON elements thanks to `--slurp`, which it transforms by mapping each element to an object with key/value fields as you can see [here](https://jqplay.org/s/dvTvhiKVKv).",
                "title": "Constructing a syntax correct JSON file via BASH while loop"
            },
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1566403924,
                "last_edit_date": 1566403924,
                "creation_date": 1566400897,
                "answer_id": 57594825,
                "question_id": 57585761,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Sometimes it helps to take a step back, walk away then come back. Thanks for your suggestions peak and Aaron, but after going to sleep and waking up thinking about it for awhile after toying with the suggestions, jq was not actually necessary in achieving my goal, at least not in a rudimentary fashion.\r\n\r\nI removed jq from the equation all together and instead used the while loop to construct a bash array, then transform that bash array into JSON compliant syntax in a way that satisfies my Rundeck use case:\r\n\r\n```\r\n#! /bin/bash\r\n\r\nbaseUrl=hostname/tenant:dir/\r\nwget -q $baseUrl --output-document=output.xml\r\n\r\nread_dom () {\r\n    local IFS=\\&gt;\r\n    read -d \\&lt; ELEMENT STRING\r\n}\r\n\r\ndeploy=()\r\nwhile read_dom; do\r\n    if [[ $ELEMENT == &quot;Key&quot; ]] &amp;&amp; [[ $STRING == *&quot;STRING&quot;* ]]; then\r\n        deploy+=(&quot;${STRING}&quot;)\r\n    fi\r\ndone &lt; output.xml\r\n\r\nif [ ! -f deploy.json ]; then touch deploy.json; fi\r\njson=&quot;[$(printf &#39;&quot;%q&quot;,&#39; &quot;${deploy[@]}&quot;)&quot;\r\njson=&quot;${json%,}]&quot;\r\necho &quot;$json&quot; &gt; deploy.json\r\n```\r\n\r\nOutput:\r\n```\r\n[user@hostname deploy]$ cat deploy.json\r\n[&quot;someValue1&quot;,&quot;someValue2&quot;,&quot;someValue3&quot;,&quot;someValue4&quot;,&quot;someValue5&quot;,&quot;someValue6&quot;,&quot;someValue7&quot;,&quot;someValue8&quot;]\r\n```\r\n\r\nI also removed the need for the condition around the no-match grep by simply continuing to filter what gets added to the array, and reconstruct the entire array instead of appending an additional object.\r\n\r\nIt probably wouldn&#39;t scale to be very performant over thousands of objects, but in my use case it doesn&#39;t need to.",
                "title": "Constructing a syntax correct JSON file via BASH while loop"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1566403924,
        "creation_date": 1566369534,
        "question_id": 57585761,
        "body_markdown": "Receive remote XML document (S3 bucket file listing), extract relevant keys and build syntax correct JSON file. File will be appended onto in the future.\r\n\r\nSeveral iterations of applying filters for jq while passing an argument containing the value of the relevant element/string pair from XML source.\r\n\r\n```\r\n#! /bin/bash\r\n\r\nbaseUrl=https://hostname/tenant:bucket/\r\nwget -q $baseUrl --output-document=output.xml\r\n\r\nread_dom () {\r\n    local IFS=\\&gt;\r\n    read -d \\&lt; ELEMENT STRING\r\n}\r\n\r\nwhile read_dom; do\r\n    if [[ $ELEMENT == &quot;Key&quot; ]] &amp;&amp; [[ $STRING == *&quot;string&quot;* ]]; then\r\n        if ! grep -Fxq &quot;{\\&quot;name\\&quot;:\\&quot;${STRING}\\&quot;,\\&quot;value\\&quot;:\\&quot;${STRING}\\&quot;}&quot; deploy.json; then\r\n            jq -cn --arg kv &quot;${STRING}&quot; &#39;{name: $kv, value: $kv}&#39; &gt;&gt; deploy.json\r\n        fi\r\n    fi\r\ndone &lt; output.xml\r\n```\r\n\r\nAbove is the full script which fetches the remote document (S3 bucket file listing), then iterates over the document with a while loop while filtering the contents of each Key for the specific filetype.\r\n\r\nDuring the while loop, it iterates over the file `deploy.json` to grep for a no-match for the current `while` iteration value. If it doesn&#39;t find a match it proceeds to append it to the file as a new JSON object, otherwise it skips it.\r\n\r\nOutput from running the above script:\r\n\r\n```\r\n[user@hostname deploy]$ cat deploy.json\r\n{&quot;name&quot;:&quot;someName1&quot;,&quot;value&quot;:&quot;someValue1&quot;}\r\n{&quot;name&quot;:&quot;someName2&quot;,&quot;value&quot;:&quot;someValue2&quot;}\r\n{&quot;name&quot;:&quot;someName3&quot;,&quot;value&quot;:&quot;someValue3&quot;}\r\n{&quot;name&quot;:&quot;someName4&quot;,&quot;value&quot;:&quot;someValue4&quot;}\r\n{&quot;name&quot;:&quot;someName5&quot;,&quot;value&quot;:&quot;someValue5&quot;}\r\n{&quot;name&quot;:&quot;someName6&quot;,&quot;value&quot;:&quot;someValue6&quot;}\r\n{&quot;name&quot;:&quot;someName7&quot;,&quot;value&quot;:&quot;someValue7&quot;}\r\n```\r\n\r\nWhat I need the output to be, is as follows:\r\n\r\n```\r\n[\r\n  {&quot;name&quot;:&quot;someName1&quot;,&quot;value&quot;:&quot;someValue1&quot;},\r\n  {&quot;name&quot;:&quot;someName2&quot;,&quot;value&quot;:&quot;someValue2&quot;},\r\n  {&quot;name&quot;:&quot;someName3&quot;,&quot;value&quot;:&quot;someValue3&quot;},\r\n  {&quot;name&quot;:&quot;someName4&quot;,&quot;value&quot;:&quot;someValue4&quot;},\r\n  {&quot;name&quot;:&quot;someName5&quot;,&quot;value&quot;:&quot;someValue5&quot;},\r\n  {&quot;name&quot;:&quot;someName6&quot;,&quot;value&quot;:&quot;someValue6&quot;},\r\n  {&quot;name&quot;:&quot;someName7&quot;,&quot;value&quot;:&quot;someValue7&quot;}\r\n]\r\n```\r\n\r\nThe reason for the specific need of formatting for this list is the use case as an Option Model Provider for a Rundeck job. I&#39;m trying to dynamically populate a list of deployment options as VM images are uploaded to S3 storage after their creation. As new images are created, this script will run during the cleanup stage and update the contents of the `deploy.json` file.\r\n\r\nRegardless of what I try with jq, I can never get it quite right, I can feel that I&#39;m right on the precipice of achieving it, but alas I lack the requisite experience with jq to articulate via syntax what is necessary to reach the summit.",
        "link": "https://stackoverflow.com/questions/57585761/constructing-a-syntax-correct-json-file-via-bash-while-loop",
        "title": "Constructing a syntax correct JSON file via BASH while loop"
    },
    {
        "tags": [
            "json",
            "yaml",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1566394627,
                "last_edit_date": 1566394627,
                "creation_date": 1566375890,
                "answer_id": 57587384,
                "question_id": 57586614,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The good news is that you&#39;re close.\r\n\r\nFor simplicity, I&#39;m going to assume that the .yaml conversion to .json has already been done. Slightly adapting your filter, it&#39;s easy to see that:\r\n\r\n    jq &#39;{ (.sdgs[]|tostring): del(.sdgs) }&#39; a11y.json gnu_health.json bahmni.json\r\n\r\nproduces a stream of four single-key objects corresponding closely to what you want.  \r\n\r\nTo combine them into a single object is a tiny bit tricky.  To keep things simple, let&#39;s first define a helper function which can be used to group single-key objects by key:\r\n```\r\n  def group_by_keys: reduce .[] as $o ({}; \r\n     reduce ($o | to_entries[]) as $kv (.; .[$kv.key]\r\n```\r\n\r\nNext, we&#39;ll use `inputs` with the -n command line option:\r\n```\r\njq -n &#39;\r\n  def group_by_keys: reduce .[] as $o ({}; \r\n     reduce ($o | to_entries[]) as $kv (.; .[$kv.key] += [$kv.value]));\r\n  [inputs | {(.sdgs[]|tostring): del(.sdgs) }] | group_by_keys\r\n\r\n&#39; a11y.json gnu_health.json bahmni.json\r\n\r\n```\r\n(Don&#39;t forget `-n`.)\r\n\r\nIf the ordering of the keys is important, then simply use this filter:\r\n\r\n    def sort_by_keys:\r\n      to_entries\r\n      | sort_by(.key|tonumber)\r\n      | from_entries;\r\n",
                "title": "Merge yaml files and re-organize by values of key value list"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1566394627,
        "creation_date": 1566372798,
        "last_edit_date": 1566392354,
        "question_id": 57586614,
        "body_markdown": "I have a list of yaml files, each describing a project, with a key `sdgs` which contains a list of numbers representing the Sustainable Development Goals.\r\n\r\nI would like to merge all files and convert them to json in a different format, with sdg indexes as key, and related projects as list values.\r\n\r\nInput:\r\n\r\n```yml\r\n---\r\n# gnu_health.yaml\r\ndescription: &gt;\r\n  GNU Health is a Free/Libre project for health practitioners, health\r\n  institutions and governments. It provides the functionality of Electronic\r\n  Medical Record (EMR), Hospital Management (HMIS) and Health Information\r\n  System (HIS).\r\nsdgs: [3]\r\nname: GNU Health \r\n\r\n---\r\n# a11y.yaml\r\ndescription: &gt;\r\n  This Accessibility Project is a community-driven effort to make web\r\n  accessibility easier by leveraging a worldwide community of developer\r\n  knowledge.\r\nsdgs: [10]\r\nname: A11Y\r\n\r\n---\r\n# bahmni.yaml\r\ndescription: &gt;\r\n  Bahmni is an Open Source hospital Management System focusing\r\n  on poor/underserved and public hospitals in the developing\r\n  world.\r\n  It&#39;s aimed to being a generic system which can be used for\r\n  multiple diseases and hospitals in different countries.\r\nsdgs: [1, 3]\r\nname: Bahmni\r\n```\r\n\r\n**Expected Output**:\r\n\r\n```json\r\n{\r\n  &quot;1&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;Bahmni&quot;,\r\n      &quot;description: &quot;...&quot;\r\n    }\r\n  ],\r\n  &quot;3&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;GNU Health&quot;,\r\n      &quot;description: &quot;...&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;Bahmni&quot;,\r\n      &quot;description: &quot;...&quot;\r\n    }\r\n  ],\r\n  &quot;10&quot;: [\r\n    {\r\n      &quot;name: &quot;A11Y&quot;,\r\n      &quot;description: &quot;...&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nI&#39;m finding it surprisingly difficult to figure this out using jq&#39;s filtering system, even after reading the [manual][1] and other [awesome-jq][2] resources.\r\n\r\nCan someone point me to the right direction?\r\n\r\n\r\n\r\nCurrent best effort:\r\n\r\n```jq\r\n# use as follow: yq -f $binDir/concat_sdgs.jq $srcDir/*.y*ml\r\n\r\n# concat_sdgs.jq\r\n{\r\n  (.sdgs[]|tostring): [.]\r\n}\r\n```\r\n\r\nThis will not merge projects from the same sdg together unfortunately\r\n\r\n\r\n**Current incorrect output**:\r\n\r\n```json\r\n{\r\n  &quot;1&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;Bahmni&quot;,\r\n      &quot;description: &quot;...&quot;\r\n    }\r\n  ],\r\n  &quot;3&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;GNU Health&quot;,\r\n      &quot;description: &quot;...&quot;\r\n    }\r\n  ],\r\n  &quot;3&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;Bahmni&quot;,\r\n      &quot;description: &quot;...&quot;\r\n    }\r\n  ],\r\n  &quot;10&quot;: [\r\n    {\r\n      &quot;name: &quot;A11Y&quot;,\r\n      &quot;description: &quot;...&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\n----------\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/\r\n  [2]: https://github.com/fiatjaf/awesome-jq",
        "link": "https://stackoverflow.com/questions/57586614/merge-yaml-files-and-re-organize-by-values-of-key-value-list",
        "title": "Merge yaml files and re-organize by values of key value list"
    },
    {
        "tags": [
            "amazon-web-services",
            "aws-api-gateway",
            "jq",
            "boto"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1566807570,
                "creation_date": 1566807570,
                "answer_id": 57654202,
                "question_id": 57602000,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Boto is the Amazon Web Services (AWS) SDK for Python. Showing the output in the tabular format can be achieved by using Python output techniques along with different Python data structures.\r\n\r\nIn the following links, you can find API references that you can use for your API Gateway deployments to get all the information that you require using APIs like `get_deployments()`, `get_integration()`, `get_integration_response()`, etc: \r\n\r\n 1. [Boto3 API Gateway APIs][1]\r\n 2. [Boto3 API Gateway v2 APIs][2]\r\n\r\nIf you want to use AWS CLI, you can use `--output table` parameter with the respective CLI command. For example: `aws apigateway get-deployments --rest-api-id 1234123412 --output table`\r\n\r\nYou can find the reference for AWS CLI commands for AWS API Gateway service here: [AWS API Gateway CLI Reference][3]\r\n\r\n  [1]: https://boto3.amazonaws.com/v1/documentation/api/latest/reference/services/apigateway.html\r\n  [2]: https://boto3.amazonaws.com/v1/documentation/api/latest/reference/services/apigatewayv2.html\r\n  [3]: https://docs.aws.amazon.com/cli/latest/reference/apigateway/index.html",
                "title": "boto script to list all api gateway deployments"
            },
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1566938848,
                "last_edit_date": 1566938848,
                "creation_date": 1566928295,
                "answer_id": 57679903,
                "question_id": 57602000,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Although it might not satisfy all of your requirements (or it might be just what you need), easiest and most standardized way of achieving what you want is to export your REST API to an OpenAPI format (former [&quot;Swagger&quot;](https://swagger.io/docs/specification/about/) format). Support for version 3.0 was [recently added](https://aws.amazon.com/about-aws/whats-new/2018/09/amazon-api-gateway-adds-support-for-openapi-3-api-specification/) to API Gateway. You may augment/extend the output JSON with additional information that you need.\r\n\r\nOfficial documentation: https://docs.aws.amazon.com/apigateway/latest/developerguide/api-gateway-export-api.html",
                "title": "boto script to list all api gateway deployments"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1679070250,
                "last_edit_date": 1679070250,
                "creation_date": 1679068857,
                "answer_id": 75769752,
                "question_id": 57602000,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This is what I used to get all my API Gateway deployments:\r\n\r\n```python\r\nimport boto3\r\ngateway = boto3.client(&#39;apigateway&#39;)\r\nall_rest_apis = gateway.get_rest_apis()\r\nall_rest_apis[&#39;items&#39;]\r\n```",
                "title": "boto script to list all api gateway deployments"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 6,
        "last_activity_date": 1679070250,
        "creation_date": 1566447665,
        "last_edit_date": 1567316792,
        "question_id": 57602000,
        "body_markdown": "I have several API&#39;s deployed using gateway. How do I list all of them along with details like type of integration (like lambda) and method response (like 200) in tabular format?\r\n_____\r\n\r\nUpdate:\r\nAs suggested in the answer, I can use &quot;get-rest-apis&quot; method to get the list of all API ID&#39;s.\r\nThe json data can be converted to pandas dataframe like this...\r\n\r\n    # aws apigateway get-rest-apis --region=us-east-1 &gt; /tmp/to_file.json\r\n    \r\n    import pandas as pd\r\n    import json\r\n    from pandas.io.json import json_normalize\r\n    \r\n    with open(&quot;to_file.json&quot;) as f:\r\n        data = json.load(f)\r\n    \r\n    df = json_normalize(data, &quot;items&quot;)\r\n    \r\n    df[&quot;createdDate&quot;] = pd.to_datetime(df[&quot;createdDate&quot;], unit=&quot;s&quot;).dt.date\r\n    df = df.sort_values([&quot;createdDate&quot;])\r\n    \r\n    df[&quot;endpointConfiguration.types&quot;] = df[&quot;endpointConfiguration.types&quot;].str[0]\r\n\r\nBut how do I query to get details of each ID?\r\n_____\r\n\r\nIn order to get the complete picture of a given API, I need to query several methods like get-integration, get-method-response, get-resource. Each one of these has different number of required parameters that makes the automation process very difficult.\r\n\r\n",
        "link": "https://stackoverflow.com/questions/57602000/boto-script-to-list-all-api-gateway-deployments",
        "title": "boto script to list all api gateway deployments"
    },
    {
        "tags": [
            "json",
            "bash",
            "recursion",
            "key",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1566505434,
                "last_edit_date": 1566505434,
                "creation_date": 1566485454,
                "answer_id": 57612059,
                "question_id": 57611682,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "there&#39;s also an easy way to achieve the same using a `walk-path` based unix utility [**`jtc`**](https://github.com/ldn-softdev/jtc):\r\n\r\n    jtc -pw&#39;&lt;remove&gt;l:&#39; sample.json\r\n\r\n\\- it will delete recursively all occurrences of label `&quot;remove&quot;`. If you like to apply the changes right into the source file (`sample.json`), then add option `-f`\r\n\r\nPS&gt; Disclosure: I&#39;m the creator of the `jtc` - shell cli tool for JSON operations\r\n\r\n",
                "title": "remove all values from JSON matching specific key"
            },
            {
                "up_vote_count": 6,
                "is_accepted": false,
                "score": 6,
                "last_activity_date": 1566500668,
                "creation_date": 1566500668,
                "answer_id": 57615671,
                "question_id": 57611682,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This gets the desired result in jq.\r\n\r\n    jq &#39;del(..|.remove?)&#39;",
                "title": "remove all values from JSON matching specific key"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 6,
        "last_activity_date": 1629534120,
        "creation_date": 1566484239,
        "last_edit_date": 1566520479,
        "question_id": 57611682,
        "body_markdown": "What is the easy way to delete arbitrary values from entire JSON by a specific label/key? My JSON may have an arbitrary depth, so deleting by the label should be done recursively.&#160;\r\n\r\n\r\n    {\r\n       &quot;root&quot;: [\r\n          {\r\n             &quot;name&quot;: &quot;blah 1&quot;,\r\n             &quot;remove&quot;: [ 1, 2, 3 ],\r\n             &quot;new list&quot;: [\r\n                {\r\n                   &quot;name&quot;: &quot;blah 2&quot;,\r\n                   &quot;remove&quot;: null,\r\n                   &quot;new list&quot;: [\r\n                      {\r\n                         &quot;name&quot;: &quot;blah 3&quot;,\r\n                         &quot;remove&quot;: [\r\n                            {\r\n                               &quot;name&quot;: &quot;blah 4&quot;,\r\n                               &quot;new list&quot;: []\r\n                            },\r\n                            {\r\n                               &quot;name&quot;: &quot;blah 5&quot;,\r\n                               &quot;new list&quot;: []\r\n                            }\r\n                         ]\r\n                      }\r\n                   ]\r\n                },\r\n                {\r\n                   &quot;name&quot;: &quot;blah 6&quot;,\r\n                   &quot;new list&quot;: []\r\n                }\r\n             ]\r\n          }\r\n       ]\r\n    }\r\n\r\nand I want to remove all the elements with the label `&quot;remove&quot;`, so that the final result would look like this:\r\n\r\n    {\r\n       &quot;root&quot;: [\r\n          {\r\n             &quot;name&quot;: &quot;blah 1&quot;,\r\n             &quot;new list&quot;: [\r\n                {\r\n                   &quot;name&quot;: &quot;blah 2&quot;,\r\n                   &quot;new list&quot;: [\r\n                      {\r\n                         &quot;name&quot;: &quot;blah 3&quot;\r\n                      }\r\n                   ]\r\n                },\r\n                {\r\n                   &quot;name&quot;: &quot;blah 6&quot;,\r\n                   &quot;new list&quot;: []\r\n                }\r\n             ]\r\n          }\r\n       ]\r\n    }\r\n\r\nusing `sed`/`awk` gives unexpected result (especially when there are nested object to be removed) so it must be a JSON aware utility like jq, or similar.\r\n\r\n",
        "link": "https://stackoverflow.com/questions/57611682/remove-all-values-from-json-matching-specific-key",
        "title": "remove all values from JSON matching specific key"
    },
    {
        "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": 1566556810,
                "post_id": 57623064,
                "comment_id": 101702835,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1566552655,
                "last_edit_date": 1566552655,
                "creation_date": 1566551938,
                "answer_id": 57623264,
                "question_id": 57623064,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```\r\n$ jq -n &#39;{Feline: [\r\n  [inputs.Feline[] | select(.Race==&quot;Bengal&quot;)] | max_by(.Weight)\r\n]}&#39; file1 file2\r\n{\r\n  &quot;Feline&quot;: [\r\n    {\r\n      &quot;Name&quot;: &quot;Lynx&quot;,\r\n      &quot;Race&quot;: &quot;Bengal&quot;,\r\n      &quot;Weight&quot;: &quot;15&quot;\r\n    }\r\n  ]\r\n}\r\n```",
                "title": "Output object of two json files with two filters using jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1566552687,
                "creation_date": 1566552687,
                "answer_id": 57623449,
                "question_id": 57623064,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With the following pipeline:\r\n\r\n    $ jq -s &#39;[.[] | .Feline[] | select(.Race == &quot;Bengal&quot;)] | max_by(.Weight) | {&quot;Feline&quot;: [.]}&#39; f1 f2\r\n    {\r\n      &quot;Feline&quot;: [\r\n        {\r\n          &quot;Name&quot;: &quot;Lynx&quot;,\r\n          &quot;Race&quot;: &quot;Bengal&quot;,\r\n          &quot;Weight&quot;: &quot;15&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\n",
                "title": "Output object of two json files with two filters using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 3,
        "last_activity_date": 1566554224,
        "creation_date": 1566551236,
        "last_edit_date": 1566554224,
        "question_id": 57623064,
        "body_markdown": "I have these two json files :\r\n\r\nFile 0.json\r\n\r\n    {\r\n      &quot;Feline&quot;: [\r\n        {\r\n          &quot;Name&quot;: &quot;Leo&quot;,\r\n          &quot;Race&quot;: &quot;Bengal&quot;,\r\n          &quot;Weight&quot;: &quot;12&quot;\r\n        },\r\n        {\r\n          &quot;Name&quot;: &quot;Diego&quot;,\r\n          &quot;Race&quot;: &quot;Toyger&quot;,\r\n          &quot;Weight&quot;: &quot;24&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\n\r\n\r\nFile 1.json\r\n\r\n    {\r\n      &quot;Feline&quot;: [\r\n        {\r\n          &quot;Name&quot;: &quot;Lynx&quot;,\r\n          &quot;Race&quot;: &quot;Bengal&quot;,\r\n          &quot;Weight&quot;: &quot;15&quot;\r\n        },\r\n        {\r\n          &quot;Name&quot;: &quot;Simba&quot;,\r\n          &quot;Race&quot;: &quot;Ussuri&quot;,\r\n          &quot;Weight&quot;: &quot;14&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\nWith jq I would like the heaviest Feline whose race is Bengal of these two json file.\r\n\r\nSo the output will be \r\n\r\n\r\n    {\r\n      &quot;Feline&quot;: [\r\n        {\r\n          &quot;Name&quot;: &quot;Lynx&quot;,\r\n          &quot;Race&quot;: &quot;Bengal&quot;,\r\n          &quot;Weight&quot;: &quot;15&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\nI tried to combine --slurp and --arg and pipe in max without concrete result.\r\nIf someone know how to do this I&#39;ll apreciate the help.",
        "link": "https://stackoverflow.com/questions/57623064/output-object-of-two-json-files-with-two-filters-using-jq",
        "title": "Output object of two json files with two filters using jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 15535508,
                    "reputation": 445,
                    "user_id": 11207803,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/-FJ4WGmO0jKs/AAAAAAAAAAI/AAAAAAAAAAA/ACHi3rellG-NbGxyx1QYHIwx94nRxx6j2g/mo/s256-rj/photo.jpg",
                    "display_name": "AK123",
                    "link": "https://stackoverflow.com/users/11207803/ak123"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1566554221,
                "post_id": 57623522,
                "comment_id": 101701553,
                "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": 1566557125,
                "post_id": 57623522,
                "comment_id": 101702979,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1566580515,
                "last_edit_date": 1566580515,
                "creation_date": 1566555419,
                "answer_id": 57624223,
                "question_id": 57623522,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You got it almost right, but missing the part to identify those objects whose name contains `/`. You can use `startswith()` on the keyname\r\n\r\n    jq --slurpfile auth Auth.json &#39;\r\n        .paths |= with_entries( \r\n            if .key|startswith(&quot;/&quot;) \r\n            then\r\n               .value.get.parameters |= $auth  \r\n            else \r\n               . end\r\n        )&#39; Main.json\r\n\r\nAdditionally, if you would like to compare if `.parameters` object does not already contain the Authentication object, change your if condition to\r\n\r\n    if (.key|startswith(&quot;/&quot;)) and (.value.get.parameters[] != $auth)",
                "title": "Conditionally add json file into Main json file in jq 1.5"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1566580515,
        "creation_date": 1566552950,
        "last_edit_date": 1566555425,
        "question_id": 57623522,
        "body_markdown": "I have a json file with just one object as below. Am calling it Auth.json\r\n\r\n    { \r\n        &quot;name&quot;: &quot;Authorization&quot;,\r\n        &quot;description&quot;: &quot;This parameter represents the Authorization token obtained from the OKTA Authorization server. It is the Bearer token provided to authorize the consumer. Usage Authorization : Bearer token&quot;,\r\n         &quot;in&quot;: &quot;header&quot;,\r\n         &quot;required&quot;: true,\r\n         &quot;type&quot;: &quot;string&quot;\r\n    }\r\n\r\nI need to add the above json file value into the below json, only if the below path\r\n`.paths.&lt;any method that starts with /&gt;.get.parameters` does not have that object already. \r\nIf it exists that object needs to be removed and the contents of the above Auth.json needs to be added.\r\nI have jq 1.5 and do have access on the system to update the jq initialization file, so could not use walk function which would&#39;ve made this simpler. \r\n\r\nMain.json\r\n\r\n    {\r\n      &quot;swagger&quot;: &quot;2.0&quot;,\r\n        &quot;paths&quot;: {\r\n        &quot;/agents/delta&quot;: {\r\n          &quot;get&quot;: {\r\n            &quot;description&quot;: &quot;lorem ipsum doram&quot;,\r\n            &quot;operationId&quot;: &quot;getagentdelta&quot;,\r\n            &quot;summary&quot;: &quot;GetAgentDelta&quot;,\r\n            &quot;tags&quot;: [\r\n              &quot;Agents&quot;\r\n            ],\r\n            &quot;parameters&quot;: [\r\n              {\r\n                &quot;name&quot;: &quot;since&quot;,\r\n                &quot;in&quot;: &quot;query&quot;,\r\n                &quot;description&quot;: &quot;Format - date-time (as date-time in RFC3339). The time from which you need changes from. You should use the format emitted by Date&#39;s toJSON method (for example, 2017-04-23T18:25:43.511Z). If a timestamp older than a week is passed, a business rule violation will be thrown which will require the client to change the from date. As a best-practice, for a subsequent call to this method, send the timestamp when you &lt;b&gt;started&lt;/b&gt; the previous delta call (instead of when you completed processing the response or the max of the lastUpdateOn timestamps of the returned records). This will ensure that you do not miss any changes that occurred while you are processing the response from this method&quot;,\r\n                &quot;required&quot;: true,\r\n                &quot;type&quot;: &quot;string&quot;\r\n              }\r\n            ]\r\n            }\r\n            }\r\n            }\r\n            }\r\n\r\nI tried the below command, but it is adding it recursively within all objects of the path in the Main.json.\r\n\r\n    jq --slurpfile newval Auth.json &#39;.paths | .. | .get.parameters += $newval&#39; Main.json &gt; test.json\r\n\r\nHow can I achieve the above using jq 1.5?",
        "link": "https://stackoverflow.com/questions/57623522/conditionally-add-json-file-into-main-json-file-in-jq-1-5",
        "title": "Conditionally add json file into Main json file in jq 1.5"
    },
    {
        "tags": [
            "json",
            "awk",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "user_type": "does_not_exist",
                    "display_name": "user11966401"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1566557804,
                "post_id": 57624276,
                "comment_id": 101703333,
                "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": 1,
                "creation_date": 1566558262,
                "post_id": 57624276,
                "comment_id": 101703575,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1566563894,
                "last_edit_date": 1566563894,
                "creation_date": 1566559778,
                "answer_id": 57625452,
                "question_id": 57624276,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Since you have a large number of serial numbers to check, using a large regex is inadvisable.\r\n\r\nIf you just had to produce a stream of the objects satisfying the serial number criterion, you could use the invocation:\r\n\r\n    jq --rawfile sn serial-numbers.txt -f select.jq input.json\r\n\r\nwhere select.jq contains\r\n\r\n    INDEX($sn | splits(&quot;\\n&quot;) | select(length&gt;0); .) as $dict\r\n    | .[]\r\n    | select($dict[.serial])\r\n\r\n\r\nThe key to using jq to partition the objects into three files is to tag the objects and invoke jq with the -c command-line option.  You then process the tagged output using a tool such as `awk`.  This last part has been covered in several other SO Q&amp;As, so I&#39;ll just focus on the tagging part, which can be accomplished using `foreach`:\r\n\r\n```    \r\nINDEX($sn | splits(&quot;\\n&quot;) | select(length&gt;0); .) as $dict\r\n| foreach .[] as $in ({parity:0};\r\n    if ($in | $dict[.serial])\r\n    then .code = 2\r\n    else .code = .parity\r\n    | .parity |= (.+1 % 2)\r\n    end;\r\n    .code, $in )\r\n```\r\n\r\n\r\n\r\n  \r\n## awk-based solution\r\n\r\nFor example:\r\n\r\n    awk &#39;NR%2==1 {fn=$1 &quot;.json&quot;; next} {print &gt;&gt; fn}&#39;  \r\n    ",
                "title": "Use jq to filter json with regex, and the rest objects split into two separate chunks, containing half of the remaining objects each"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1566563894,
        "creation_date": 1566555626,
        "last_edit_date": 1566557939,
        "question_id": 57624276,
        "body_markdown": "Given the following json:    \r\n\r\n    [{\r\n    \t\t&quot;_id&quot;: {\r\n    \t\t\t&quot;productno&quot;: &quot;5d538a&quot;\r\n    \t\t},\r\n    \t\t&quot;serial&quot;: &quot;15947&quot;,\r\n    \t\t&quot;description&quot;: &quot;text&quot;\r\n    \t},\r\n    \t{\r\n    \t\t&quot;_id&quot;: {\r\n    \t\t\t&quot;productno&quot;: &quot;5d587&quot;\r\n    \t\t},\r\n    \t\t&quot;serial&quot;: &quot;15948&quot;,\r\n    \t\t&quot;description&quot;: &quot;text&quot;\r\n    \t},\r\n    \t{\r\n    \t\t&quot;_id&quot;: {\r\n    \t\t\t&quot;productno&quot;: &quot;5d5c38c&quot;\r\n    \t\t},\r\n    \t\t&quot;serial&quot;: &quot;15949&quot;,\r\n    \t\t&quot;description&quot;: &quot;more text&quot;\r\n    \t},{\r\n    \t\t&quot;_id&quot;: {\r\n    \t\t\t&quot;productno&quot;: &quot;5d5c38c&quot;\r\n    \t\t},\r\n    \t\t&quot;serial&quot;: &quot;15967&quot;,\r\n    \t\t&quot;description&quot;: &quot;more text&quot;\r\n    \t}\r\n    ]\r\n\r\ni need to filter based on a list of numbers, say for our example\r\n\r\n    15947\r\n    15948\r\n(i have a list of thousands of serials numbers, that are separated by the newline)\r\nI have tried with \r\n```\r\nmap(select(test(&quot;\\\\^15947$|^15948$\\\\b&quot;)))\r\n```\r\nexpected output:\r\nfile A:\r\n\r\n    {\r\n      &quot;_id&quot;: {\r\n        &quot;productno&quot;: &quot;5d538a&quot;\r\n      },\r\n      &quot;serial&quot;: &quot;15947&quot;,\r\n      &quot;description&quot;: &quot;text&quot;\r\n    }\r\n    {\r\n      &quot;_id&quot;: {\r\n        &quot;productno&quot;: &quot;5d587&quot;\r\n      },\r\n      &quot;serial&quot;: &quot;15948&quot;,\r\n      &quot;description&quot;: &quot;text&quot;\r\n    }\r\n\r\nand file B: (since there are two more objects, each file will have one object)\r\n\r\n    {\r\n      &quot;_id&quot;: {\r\n        &quot;productno&quot;: &quot;5d5c38c&quot;\r\n      },\r\n      &quot;serial&quot;: &quot;15949&quot;,\r\n      &quot;description&quot;: &quot;more text&quot;\r\n    }\r\nand finally file C:\r\n\r\n    {\r\n      &quot;_id&quot;: {\r\n        &quot;productno&quot;: &quot;5d5c38c&quot;\r\n      },\r\n      &quot;serial&quot;: &quot;15967&quot;,\r\n      &quot;description&quot;: &quot;more text&quot;\r\n    }\r\n\r\n",
        "link": "https://stackoverflow.com/questions/57624276/use-jq-to-filter-json-with-regex-and-the-rest-objects-split-into-two-separate-c",
        "title": "Use jq to filter json with regex, and the rest objects split into two separate chunks, containing half of the remaining objects each"
    },
    {
        "tags": [
            "terminal",
            "yaml",
            "jq",
            "yq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1373414,
                    "reputation": 77817,
                    "user_id": 1307905,
                    "user_type": "registered",
                    "accept_rate": 75,
                    "profile_image": "https://www.gravatar.com/avatar/a38a4f5f180194ac457cdc057f1be6e3?s=256&d=identicon&r=PG",
                    "display_name": "Anthon",
                    "link": "https://stackoverflow.com/users/1307905/anthon"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1566662843,
                "post_id": 57626741,
                "comment_id": 101730978,
                "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"
                },
                "reply_to_user": {
                    "account_id": 1373414,
                    "reputation": 77817,
                    "user_id": 1307905,
                    "user_type": "registered",
                    "accept_rate": 75,
                    "profile_image": "https://www.gravatar.com/avatar/a38a4f5f180194ac457cdc057f1be6e3?s=256&d=identicon&r=PG",
                    "display_name": "Anthon",
                    "link": "https://stackoverflow.com/users/1307905/anthon"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1567152567,
                "post_id": 57626741,
                "comment_id": 101886446,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1373414,
                    "reputation": 77817,
                    "user_id": 1307905,
                    "user_type": "registered",
                    "accept_rate": 75,
                    "profile_image": "https://www.gravatar.com/avatar/a38a4f5f180194ac457cdc057f1be6e3?s=256&d=identicon&r=PG",
                    "display_name": "Anthon",
                    "link": "https://stackoverflow.com/users/1307905/anthon"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1567285027,
                "post_id": 57626741,
                "comment_id": 101922168,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1566565810,
                "last_edit_date": 1566565810,
                "creation_date": 1566565279,
                "answer_id": 57626873,
                "question_id": 57626741,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": ".records is an array, so you could use this filter:\r\n\r\n    .records |= map(.delay /= 3)\r\n\r\nOr you might prefer:\r\n\r\n    .records[].delay |= (. /= 3)",
                "title": "Edit yaml objects in array with yq. Speed up Terminalizer&#39;s terminal cast (record)"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1566565810,
        "creation_date": 1566564780,
        "question_id": 57626741,
        "body_markdown": "## The goal: Speed up Terminalizer&#39;s terminal cast (record)\r\n\r\nI have a record of terminal created with Terminalizer. `cast.yaml`:\r\n```\r\n# The configurations that used for the recording, feel free to edit them\r\nconfig:\r\n  # do not touch it\r\n  \r\n# Records, feel free to edit them\r\nrecords:\r\n  - delay: 841\r\n    content: &quot;\\e]1337;RemoteHost=kyb@kyb-nuc\\a\\e]1337;CurrentDir=/home/kyb/devel/git-rev-label\\a\\e]1337;ShellIntegrationVersion=7;shell=fish\\a&quot;\r\n  - delay: 19\r\n    content: &quot;\\e]1337;RemoteHost=kyb@kyb-nuc\\a\\e]1337;CurrentDir=/home/kyb/devel/git-rev-label\\a\\e]0;fish /home/kyb/devel/git-rev-label\\a\\e[30m\\e(B\\e[m&quot;\r\n  - delay: 6\r\n    content: &quot;\\e[?2004h&quot;\r\n  - delay: 28\r\n    content: &quot;\\e]0;fish /home/kyb/devel/git-rev-label\\a\\e[30m\\e(B\\e[m\\e[2m⏎\\e(B\\e[m                                                                                                                                                        \\r⏎ \\r\\e[K\\e]133;D;0\\a\\e]133;A\\a\\e[44m\\e[30m ~/d/git-rev-label \\e[42m\\e[34m \\e[42m\\e[30m demo  \\e[30m\\e(B\\e[m\\e[32m \\e[30m\\e(B\\e[m\\e]133;B\\a\\e[K&quot;\r\n  - delay: 1202\r\n    content: &quot;#\\b\\e[38;2;231;197;71m#\\e[30m\\e(B\\e[m&quot;\r\n  - delay: 134\r\n    content: &quot;\\e[38;2;231;197;71m#\\e[30m\\e(B\\e[m&quot;\r\n  - delay: 489\r\n    content: &quot;\\e[38;2;231;197;71m \\e[30m\\e(B\\e[m&quot;\r\n  - delay: 318\r\n```\r\nI want to speed up payback without passing `--speed-factor` to `terminalizer play`. To do so `delay`s should be decreased. \r\n\r\nSo, I need to create `yq`-expression to make delays lower\r\n```\r\n.records.delay=.records.delay/3\r\n```\r\nbut this expression won&#39;t work. Please help to write proper one.",
        "link": "https://stackoverflow.com/questions/57626741/edit-yaml-objects-in-array-with-yq-speed-up-terminalizers-terminal-cast-recor",
        "title": "Edit yaml objects in array with yq. Speed up Terminalizer&#39;s terminal cast (record)"
    },
    {
        "tags": [
            "comments",
            "jq",
            "yq"
        ],
        "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": 1566579639,
                "post_id": 57627243,
                "comment_id": 101714453,
                "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": 1566622741,
                "post_id": 57627243,
                "comment_id": 101723273,
                "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"
                },
                "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": 1566624342,
                "post_id": 57627243,
                "comment_id": 101723477,
                "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": 1566681168,
                "post_id": 57627243,
                "comment_id": 101734828,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 470798,
                    "reputation": 6587,
                    "user_id": 878182,
                    "user_type": "registered",
                    "accept_rate": 50,
                    "profile_image": "https://www.gravatar.com/avatar/fe9bb29f576661916e29a8d327493d6b?s=256&d=identicon&r=PG",
                    "display_name": "Alistair A. Israel",
                    "link": "https://stackoverflow.com/users/878182/alistair-a-israel"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1657636103,
                "post_id": 57627243,
                "comment_id": 128854587,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 12,
                "is_accepted": true,
                "score": 12,
                "last_activity_date": 1568485662,
                "creation_date": 1568485662,
                "answer_id": 57938189,
                "question_id": 57627243,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "In some limited cases you could use diff/patch along with yq.   \r\nFor example if `input.yml` contains your input text, the commands\r\n\r\n    $ yq -y . input.yml &gt; input.yml.1\r\n    $ yq -y .env.recording=false input.yml &gt; input.yml.2\r\n    $ diff input.yml.1 input.yml.2 &gt; input.yml.diff\r\n    $ patch -o input.yml.new input.yml &lt; input.yml.diff\r\n\r\ncreates\ta file `input.yml.new` with comments preserved but\r\nrecording changed to false:\r\n\r\n    # Specify a command to be executed\r\n    # like `/bin/bash -l`, `ls`, or any other commands\r\n    # the default is bash for Linux\r\n    # or powershell.exe for Windows\r\n    command: fish -l\r\n\r\n    # Specify the current working directory path\r\n    # the default is the current working directory path\r\n    cwd: null\r\n\r\n    # Export additional ENV variables\r\n    env:\r\n      recording: false\r\n\r\n    # Explicitly set the number of columns\r\n    # or use `auto` to take the current\r\n    # number of columns of your shell\r\n    cols: 110\r\n",
                "title": "How to prevent yq removing comments and empty lines?"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1697861372,
                "last_edit_date": 1697861372,
                "creation_date": 1651139815,
                "answer_id": 72041655,
                "question_id": 57627243,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This is improvement of https://stackoverflow.com/questions/57627243/how-to-prevent-yq-removing-comments-and-empty-lines#comment115811480_57938189 comment.\r\n\r\nIn mine case was not enough `diff -B` and `diff -wB` as it still does not keep blank lines and keep generate an entire file difference as a single chunk instead of many small chunks.\r\n\r\nHere is example of the input (`test.yml`):\r\n\r\n```yml\r\n# This file is automatically generated\r\n#\r\n\r\ncontent-index:\r\n\r\n  timestamp: 1970-01-01T00:00:00Z\r\n\r\n  entries:\r\n\r\n    - dirs:\r\n\r\n        - dir: dir-1/dir-2\r\n\r\n          files:\r\n\r\n            - file: file-1.dat\r\n              md5-hash:\r\n              timestamp: 1970-01-01T00:00:00Z\r\n\r\n            - file: file-2.dat\r\n              md5-hash:\r\n              timestamp:\r\n\r\n            - file: file-3.dat\r\n              md5-hash:\r\n              timestamp:\r\n\r\n        - dir: dir-1/dir-2/dir-3\r\n\r\n          files:\r\n\r\n            - file: file-1.dat\r\n              md5-hash:\r\n              timestamp:\r\n\r\n            - file: file-2.dat\r\n              md5-hash:\r\n              timestamp:\r\n```\r\n\r\nIf try to edit a field and generate the difference file:\r\n\r\n```sh\r\ndiff -B test.yml &lt;(yq -y &quot;.\\&quot;content-index\\&quot;.timestamp=\\&quot;2022-01-01T00:00:00Z\\&quot;&quot; test.yml)\r\n```\r\n\r\nIt does keep remove blank lines:\r\n\r\n```diff\r\n5,7c2\r\n&lt;\r\n&lt;   timestamp: 1970-01-01T00:00:00Z\r\n&lt;\r\n---\r\n&gt;   timestamp: &#39;2022-01-01T00:00:00Z&#39;\r\n```\r\n\r\nAdds everywhere `null` instead of an empty field and changes the rest of timestamp fields (which means you have to use &#39;...&#39; to retain these as is):\r\n\r\n```diff\r\n17,19c8,9\r\n&lt;               md5-hash:\r\n&lt;               timestamp: 1970-01-01T00:00:00Z\r\n&lt;\r\n---\r\n&gt;               md5-hash: null\r\n&gt;               timestamp: &#39;1970-01-01T00:00:00+00:00&#39;\r\n```\r\n\r\nThe `-wB` flags changes the difference file from a single chunk into multiple chunks, but still does remove blank lines.\r\n\r\nHere is a mention of that diff issue: https://unix.stackexchange.com/questions/423186/diff-how-to-ignore-empty-lines/423188#423188\r\n\r\nTo fix that you have to use it with grep:\r\n\r\n```sh\r\ndiff -wB &lt;(grep -vE &#39;^\\s*$&#39; test.yml) &lt;(yq -y &quot;.\\&quot;content-index\\&quot;.timestamp=\\&quot;2022-01-01T00:00:00Z\\&quot;&quot; test.yml)\r\n```\r\n\r\nBut nevertheless it still does remove comments:\r\n\r\n```diff\r\n1,2d0\r\n&lt; # This file is automatically generated\r\n&lt; #\r\n```\r\n\r\nHere is solution for that: https://unix.stackexchange.com/questions/17040/how-to-diff-files-ignoring-comments-lines-starting-with/17044#17044\r\n\r\nSo the complete oneliner is:\r\n\r\n```sh\r\ndiff -wB &lt;(grep -vE &#39;^\\s*(#|$)&#39; test.yml) &lt;(yq -y &quot;.\\&quot;content-index\\&quot;.timestamp=\\&quot;2022-01-01T00:00:00Z\\&quot;&quot; test.yml) | patch -o - test.yml 2&gt;/dev/null\r\n```\r\n\r\nWhere `2&gt;/dev/null` stands to ignore patch warnings like:\r\n\r\n```\r\nHunk #1 succeeded at 6 (offset 4 lines).\r\n```\r\n\r\nTo avoid it in real code, you can use the `-s` flag instead:\r\n\r\n```bash\r\n... | patch -s -o ...\r\n```\r\n\r\n**Update**:\r\n\r\n&gt; **CAUTION**:\r\n&gt;\r\n&gt; This is the previous implementation and has an issue with a line addition to the yaml file and left as an example of implementation. Search for more reliable implementation in the `Update 2` section.\r\n\r\nThere is a better implementation as a shell script for GitHub Actions pipeline composite action.\r\n\r\nGitHub Composite action: https://github.com/andry81-devops/gh-action--accum-content\r\n\r\nBash scripts (previous implementation):\r\n\r\nImplementation: https://github.com/andry81-devops/gh-workflow/blob/2a60c95747ab741ca377f616c124545dd2a9331e/bash/github/init-yq-workflow.sh&lt;br /&gt;\r\nExample of usage: https://github.com/andry81-devops/gh-workflow/blob/30a09eea05efbfb4567d9d56b482947d78fb40e5/bash/cache/accum-content.sh\r\n\r\nThe implementation can use 2 of `yq` implementations:\r\n\r\n* https://github.com/kislyuk/yq     - a `jq` wrapper (default Cygwin distribution)\r\n* https://github.com/mikefarah/yq   - Go implementation (default Ubuntu 20.04 distribution)\r\n\r\nSearch for: `yq_edit`, `yq_diff`, `yq_patch` functions\r\n\r\n**Update 2**:\r\n\r\nThere is another discussion with some more reliable workarounds:&lt;br/&gt;\r\n`yq write strips completely blank lines from the output` : https://github.com/mikefarah/yq/issues/515\r\n\r\nBash scripts (new implementation):\r\n\r\nImplementation: https://github.com/andry81-devops/gh-workflow/tree/HEAD/bash/github/init-yq-workflow.sh&lt;br /&gt;\r\nExample of usage: https://github.com/andry81-devops/gh-workflow/tree/HEAD/bash/cache/accum-content.sh\r\n\r\n```sh\r\n# Usage example:\r\n#\r\n&gt;yq_edit &quot;&lt;prefix-name&gt;&quot; &quot;&lt;suffix-name&gt;&quot; &quot;&lt;input-yaml&gt;&quot; &quot;$TEMP_DIR/&lt;output-yaml-edited&gt;&quot; \\\r\n  &lt;list-of-yq-eval-strings&gt; &amp;&amp; \\\r\n  yq_diff &quot;$TEMP_DIR/&lt;output-yaml-edited&gt;&quot; &quot;&lt;input-yaml&gt;&quot; &quot;$TEMP_DIR/&lt;output-diff-edited&gt;&quot; &amp;&amp; \\\r\n  yq_restore_edited_uniform_diff &quot;$TEMP_DIR/&lt;output-diff-edited&gt;&quot; &quot;$TEMP_DIR/&lt;output-diff-edited-restored&gt;&quot; &amp;&amp; \\\r\n  yq_patch &quot;$TEMP_DIR/&lt;output-yaml-edited&gt;&quot; &quot;$TEMP_DIR/&lt;output-diff-edited-restored&gt;&quot; &quot;$TEMP_DIR/&lt;output-yaml-edited-restored&gt;&quot; &quot;&lt;output-yaml&gt;&quot;\r\n#\r\n# , where:\r\n#\r\n#   &lt;prefix-name&gt; - prefix name part for files in the temporary directory\r\n#   &lt;suffix-name&gt; - suffix name part for files in the temporary directory\r\n#\r\n#   &lt;input-yaml&gt;  - input yaml file path\r\n#   &lt;output-yaml&gt; - output yaml file path\r\n#\r\n#   &lt;output-yaml-edited&gt;          - output file name of edited yaml\r\n#   &lt;output-diff-edited&gt;          - output file name of difference file generated from edited yaml\r\n#   &lt;output-diff-edited-restored&gt; - output file name of restored difference file generated from original difference file\r\n#   &lt;output-yaml-edited-restored&gt; - output file name of restored yaml file stored as intermediate temporary file\r\n```\r\n\r\nExample with `test.yml` from above:\r\n\r\n```sh\r\nexport GH_WORKFLOW_ROOT=&#39;&lt;path-to-gh-workflow-root&gt;&#39; # https://github.com/andry81-devops/gh-workflow\r\n\r\nsource &quot;$GH_WORKFLOW_ROOT/bash/github/init-yq-workflow.sh&quot;\r\n\r\n[[ -d &quot;./temp&quot; ]] || mkdir &quot;./temp&quot;\r\n\r\nexport TEMP_DIR=&quot;./temp&quot;\r\n\r\nyq_edit &#39;content-index&#39; &#39;edit&#39; &quot;test.yml&quot; &quot;$TEMP_DIR/test-edited.yml&quot; \\\r\n  &quot;.\\&quot;content-index\\&quot;.timestamp=\\&quot;2022-01-01T00:00:00Z\\&quot;&quot; &amp;&amp; \\\r\n  yq_diff &quot;$TEMP_DIR/test-edited.yml&quot; &quot;test.yml&quot; &quot;$TEMP_DIR/test-edited.diff&quot; &amp;&amp; \\\r\n  yq_restore_edited_uniform_diff &quot;$TEMP_DIR/test-edited.diff&quot; &quot;$TEMP_DIR/test-edited-restored.diff&quot; &amp;&amp; \\\r\n  yq_patch &quot;$TEMP_DIR/test-edited.yml&quot; &quot;$TEMP_DIR/test-edited-restored.diff&quot; &quot;$TEMP_DIR/test.yml&quot; &quot;test-patched.yml&quot; || exit $?\r\n```\r\n\r\n**PROs**:\r\n* Can restore blank lines together with standalone comment lines: `  # ... `\r\n* Can restore line end comments: `  key: value # ...`\r\n* Can detect a line remove/change/add altogether.\r\n\r\n**CONs**:\r\n* Because of has having a guess logic, may leave artefacts or invalid corrections.\r\n* Does not restore line end comments, where the yaml data is changed.\r\n",
                "title": "How to prevent yq removing comments and empty lines?"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1698650360,
                "last_edit_date": 1698650360,
                "creation_date": 1697738044,
                "answer_id": 77326094,
                "question_id": 57627243,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "My use case i was running an yq image inside docker container without any diff commands being installed on the base image and also just want to have an inplace update. So instead i replaced the empty lines first with a placeholder tag \r\n\r\n`sed -i &#39;/^$/s// #BLANK_LINE/&#39; ./$filename` \r\nexecuted the operation and then replaced the placeholder back with empty lines `sed -i  &quot;s/ *#BLANK_LINE//g&quot; ./$filename` . and worked like a charm \r\n\r\nOverall combined command: \r\n\r\n    sed -i &#39;/^$/s// #BLANK_LINE/&#39; ./$filename;yq {{operation}}; sed -i  &quot;s/ *#BLANK_LINE//g&quot; ./$filename ",
                "title": "How to prevent yq removing comments and empty lines?"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 15,
        "last_activity_date": 1698650360,
        "creation_date": 1566566454,
        "last_edit_date": 1566568673,
        "question_id": 57627243,
        "body_markdown": "Here https://stackoverflow.com/questions/57626741/edit-yaml-objects-in-array-with-yq-speed-up-terminalizers-terminal-cast-recor/57626873#57626873 I asked about how to edit yaml with yq. I received the best answer. But by default `yq` removes comments and empty lines. How to prevent this behavior?\r\n\r\n`input.yml`\r\n```\r\n# Specify a command to be executed\r\n# like `/bin/bash -l`, `ls`, or any other commands\r\n# the default is bash for Linux\r\n# or powershell.exe for Windows\r\ncommand: fish -l\r\n\r\n# Specify the current working directory path\r\n# the default is the current working directory path\r\ncwd: null\r\n\r\n# Export additional ENV variables\r\nenv:\r\n  recording: true\r\n\r\n# Explicitly set the number of columns\r\n# or use `auto` to take the current\r\n# number of columns of your shell\r\ncols: 110\r\n```\r\n\r\nexecute\r\n```\r\nyq -y . input.yml\r\n```\r\n\r\nresult\r\n```\r\ncommand: fish -l\r\ncwd: null\r\nenv:\r\n  recording: true\r\ncols: 110\r\n```",
        "link": "https://stackoverflow.com/questions/57627243/how-to-prevent-yq-removing-comments-and-empty-lines",
        "title": "How to prevent yq removing comments and empty lines?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1566672731,
                "last_edit_date": 1566672731,
                "creation_date": 1566659970,
                "answer_id": 57639240,
                "question_id": 57637890,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```\r\njq &#39;reduce (input[]|to_entries[]) as $e (add;\r\n  if has($e.key) then .[$e.key] += [$e.value] else . end\r\n) | [keys_unsorted[] as $k|{($k): .[$k]}]&#39; file1 file2\r\n```\r\n&lt;sub&gt;[online demo](https://jqplay.org/s/z1S9TcgWwv)&lt;/sub&gt;",
                "title": "Merging two files using jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1566704577,
                "creation_date": 1566704577,
                "answer_id": 57643076,
                "question_id": 57637890,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The following solution is focused on efficiency, and also suggests an alternative format for the output:\r\n\r\n### jq program (merge.jq)\r\n```\r\nadd as $dict\r\n# aggregation:\r\n| (reduce input[] as $record ({};\r\n   ($record|keys_unsorted[0]) as $person\r\n   | if $dict[$person] then .[$person] += [$record[$person]] else . end )) as $answer\r\n# re-arrangement\r\n| reduce ($dict|keys_unsorted[]) as $person ([]; . + [ {($person): $answer[$person] } ] )\r\n```\r\n## Invocation\r\n\r\n    jq -f merge.jq first.json second.json",
                "title": "Merging two files using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1566704577,
        "creation_date": 1566649212,
        "last_edit_date": 1566660158,
        "question_id": 57637890,
        "body_markdown": "I&#39;ve got two files.\r\n\r\nFirst:\r\n```\r\n[\r\n  { &quot;person1&quot;: [] },\r\n  { &quot;person2&quot;: [] }\r\n]\r\n```\r\nSecond:\r\n```\r\n[\r\n  {\r\n    &quot;person2&quot;: { &quot;attribute1&quot;: &quot;wer&quot;, &quot;attribute2&quot;: &quot;sdf&quot; }\r\n  },\r\n  {\r\n    &quot;person2&quot;: { &quot;attribute1&quot;: &quot;ert&quot;, &quot;attribute2&quot;: &quot;dfg&quot; }\r\n  },\r\n  {\r\n    &quot;person2&quot;: { &quot;attribute1&quot;: &quot;rty&quot;, &quot;attribute2&quot;: &quot;fgh&quot; }\r\n  },\r\n  {\r\n    &quot;person3&quot;: { &quot;attribute1&quot;: &quot;tyu&quot;, &quot;attribute2&quot;: &quot;ghj&quot; }\r\n  },\r\n  {\r\n    &quot;person1&quot;: { &quot;attribute1&quot;: &quot;yui&quot;, &quot;attribute2&quot;: &quot;hjk&quot; }\r\n  }\r\n]\r\n```\r\nI try to merge them, using `jq`. For each person from the first file (in the second file migth be more persons, which should be ignored) create list of it&#39;s attributes. So an output should look something like this:\r\n\r\n```\r\n[\r\n  {\r\n    &quot;person1&quot;:\r\n      [\r\n        { &quot;attribute1&quot;: &quot;yui&quot;, &quot;attribute2&quot;: &quot;hjk&quot; }\r\n      ]\r\n  },\r\n  {\r\n    &quot;person2&quot;:\r\n      [\r\n        { &quot;attribute1&quot;: &quot;wer&quot;, &quot;attribute2&quot;: &quot;sdf&quot; },\r\n        { &quot;attribute1&quot;: &quot;ert&quot;, &quot;attribute2&quot;: &quot;dfg&quot; },\r\n        { &quot;attribute1&quot;: &quot;rty&quot;, &quot;attribute2&quot;: &quot;fgh&quot; }\r\n      ]\r\n  }\r\n]\r\n```\r\nI tried different options, but I can&#39;t achieve expected result. ",
        "link": "https://stackoverflow.com/questions/57637890/merging-two-files-using-jq",
        "title": "Merging two files using jq"
    },
    {
        "tags": [
            "json",
            "python-3.x",
            "jq",
            "jsonpath",
            "json-path-expression"
        ],
        "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": 1566731851,
                "post_id": 57640053,
                "comment_id": 101742177,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1566694705,
                "creation_date": 1566694705,
                "answer_id": 57642527,
                "question_id": 57640053,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If your json file contains one big array, you&#39;ll want to stream that file in truncating out the array. Then use `fromstream/1` to rebuild the objects and filtering them out as you go.\r\n\r\nI don&#39;t have a representative file to test out the performance myself, but give this a try:\r\n\r\n    $ jq --stream -n &#39;fromstream(1|truncate_stream(inputs))\r\n        | select(.statusInfo.status != &quot;UP&quot;)\r\n        | .name, .serviceUrl, .statusInfo.status\r\n    &#39; input.json",
                "title": "Parse and filter complex JSON Response in Python (the easy compute method)"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1566764415,
        "creation_date": 1566666991,
        "question_id": 57640053,
        "body_markdown": "I have a list of dictionaries (basically JSON Response of an endpoint)\r\n\r\nI would need to Parse this 16000 lines of json objects and fitler the documents/objects which match criteria that\r\nwhose leaf element/field : `statusInfo/status` in not &quot;UP&quot; and of those filtered objects, just return    ` &quot;name&quot; , &quot;serviceUrl&quot;,&quot;status&quot;`\r\n\r\nexample :\r\n\r\n    &quot;ADMIN-V1&quot;  &quot;http://aws-ec2.aws.com:4435&quot;  &quot;Warning&quot;\r\n\r\nI have been researching about JSONPath module , but there is no good documentation about it, and I could not find any easier way. \r\nAny guidance is highly appreciated.\r\n\r\nhere is a snippet from long 16000 lines of JSON response.\r\n\r\n    [\r\n        {\r\n            &quot;id&quot;: &quot;9c108ec5&quot;,\r\n            &quot;name&quot;: &quot;USER-V2&quot;,\r\n            &quot;managementUrl&quot;: &quot;http://aws-ec2.aws.com:5784/&quot;,\r\n            &quot;healthUrl&quot;: &quot;http://aws-ec2.aws.com:5784/health&quot;,\r\n            &quot;serviceUrl&quot;: &quot;http://aws-ec2.aws.com:5784/&quot;,\r\n            &quot;statusInfo&quot;: {\r\n                &quot;status&quot;: &quot;UP&quot;,\r\n                &quot;timestamp&quot;: 1566663146681,\r\n                &quot;details&quot;: {\r\n                    &quot;description&quot;: &quot; Eureka Discovery Client&quot;,\r\n                    &quot;status&quot;: &quot;UP&quot;\r\n                }\r\n            },\r\n            &quot;source&quot;: &quot;discovery&quot;,\r\n            &quot;metadata&quot;: {},\r\n            &quot;info&quot;: {\r\n                &quot;component&quot;: &quot;user&quot;,\r\n                &quot;description&quot;: &quot;User REST Resource&quot;,\r\n                &quot;version&quot;: &quot;2.2.1&quot;,\r\n                &quot;git&quot;: {\r\n                    &quot;commit&quot;: {\r\n                        &quot;time&quot;: &quot;07/27/2018 @ 15:06:55 CDT&quot;,\r\n                        &quot;id&quot;: &quot;b2a1b37&quot;\r\n                    },\r\n                    &quot;branch&quot;: &quot;refs/tags/v2.2.1&quot;\r\n                }\r\n            }\r\n        },\r\n        {\r\n            &quot;id&quot;: &quot;1a381f20&quot;,\r\n            &quot;name&quot;: &quot;ADMIN-V1&quot;,\r\n            &quot;managementUrl&quot;: &quot;http://aws-ec2.aws.com:4435/&quot;,\r\n            &quot;healthUrl&quot;: &quot;http://aws-ec2.aws.com:4435/health&quot;,\r\n            &quot;serviceUrl&quot;: &quot;http://aws-ec2.aws.com:4435/&quot;,\r\n            &quot;statusInfo&quot;: {\r\n                &quot;status&quot;: &quot;Warning&quot;,\r\n                &quot;timestamp&quot;: 1566663146682,\r\n                &quot;details&quot;: {\r\n                    &quot;description&quot;: &quot;Spring Cloud Eureka Discovery Client&quot;,\r\n                    &quot;status&quot;: &quot;Warning&quot;\r\n                }\r\n            },\r\n            &quot;source&quot;: &quot;discovery&quot;,\r\n            &quot;metadata&quot;: {},\r\n            &quot;info&quot;: {\r\n                &quot;description&quot;: &quot;Exchange Admin REST Resource&quot;,\r\n                &quot;api&quot;: {\r\n                    &quot;version&quot;: &quot;1.2.1&quot;,\r\n                    &quot;name&quot;: &quot;admin&quot;,\r\n                    &quot;link&quot;: &quot;https://app.swaggerhub.com/apis/AWSExchange/admin/1.2.1&quot;\r\n                },\r\n                &quot;implementation&quot;: &quot;admin&quot;,\r\n                &quot;version&quot;: &quot;1.1.0&quot;,\r\n                &quot;git&quot;: {\r\n                    &quot;commit&quot;: {\r\n                        &quot;time&quot;: &quot;01/04/2019 @ 15:36:48 UTC&quot;,\r\n                        &quot;id&quot;: &quot;39d5551&quot;\r\n                    },\r\n                    &quot;branch&quot;: &quot;refs/tags/v1.1.0&quot;\r\n                }\r\n            }\r\n        }\r\n    ]\r\n\r\n",
        "link": "https://stackoverflow.com/questions/57640053/parse-and-filter-complex-json-response-in-python-the-easy-compute-method",
        "title": "Parse and filter complex JSON Response in Python (the easy compute method)"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1566730055,
                "last_edit_date": 1566730055,
                "creation_date": 1566691535,
                "answer_id": 57642327,
                "question_id": 57642287,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Get *subkey*s using `keys_unsorted`, and check if their values have `filterkey1: &quot;value1&quot;` pair using `any`:\r\n```\r\n.key1 | [\r\n    keys_unsorted[] as $k\r\n    | if any(.[$k][]; .filterkey1==&quot;value1&quot;)\r\n    then $k \r\n    else empty end\r\n]\r\n```",
                "title": "How to select/get object elements&#39; (array of objects) keys based on value of an element in an object in the aforementioned array in jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 4,
        "last_activity_date": 1566755014,
        "creation_date": 1566690878,
        "last_edit_date": 1566726278,
        "question_id": 57642287,
        "body_markdown": "I have the following input:\r\n\r\n    {\r\n      &quot;key1&quot;: {\r\n        &quot;subkey1&quot;: [\r\n          {\r\n            &quot;filterkey1&quot;: &quot;value1&quot;,\r\n            &quot;filterkey2&quot;: &quot;value2&quot;\r\n          },\r\n          {\r\n            &quot;filterkey1&quot;: &quot;value3&quot;,\r\n            &quot;filterkey2&quot;: &quot;value4&quot;\r\n          }\r\n        ],\r\n        &quot;subkey2&quot;: [\r\n          {\r\n            &quot;filterkey1&quot;: &quot;value5&quot;,\r\n            &quot;filterkey2&quot;: &quot;value6&quot;\r\n          },\r\n          {\r\n            &quot;filterkey1&quot;: &quot;value7&quot;,\r\n            &quot;filterkey2&quot;: &quot;value8&quot;\r\n          }\r\n        ],\r\n        &quot;subkey3&quot;: [\r\n          {\r\n            &quot;filterkey1&quot;: &quot;value1&quot;,\r\n            &quot;filterkey2&quot;: &quot;value6&quot;\r\n          },\r\n          {\r\n            &quot;filterkey1&quot;: &quot;value9&quot;,\r\n            &quot;filterkey2&quot;: &quot;value4&quot;\r\n          }\r\n        ]\r\n      },\r\n      &quot;key2&quot;: {\r\n      }\r\n    }\r\n\r\nI want to get the key of the arrays that has an object which has `&quot;value1&quot;` for key: `&quot;filterkey1&quot;`. So in this case the output must be:\r\n\r\n    [&quot;subkey1&quot;, &quot;subkey3&quot;]\r\n\r\n**All the elements I care about are in &quot;key1&quot; object.**",
        "link": "https://stackoverflow.com/questions/57642287/how-to-select-get-object-elements-array-of-objects-keys-based-on-value-of-an",
        "title": "How to select/get object elements&#39; (array of objects) keys based on value of an element in an object in the aforementioned array in jq?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 166270,
                    "reputation": 135171,
                    "user_id": 390278,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/84715fec547362389d02f5be0ed12814?s=256&d=identicon&r=PG",
                    "display_name": "Jeff Mercado",
                    "link": "https://stackoverflow.com/users/390278/jeff-mercado"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1566761659,
                "post_id": 57648741,
                "comment_id": 101748745,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1566758881,
                "creation_date": 1566758881,
                "answer_id": 57648807,
                "question_id": 57648741,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The correct way of doing this is `walk`:\r\n```\r\nwalk(\r\n  if type == &quot;object&quot; and has(&quot;uid&quot;)\r\n  then .uid |= tostring\r\n  else . end\r\n)\r\n```",
                "title": "How to replace numeric value with string representation in JSON?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1566758881,
        "creation_date": 1566758355,
        "question_id": 57648741,
        "body_markdown": "I have a JSON file with several uid fields that are numeric but I need to convert them to string.  These uid fields are nested in different places in the file.\r\n\r\n    e.g.   &quot;uid&quot;: 891602734537070110  =&gt; &quot;uid&quot;: &quot;891602734537070110&quot;\r\n\r\nI tried this command:\r\n\r\n    jq &#39;(.. | .uid?) |= (tostring)&#39;\r\n\r\nwhich somewhat worked but it added a &quot;uid&quot; field (e.g.  &quot;uid&quot;: &quot;null&quot;) to any dictionaries that didn&#39;t have one to begin with.\r\n\r\nWhat is the correct way of doing this?\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/57648741/how-to-replace-numeric-value-with-string-representation-in-json",
        "title": "How to replace numeric value with string representation in JSON?"
    },
    {
        "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": 1566767548,
                "post_id": 57649735,
                "comment_id": 101750018,
                "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": 1566767935,
                "post_id": 57649735,
                "comment_id": 101750106,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 16,
                "is_accepted": true,
                "score": 16,
                "last_activity_date": 1702901178,
                "last_edit_date": 1702901178,
                "creation_date": 1566767792,
                "answer_id": 57649785,
                "question_id": 57649735,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You&#39;re right that a regex is the way to go here.  Fortunately, [the `jq` manual](https://jqlang.github.io/jq/manual/#regular-expressions) has a large section on using them.\r\n\r\n```\r\njq &#39;\r\n{\r\n  temp: .temperature,\r\n  hum: .humidity,\r\n  id: (.message | capture(&quot;ID (?&lt;id&gt;[[:digit:]]+)&quot;).id)\r\n}&#39; &lt;old.json &gt;new.json\r\n```\r\n\r\nYou can see this running with your sample data at https://jqplay.org/s/k-ZylbOC6W",
                "title": "How to extract a json value substring with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 12,
        "last_activity_date": 1702901178,
        "creation_date": 1566767381,
        "last_edit_date": 1566767465,
        "question_id": 57649735,
        "body_markdown": "I have this json: \r\n\r\n    {&quot;temperature&quot;:&quot;21&quot;, &quot;humidity&quot;:&quot;12.3&quot;, &quot;message&quot;:&quot;Today ID 342 is running&quot;}\r\n\r\nI want to use jq to obtain this json:\r\n\r\n    {&quot;temp&quot;:&quot;21&quot;, &quot;hum&quot;:&quot;12.3&quot;, &quot;id&quot;:&quot;342&quot;}\r\n\r\nAs you can see, what i want to do is extract the ID number 342 and put it in the new json with a different key name. I think i should use a regex but i don&#39;t know how to insert it in jq syntax.\r\n\r\nI can create another json using the basic command:\r\n\r\n    cat old.json | jq &#39;{temp:.temperature,hum:.humidity, id:.message}&#39; &gt; new.json\r\n\r\nI know i can select substring using square brackets, but i don&#39;t want to use them because they don&#39;t take into account strings with different lengths and structure. I want to use a regex because i know that the ID number comes lways after the &quot;ID&quot; part.",
        "link": "https://stackoverflow.com/questions/57649735/how-to-extract-a-json-value-substring-with-jq",
        "title": "How to extract a json value substring with jq"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 266703,
                    "reputation": 18823,
                    "user_id": 1149423,
                    "user_type": "registered",
                    "accept_rate": 83,
                    "profile_image": "https://i.sstatic.net/KmNLc.png?s=256",
                    "display_name": "Sufiyan Ghori",
                    "link": "https://stackoverflow.com/users/1149423/sufiyan-ghori"
                },
                "edited": false,
                "score": 3,
                "creation_date": 1566780420,
                "post_id": 57650743,
                "comment_id": 101751924,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1566785345,
                "creation_date": 1566785345,
                "answer_id": 57651078,
                "question_id": 57650743,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use the `--raw-output`/`-r` flag.\r\n\r\nFrom the documentation:\r\n\r\n&gt; With this option, if the filter’s result is a string then it will be written directly to standard output rather than being formatted as a JSON string with quotes. This can be useful for making jq filters talk to non-JSON-based systems.",
                "title": "How to escape string in `jq`?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1566785345,
        "creation_date": 1566780281,
        "question_id": 57650743,
        "body_markdown": "I&#39;d like to just print `a`. I don&#39;t find how to do so. Could anybody let me know how to do it? Thanks.\r\n\r\n```\r\n$ jq &#39;.&#39; &lt;&lt;&lt; &#39;&quot;a&quot;&#39;\r\n&quot;a&quot;\r\n```",
        "link": "https://stackoverflow.com/questions/57650743/how-to-escape-string-in-jq",
        "title": "How to escape string in `jq`?"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1526413,
                    "reputation": 13993,
                    "user_id": 1424739,
                    "user_type": "registered",
                    "accept_rate": 17,
                    "profile_image": "https://www.gravatar.com/avatar/19d3c927744b5ad3b94afbf88e1c3844?s=256&d=identicon&r=PG",
                    "display_name": "user1424739",
                    "link": "https://stackoverflow.com/users/1424739/user1424739"
                },
                "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": 1566799956,
                "post_id": 57651071,
                "comment_id": 101755299,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1526413,
                    "reputation": 13993,
                    "user_id": 1424739,
                    "user_type": "registered",
                    "accept_rate": 17,
                    "profile_image": "https://www.gravatar.com/avatar/19d3c927744b5ad3b94afbf88e1c3844?s=256&d=identicon&r=PG",
                    "display_name": "user1424739",
                    "link": "https://stackoverflow.com/users/1424739/user1424739"
                },
                "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": 1566801200,
                "post_id": 57651071,
                "comment_id": 101755684,
                "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": 1566801435,
                "post_id": 57651071,
                "comment_id": 101755765,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1526413,
                    "reputation": 13993,
                    "user_id": 1424739,
                    "user_type": "registered",
                    "accept_rate": 17,
                    "profile_image": "https://www.gravatar.com/avatar/19d3c927744b5ad3b94afbf88e1c3844?s=256&d=identicon&r=PG",
                    "display_name": "user1424739",
                    "link": "https://stackoverflow.com/users/1424739/user1424739"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1566801556,
                "post_id": 57651071,
                "comment_id": 101755803,
                "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": 1566803205,
                "post_id": 57651071,
                "comment_id": 101756419,
                "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": 1566805603,
                "post_id": 57651071,
                "comment_id": 101757340,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": -1,
                "last_activity_date": 1566802357,
                "creation_date": 1566802357,
                "answer_id": 57653042,
                "question_id": 57651071,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you want to get the `&quot;locator&quot;` value off of all objects unconditionally, you could use this:\r\n\r\n    ..|objects.locator|strings\r\n\r\nTo find all objects with `#name == &quot;section-title&quot;` and select the `_` value:\r\n\r\n    ..|select(objects.&quot;#name&quot; == &quot;section-title&quot;)._\r\n\r\nPutting it all together:\r\n\r\n    [(..|objects.locator|strings), (..|select(objects.&quot;#name&quot; == &quot;section-title&quot;)._)] | @tsv\r\n\r\nhttps://jqplay.org/s/xHWg8aGSSS",
                "title": "`jq` selection based on condition of different levels"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": -1,
                "last_activity_date": 1566807822,
                "creation_date": 1566807822,
                "answer_id": 57654262,
                "question_id": 57651071,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The following is simpler in at least some respects, produces the desired result, and seems to reflect the requirements:\r\n\r\n    ..\r\n    | .[&quot;$$&quot;]?\r\n    | (.. | objects | .locator | strings | select(test(&quot;mmc[0-9]+&quot;)) ) as $locator\r\n    | (.. | objects | select(.[&quot;#name&quot;] == &quot;section-title&quot;) | ._) as $st\r\n    | [$locator, $st]\r\n    | @tsv\r\n\r\n",
                "title": "`jq` selection based on condition of different levels"
            }
        ],
        "is_answered": false,
        "answer_count": 2,
        "score": -3,
        "last_activity_date": 1566836880,
        "creation_date": 1566785225,
        "last_edit_date": 1566836880,
        "question_id": 57651071,
        "body_markdown": "I&#39;d like to select the following node in a long json file.\r\n\r\nThe conditions are `&quot;locator&quot;: &quot;mmc1&quot;` and `&quot;#name&quot;: &quot;section-title&quot;`. This nested structure makes the jq query very complex. Notice that I have to specify things like &quot;locator&quot; and &quot;section-title&quot; multiple times.\r\n\r\n```\r\n.. | .[&quot;$$&quot;]?\r\n | select((.[]? | .&quot;#name&quot; == &quot;section-title&quot;?) and (..[]? | .locator? | test(&quot;mmc[0-9]+&quot;)?))\r\n | [\r\n(..[]? | select(.locator? | test(&quot;mmc[0-9]+&quot;)?) | .locator)\r\n, (.[] | select(.&quot;#name&quot; == &quot;section-title&quot;) | ._)\r\n] | @tsv\r\n```\r\n\r\nCould anybody let me know how to make the query simpler in jq yet make sure its function is exact the same as the original query? Just making the following simplified test input producing the same output should not be considered as an equivalent query. Thanks.\r\n\r\n```\r\n...\r\n              &quot;$$&quot;: [\r\n                {\r\n                  &quot;#name&quot;: &quot;label&quot;,\r\n                  &quot;_&quot;: &quot;Appendix A&quot;\r\n                },\r\n                {\r\n                  &quot;#name&quot;: &quot;section-title&quot;,\r\n                  &quot;$&quot;: {\r\n                    &quot;id&quot;: &quot;sectitle0145&quot;\r\n                  },\r\n                  &quot;_&quot;: &quot;Supplementary data&quot;\r\n                },\r\n                {\r\n                  &quot;#name&quot;: &quot;para&quot;,\r\n                  &quot;$&quot;: {\r\n                    &quot;id&quot;: &quot;p0210&quot;,\r\n                    &quot;view&quot;: &quot;all&quot;\r\n                  },\r\n                  &quot;$$&quot;: [\r\n                    {\r\n                      &quot;#name&quot;: &quot;__text__&quot;,\r\n                      &quot;_&quot;: &quot;The following is the supplementary data related to this article:&quot;\r\n                    },\r\n                    {\r\n                      &quot;#name&quot;: &quot;display&quot;,\r\n                      &quot;$$&quot;: [\r\n                        {\r\n                          &quot;#name&quot;: &quot;e-component&quot;,\r\n                          &quot;$&quot;: {\r\n                            &quot;id&quot;: &quot;ec1&quot;\r\n                          },\r\n                          &quot;$$&quot;: [\r\n                            {\r\n                              &quot;#name&quot;: &quot;link&quot;,\r\n                              &quot;$&quot;: {\r\n                                &quot;locator&quot;: &quot;mmc1&quot;,\r\n                                &quot;type&quot;: &quot;simple&quot;,\r\n                                &quot;role&quot;: &quot;http://data.elsevier.com/vocabulary/ElsevierContentTypes/46.1&quot;,\r\n                                &quot;href&quot;: &quot;pii:S2212877817302818/mmc1&quot;,\r\n                                &quot;id&quot;: &quot;aep-link-id8&quot;\r\n                              }\r\n                            }\r\n                          ]\r\n                        }\r\n                      ]\r\n                    }\r\n                  ]\r\n                }\r\n              ]\r\n...\r\n```\r\n\r\nSee the output below.\r\n\r\n```\r\n$ jq &#39;.. | .[&quot;$$&quot;]? | select((.[]? | .&quot;#name&quot; == &quot;section-title&quot;?) and (..[]? | .locator? | test(&quot;mmc[0-9]+&quot;)?)) | [ (..[]? | select(.locator? | test(&quot;mmc[0-9]+&quot;)?) | .locator) , (.[] | select(.&quot;#name&quot; == &quot;section-title&quot;) | ._) ] | @tsv&#39; &lt; 1.json\r\n&quot;mmc1\\tSupplementary data&quot;\r\n$ cat 1.json\r\n            {\r\n              &quot;$$&quot;: [\r\n                {\r\n                  &quot;#name&quot;: &quot;label&quot;,\r\n                  &quot;_&quot;: &quot;Appendix A&quot;\r\n                },\r\n                {\r\n                  &quot;#name&quot;: &quot;section-title&quot;,\r\n                  &quot;$&quot;: {\r\n                    &quot;id&quot;: &quot;sectitle0145&quot;\r\n                  },\r\n                  &quot;_&quot;: &quot;Supplementary data&quot;\r\n                },\r\n                {\r\n                  &quot;#name&quot;: &quot;para&quot;,\r\n                  &quot;$&quot;: {\r\n                    &quot;id&quot;: &quot;p0210&quot;,\r\n                    &quot;view&quot;: &quot;all&quot;\r\n                  },\r\n                  &quot;$$&quot;: [\r\n                    {\r\n                      &quot;#name&quot;: &quot;__text__&quot;,\r\n                      &quot;_&quot;: &quot;The following is the supplementary data related to this article:&quot;\r\n                    },\r\n                    {\r\n                      &quot;#name&quot;: &quot;display&quot;,\r\n                      &quot;$$&quot;: [\r\n                        {\r\n                          &quot;#name&quot;: &quot;e-component&quot;,\r\n                          &quot;$&quot;: {\r\n                            &quot;id&quot;: &quot;ec1&quot;\r\n                          },\r\n                          &quot;$$&quot;: [\r\n                            {\r\n                              &quot;#name&quot;: &quot;link&quot;,\r\n                              &quot;$&quot;: {\r\n                                &quot;locator&quot;: &quot;mmc1&quot;,\r\n                                &quot;type&quot;: &quot;simple&quot;,\r\n                                &quot;role&quot;: &quot;http://data.elsevier.com/vocabulary/ElsevierContentTypes/46.1&quot;,\r\n                                &quot;href&quot;: &quot;pii:S2212877817302818/mmc1&quot;,\r\n                                &quot;id&quot;: &quot;aep-link-id8&quot;\r\n                              }\r\n                            }\r\n                          ]\r\n                        }\r\n                      ]\r\n                    }\r\n                  ]\r\n                }\r\n              ]\r\n            }\r\n```\r\n",
        "link": "https://stackoverflow.com/questions/57651071/jq-selection-based-on-condition-of-different-levels",
        "title": "`jq` selection based on condition of different levels"
    },
    {
        "tags": [
            "json",
            "bash",
            "base64",
            "jq",
            "gunzip"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1566796322,
                "last_edit_date": 1566796322,
                "creation_date": 1566795721,
                "answer_id": 57652007,
                "question_id": 57651787,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "From [#1931](https://github.com/stedolan/jq/issues/1931):\r\n&gt;Let `$B` be an arbitrary base64 string, then `$B | @base64d` is undefined if `base64 -D &lt;&lt;&lt; $B` is not a valid UTF-8 string.\r\n\r\nBelow is a quick workaround; output raw base64 string and decode it using `base64` utility:\r\n```\r\njq -r &#39;.Attachment[] | .Contents[&quot;@Value&quot;]&#39; src/my-file.json | base64 -d | gunzip\r\n```",
                "title": "gzip decompress a property in a json file using bash"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1666590496,
        "creation_date": 1566794050,
        "last_edit_date": 1666590496,
        "question_id": 57651787,
        "body_markdown": "I have to verify that the base64 encoded and gzipped contents of a property in a json file are the same as the raw ones using bash.\r\n\r\nI have been able to extract the property using jq:\r\n\r\n    cat src/my-file.json | jq &#39;.Attachment[] | .Contents[&quot;@Value&quot;] | @base64d&#39;\r\n\r\nI have tried using `gzip` to decompress this using `@gzipd` filter \r\n\r\n&gt; jq: error (at &lt;stdin&gt;:798): gzipd is not a valid format\r\n\r\nand piping the value to `gunzip` command:\r\n\r\n&gt; gunzip: unknown compression format\r\n\r\nI have tried writing the contents to a file named test.gz and then using `gunzip`.\r\n\r\n    cat src/my-file.json | jq &#39;.Attachment[] | .Contents[&quot;@Value&quot;] | @base64d&#39; &gt; test.gz\r\n\r\n&gt; gunzip: test.gz: not in gzip format\r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/57651787/gzip-decompress-a-property-in-a-json-file-using-bash",
        "title": "gzip decompress a property in a json file using bash"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3889535,
                    "reputation": 20152,
                    "user_id": 3220113,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/10f69140e2a641a9f2f63bc09bc0e32c?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Walter A",
                    "link": "https://stackoverflow.com/users/3220113/walter-a"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1566820045,
                "post_id": 57657193,
                "comment_id": 101764176,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1566904854,
                "last_edit_date": 1566904854,
                "creation_date": 1566819724,
                "answer_id": 57657275,
                "question_id": 57657193,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "tabs, newlines or spaces within a json dict or list are absolutely ok.\r\n\r\nThe file is not a valid [json][1] document because it contains _many_ json documents (dictionaries in this case) separated by newlines. The result of this is _not_ a valid json document and can&#39;t be parsed by a strict json parser. At least not by the one which comes with Python&#39;s json library.\r\n\r\nIf you accept to pre-process the file with `jq`, you could put those objects into a list with the `-s` option:\r\n\r\n    jq -s . input.json &gt; output.json\r\n    cat output.json\r\n    [\r\n      {\r\n        &quot;temperature&quot;: &quot;21&quot;,\r\n        &quot;humidity&quot;: &quot;12.3&quot;,\r\n        &quot;message&quot;: &quot;Today ID 342 is running&quot;\r\n      },\r\n      {\r\n        &quot;temperature&quot;: &quot;13&quot;,\r\n        &quot;humidity&quot;: &quot;40.1&quot;,\r\n        &quot;message&quot;: &quot;Today ID 98 is running&quot;\r\n      }\r\n    ]\r\n\r\nThen use `json.load` in Python:\r\n\r\n\r\n    import json\r\n   \r\n    with open(&#39;output.json&#39;) as file_desc:\r\n        measurements = json.load(file_desc)\r\n\r\n\r\n---\r\n\r\nPure python solutions can be found here: https://stackoverflow.com/questions/6886283/how-i-can-i-lazily-read-multiple-json-values-from-a-file-stream-in-python\r\n\r\n\r\n  [1]: http://json.org/",
                "title": "How to remove \\n, \\r, \\t in a json"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1566904406,
                "last_edit_date": 1566904406,
                "creation_date": 1566825883,
                "answer_id": 57658824,
                "question_id": 57657193,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Ok i solved the problem by disabling the defautl pretty print of jq. I added the -c option and now every json is on one line:\r\n\r\n    jq -c . file.json &gt; file2.json\r\n    cat file2.json\r\n    {&quot;temperature&quot;:&quot;21&quot;,&quot;humidity&quot;:&quot;12.3&quot;,&quot;message&quot;:&quot;Today ID 342 is running&quot;}\r\n    {&quot;temperature&quot;:&quot;13&quot;,&quot;humidity&quot;:&quot;40.1&quot;,&quot;message&quot;:&quot;Today ID 98 is running&quot;}\r\n\r\n\r\nI load them like this:\r\n\r\n    import json\r\n\r\n    measurements = []\r\n    with open(&#39;file2.json&#39;) as file_desc:\r\n        for line in file_desc:\r\n            # Treat each line as a separate document\r\n            measurements.append(json.loads(line))",
                "title": "How to remove \\n, \\r, \\t in a json"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 3,
        "last_activity_date": 1566904854,
        "creation_date": 1566819365,
        "question_id": 57657193,
        "body_markdown": "I&#39;m creating a json file using jq. This is the output:\r\n\r\n    {\r\n       &quot;temperature&quot;:&quot;21&quot;, \r\n       &quot;humidity&quot;:&quot;12.3&quot;, \r\n       &quot;message&quot;:&quot;Today ID 342 is running&quot;\r\n    }\r\n    {\r\n       &quot;temperature&quot;:&quot;13&quot;, \r\n       &quot;humidity&quot;:&quot;40.1&quot;, \r\n       &quot;message&quot;:&quot;Today ID 98 is running&quot;\r\n    }\r\n\r\nIf i try to open this file using Python, it gives me errors unless i remove manually newlines and tabs like this:\r\n\r\n    {&quot;temperature&quot;:&quot;21&quot;,&quot;humidity&quot;:&quot;12.3&quot;,&quot;message&quot;:&quot;Today ID 342 is running&quot;}\r\n    {&quot;temperature&quot;:&quot;13&quot;,&quot;humidity&quot;:&quot;40.1&quot;,&quot;message&quot;:&quot;Today ID 98 is running&quot;}\r\n\r\nI tried to use the -j option in jq, but nothing changed. Any suggestions? Also a solution which uses other programs is fine (sed etc). Thanks!!",
        "link": "https://stackoverflow.com/questions/57657193/how-to-remove-n-r-t-in-a-json",
        "title": "How to remove \\n, \\r, \\t in a json"
    },
    {
        "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": 1566830046,
                "post_id": 57658528,
                "comment_id": 101769241,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1526413,
                    "reputation": 13993,
                    "user_id": 1424739,
                    "user_type": "registered",
                    "accept_rate": 17,
                    "profile_image": "https://www.gravatar.com/avatar/19d3c927744b5ad3b94afbf88e1c3844?s=256&d=identicon&r=PG",
                    "display_name": "user1424739",
                    "link": "https://stackoverflow.com/users/1424739/user1424739"
                },
                "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": 1566831063,
                "post_id": 57658528,
                "comment_id": 101769791,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1526413,
                    "reputation": 13993,
                    "user_id": 1424739,
                    "user_type": "registered",
                    "accept_rate": 17,
                    "profile_image": "https://www.gravatar.com/avatar/19d3c927744b5ad3b94afbf88e1c3844?s=256&d=identicon&r=PG",
                    "display_name": "user1424739",
                    "link": "https://stackoverflow.com/users/1424739/user1424739"
                },
                "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": 1566831173,
                "post_id": 57658528,
                "comment_id": 101769848,
                "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": 1566831377,
                "post_id": 57658528,
                "comment_id": 101769929,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1526413,
                    "reputation": 13993,
                    "user_id": 1424739,
                    "user_type": "registered",
                    "accept_rate": 17,
                    "profile_image": "https://www.gravatar.com/avatar/19d3c927744b5ad3b94afbf88e1c3844?s=256&d=identicon&r=PG",
                    "display_name": "user1424739",
                    "link": "https://stackoverflow.com/users/1424739/user1424739"
                },
                "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": 1566831640,
                "post_id": 57658528,
                "comment_id": 101770051,
                "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": 1566832222,
                "post_id": 57658528,
                "comment_id": 101770316,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 308303,
                    "reputation": 37458,
                    "user_id": 620097,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/820980fd43f2607a815c1f3dbfe152cc?s=256&d=identicon&r=PG",
                    "display_name": "shellter",
                    "link": "https://stackoverflow.com/users/620097/shellter"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1566832623,
                "post_id": 57658528,
                "comment_id": 101770492,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1566871824,
                "last_edit_date": 1566871824,
                "creation_date": 1566833256,
                "answer_id": 57660829,
                "question_id": 57658528,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&quot;built-in&quot; means &quot;built in&quot;, that is, built into the distribution of jq.  One of the files in the jq repository used to build jq is called &quot;builtin.jq&quot; and can be found at https://github.com/stedolan/jq/blob/master/src/builtin.jq; it includes jq-defined definitions of jq filters.  \r\n\r\nThe word &quot;filter&quot; rather than &quot;function&quot; is appropriate in general because in mathematics especially, a &quot;function&quot; specifies exactly one output for each input, whereas this is not true of all jq filters.  Some jq filters ignore their inputs entirely; `empty` always emits nothing.\r\n\r\nSome of the jq built-ins are not even functional in nature, notably `input` and `inputs`.\r\n\r\n",
                "title": "What are &quot; arrays, objects, iterables, booleans, numbers, normals, finites, strings, nulls, values, scalars&quot; called in jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -3,
        "last_activity_date": 1566871824,
        "creation_date": 1566824813,
        "last_edit_date": 1566832370,
        "question_id": 57658528,
        "body_markdown": "`jq` manual says\r\n\r\n\r\n&gt; These built-ins select only inputs that are arrays, objects, iterables (arrays or objects), booleans, numbers, normal numbers, finite numbers, strings, null, non-null values, and non-iterables, respectively.\r\n\r\n\r\nThey are built-in of what? Is there a name for them? Function? Or something else? Thanks.",
        "link": "https://stackoverflow.com/questions/57658528/what-are-arrays-objects-iterables-booleans-numbers-normals-finites-stri",
        "title": "What are &quot; arrays, objects, iterables, booleans, numbers, normals, finites, strings, nulls, values, scalars&quot; called in jq?"
    },
    {
        "tags": [
            "python",
            "json",
            "export-to-csv",
            "jq",
            "tinder"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 45023,
                    "reputation": 59633,
                    "user_id": 132438,
                    "user_type": "registered",
                    "accept_rate": 43,
                    "profile_image": "https://i.sstatic.net/QJxe1.jpg?s=256",
                    "display_name": "Felipe Hoffa",
                    "link": "https://stackoverflow.com/users/132438/felipe-hoffa"
                },
                "reply_to_user": {
                    "account_id": 57200,
                    "reputation": 158728,
                    "user_id": 171318,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/ePRKy.jpg?s=256",
                    "display_name": "hek2mgl",
                    "link": "https://stackoverflow.com/users/171318/hek2mgl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1566870026,
                "post_id": 57666633,
                "comment_id": 101781907,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 45023,
                    "reputation": 59633,
                    "user_id": 132438,
                    "user_type": "registered",
                    "accept_rate": 43,
                    "profile_image": "https://i.sstatic.net/QJxe1.jpg?s=256",
                    "display_name": "Felipe Hoffa",
                    "link": "https://stackoverflow.com/users/132438/felipe-hoffa"
                },
                "reply_to_user": {
                    "account_id": 57200,
                    "reputation": 158728,
                    "user_id": 171318,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/ePRKy.jpg?s=256",
                    "display_name": "hek2mgl",
                    "link": "https://stackoverflow.com/users/171318/hek2mgl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1566870529,
                "post_id": 57666633,
                "comment_id": 101781987,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 45023,
                    "reputation": 59633,
                    "user_id": 132438,
                    "user_type": "registered",
                    "accept_rate": 43,
                    "profile_image": "https://i.sstatic.net/QJxe1.jpg?s=256",
                    "display_name": "Felipe Hoffa",
                    "link": "https://stackoverflow.com/users/132438/felipe-hoffa"
                },
                "reply_to_user": {
                    "account_id": 57200,
                    "reputation": 158728,
                    "user_id": 171318,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/ePRKy.jpg?s=256",
                    "display_name": "hek2mgl",
                    "link": "https://stackoverflow.com/users/171318/hek2mgl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1566870981,
                "post_id": 57666633,
                "comment_id": 101782055,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 45023,
                    "reputation": 59633,
                    "user_id": 132438,
                    "user_type": "registered",
                    "accept_rate": 43,
                    "profile_image": "https://i.sstatic.net/QJxe1.jpg?s=256",
                    "display_name": "Felipe Hoffa",
                    "link": "https://stackoverflow.com/users/132438/felipe-hoffa"
                },
                "reply_to_user": {
                    "account_id": 57200,
                    "reputation": 158728,
                    "user_id": 171318,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/ePRKy.jpg?s=256",
                    "display_name": "hek2mgl",
                    "link": "https://stackoverflow.com/users/171318/hek2mgl"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1566941469,
                "post_id": 57666633,
                "comment_id": 101811426,
                "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": 1566960594,
                "post_id": 57666633,
                "comment_id": 101814697,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1566952150,
                "last_edit_date": 1566952150,
                "creation_date": 1566869105,
                "answer_id": 57666634,
                "question_id": 57666633,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This Python code will do the job:\r\n\r\n    from __future__ import print_function\r\n    import json\r\n    import itertools\r\n    \r\n    # load json into an object\r\n    with open(&#39;data.json&#39;) as f:\r\n      d = json.load(f)\r\n    usage = d[&#39;Usage&#39;]\r\n    \r\n    # get all listed dates\r\n    dates = sorted(set(itertools.chain.from_iterable([[day for day in usage[t]] for t in usage])))\r\n    \r\n    # pivot data into one row per date with multiple columns\r\n    print(&#39;,&#39;.join([&#39;date&#39;]+[t for t in usage]))\r\n    for day in dates:\r\n      print(&#39;,&#39;.join([day] + [str(usage[t][day]) for t in usage]))\r\n\r\n\r\nThis will transform the usage data in the json file into a csv that will look like:\r\n\r\n    date,messages_sent,matches,messages_received,swipes_passes,swipes_likes,app_opens\r\n    2018-06-03,0,2,0,4,10,2\r\n    2018-06-04,2,2,1,1,18,6\r\n    2018-06-05,35,7,32,1,47,3\r\n    2018-06-06,16,1,9,4,32,2\r\n\r\n\r\n",
                "title": "How to transform your Tinder data.json into a CSV"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1566960716,
                "last_edit_date": 1566960716,
                "creation_date": 1566957548,
                "answer_id": 57684152,
                "question_id": 57666633,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To impress your date you obviously need something more hackish than Python. `jq` is a good choice since the input format is json:\r\n\r\n*tndr2csv*\r\n\r\n    #!/usr/bin/jq -rf\r\n    .Usage as $u|$u|keys as $k|\r\n    ([&quot;date&quot;]+$k|@csv),\r\n    (.[$k[0]]|keys|map(. as $d|[.]+($k|map($u[.][$d]))|@csv))[]\r\n    \r\nRun it like this:\r\n\r\n    $ chmod +x tndr2csv\r\n    $ ./tndr2csv data.json\r\n\r\nThis outputs:\r\n\r\n    &quot;date&quot;,&quot;app_opens&quot;,&quot;matches&quot;,&quot;messages_received&quot;,&quot;messages_sent&quot;,&quot;swipes_likes&quot;,&quot;swipes_passes&quot;\r\n    &quot;2018-06-03&quot;,3,3,30,7,30,56\r\n    &quot;2018-06-04&quot;,10,1,1,9,4,1\r\n    &quot;2018-06-05&quot;,2,7,20,0,4,8\r\n\r\n... which can be opened as a spreadsheet.\r\n\r\n",
                "title": "How to transform your Tinder data.json into a CSV"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1567060764,
                "creation_date": 1567060764,
                "answer_id": 57704368,
                "question_id": 57666633,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is an easy-to-read and robust jq program that does the job:\r\n```\r\n[&quot;date&quot;, &quot;messages_sent&quot;, &quot;matches&quot;, &quot;messages_received&quot;, &quot;swipes_passes&quot;, &quot;swipes_likes&quot;, &quot;app_opens&quot;] as $keys\r\n| .Usage \r\n| ([.[] | keys_unsorted] | add | unique) as $dates\r\n| $keys,\r\n  ($dates[] as $d | [$d] + [ .[$keys[1:][]][$d] ])\r\n|  @csv\r\n```\r\n\r\nIt is &quot;robust&quot; in several senses -- the ordering of the keys within the input objects is unimportant, and the objects with dates as keys need not have the same keys, and they need not be in the same order, or indeed in chronological order.  Amongst all programs which have the same or more robustness, this program is also efficient.",
                "title": "How to transform your Tinder data.json into a CSV"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 4,
        "last_activity_date": 1567060764,
        "creation_date": 1566869105,
        "last_edit_date": 1567058513,
        "question_id": 57666633,
        "body_markdown": "Tinder allows you to export your data (https://account.gotinder.com/data), which ends up exporting a `data.json` file.\r\n\r\nHow can I transform this nested json into a CSV file I can load into a spreadsheet?\r\n\r\nThe file looks something like this:\r\n\r\n    $ cat data.json  |jq .Usage\r\n    {\r\n      &quot;app_opens&quot;: {\r\n        &quot;2018-06-03&quot;: 3,\r\n        &quot;2018-06-04&quot;: 10,\r\n        &quot;2018-06-05&quot;: 2,\r\n    ...\r\n\r\nWith usage for:\r\n\r\n    messages_sent\r\n    matches\r\n    messages_received\r\n    swipes_passes\r\n    swipes_likes\r\n    app_opens\r\n\r\n\r\nA full json with the interesting data would look like:\r\n\r\n    {\r\n    \t&quot;Usage&quot;: {\r\n    \t\t&quot;app_opens&quot;: {\r\n    \t\t\t&quot;2018-06-03&quot;: 3,\r\n    \t\t\t&quot;2018-06-04&quot;: 10,\r\n    \t\t\t&quot;2018-06-05&quot;: 2\r\n    \t\t},\r\n    \t\t&quot;messages_sent&quot;: {\r\n    \t\t\t&quot;2018-06-03&quot;: 7,\r\n    \t\t\t&quot;2018-06-04&quot;: 9,\r\n    \t\t\t&quot;2018-06-05&quot;: 0\r\n    \t\t},\r\n    \t\t&quot;matches&quot;: {\r\n    \t\t\t&quot;2018-06-03&quot;: 3,\r\n    \t\t\t&quot;2018-06-04&quot;: 1,\r\n    \t\t\t&quot;2018-06-05&quot;: 7\r\n    \t\t},\r\n    \t\t&quot;messages_received&quot;: {\r\n    \t\t\t&quot;2018-06-03&quot;: 30,\r\n    \t\t\t&quot;2018-06-04&quot;: 1,\r\n    \t\t\t&quot;2018-06-05&quot;: 20\r\n    \t\t},\r\n    \t\t&quot;swipes_passes&quot;: {\r\n    \t\t\t&quot;2018-06-03&quot;: 56,\r\n    \t\t\t&quot;2018-06-04&quot;: 1,\r\n    \t\t\t&quot;2018-06-05&quot;: 8\r\n    \t\t},\r\n    \t\t&quot;swipes_likes&quot;: {\r\n    \t\t\t&quot;2018-06-03&quot;: 30,\r\n    \t\t\t&quot;2018-06-04&quot;: 4,\r\n    \t\t\t&quot;2018-06-05&quot;: 4\r\n    \t\t}\r\n    \t}\r\n    }\r\n\r\nThe output should look like this:\r\n\r\n    date,messages_sent,matches,messages_received,swipes_passes,swipes_likes,app_opens\r\n    2018-06-03,0,2,0,4,10,2\r\n    2018-06-04,2,2,1,1,18,6\r\n    2018-06-05,35,7,32,1,47,3\r\n\r\n",
        "link": "https://stackoverflow.com/questions/57666633/how-to-transform-your-tinder-data-json-into-a-csv",
        "title": "How to transform your Tinder data.json into a CSV"
    },
    {
        "tags": [
            "bash",
            "shell",
            "awk",
            "split",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1566904802,
                "last_edit_date": 1566904802,
                "creation_date": 1566902747,
                "answer_id": 57673012,
                "question_id": 57672838,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is a `jq` solution:\r\n\r\n    jq -cR &#39;. | gsub(&quot;^ +| +$&quot;; &quot;&quot;) | split(&quot; *, *&quot;; &quot;&quot;)&#39; &lt;&lt;&lt; &quot;TAG1,TAG2&quot;\r\n    [&quot;TAG1&quot;,&quot;TAG2&quot;]\r\n    \r\n    jq -cR &#39;. | gsub(&quot;^ +| +$&quot;; &quot;&quot;) | split(&quot; *, *&quot;; &quot;&quot;)&#39; &lt;&lt;&lt; &quot;TAG1, TAG2&quot;\r\n    [&quot;TAG1&quot;,&quot;TAG2&quot;]\r\n    \r\n    jq -cR &#39;. | gsub(&quot;^ +| +$&quot;; &quot;&quot;) | split(&quot; *, *&quot;; &quot;&quot;)&#39; &lt;&lt;&lt; &quot;   TAG1,       TAG2     &quot;\r\n    [&quot;TAG1&quot;,&quot;TAG2&quot;]\r\n\r\n**PS:** Remove `-c` if you want pretty `json` output.\r\n\r\n---\r\n\r\nYou may also use `awk`:\r\n\r\n    cat comma.csv\r\n&lt;p/&gt;\r\n   \r\n    BEGIN {\r\n       FS = &quot; *, *&quot;\r\n       OFS=&quot;, &quot;\r\n    }\r\n    {\r\n       for (i=1; i&lt;=NF; i++) {\r\n          gsub(/^ *| *$/, &quot;&quot;, $i)\r\n          $i = &quot;\\&quot;&quot; $i &quot;\\&quot;&quot;\r\n       }\r\n\r\n       print &quot;[ &quot; $0 &quot; ]&quot;\r\n    }\r\n\r\nand use it as:\r\n\r\n    awk -f comma.csv &lt;&lt;&lt; &quot;TAG1, TAG2&quot;\r\n    [ &quot;TAG1&quot;, &quot;TAG2&quot; ]\r\n    \r\n    awk -f comma.csv &lt;&lt;&lt; &quot;TAG1,TAG2&quot;\r\n    [ &quot;TAG1&quot;, &quot;TAG2&quot; ]\r\n    \r\n    awk -f comma.csv &lt;&lt;&lt; &quot;   TAG1,   TAG2   &quot;\r\n    [ &quot;TAG1&quot;, &quot;TAG2&quot; ]\r\n\r\n---\r\n\r\n**`sed` solution:**\r\n\r\n    sed &#39;s/^ */[ &quot;/; s/ *$/&quot; ]/; s/ *, */&quot;, &quot;/g&#39; &lt;&lt;&lt; &quot;       TAG1,        TAG2     &quot;\r\n    [ &quot;TAG1&quot;, &quot;TAG2&quot; ]    \r\n    \r\n    sed &#39;s/^ */[ &quot;/; s/ *$/&quot; ]/; s/ *, */&quot;, &quot;/g&#39; &lt;&lt;&lt; &quot;TAG1,TAG2&quot;\r\n    [ &quot;TAG1&quot;, &quot;TAG2&quot; ]\r\n    \r\n    sed &#39;s/^ */[ &quot;/; s/ *$/&quot; ]/; s/ *, */&quot;, &quot;/g&#39; &lt;&lt;&lt; &quot;TAG1 , TAG2&quot;\r\n    [ &quot;TAG1&quot;, &quot;TAG2&quot; ]\r\n\r\n\r\n",
                "title": "How to add double quotes around the values separated by a delimiter?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1566905428,
                "last_edit_date": 1566905428,
                "creation_date": 1566903704,
                "answer_id": 57673272,
                "question_id": 57672838,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I don&#39;t what does &quot;trim&quot; mean, I assume whitespaces can be safely ignored.\r\n\r\nSo first let&#39;s read the input into an array. Read items separated by spaces or comma.\r\n\r\n    input=&quot;        TAG1        ,      TAG2        &quot;\r\n    IFS=&#39;, &#39; read -r -a input &lt;&lt;&lt;&quot;$input&quot;\r\n\r\nThen create the `output`: first output array elements quoetd with `&quot;` on separate newlines, then join them with a comma, add leading `[` and trailing `]`:\r\n\r\n    output=&quot;[ $(printf &#39;&quot;%s&quot;\\n&#39; &quot;${input[@]}&quot; | paste -sd,) ]&quot;\r\n    echo &quot;$output&quot;",
                "title": "How to add double quotes around the values separated by a delimiter?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1566905428,
        "creation_date": 1566902196,
        "last_edit_date": 1566905041,
        "question_id": 57672838,
        "body_markdown": "I take a string with values separated by `,`. I need to place &quot;around them&quot; the double quotes and, after each split, do a trim.\r\n\r\nHere&#39;s my actual code:\r\n\r\n\tinput=&quot;TAG1, TAG2&quot;\r\n\toutput=&#39;[ &quot;&#39;${input//, /\\&quot;, \\&quot;}&#39;&quot; ]&#39;\r\n\techo &quot;$output&quot;\r\n\r\nwhich correctly display:\r\n\r\n    [ &quot;TAG1&quot;, &quot;TAG2&quot; ]\r\n\r\nBut:\r\n\r\n1. It doesn&#39;t works if I use `input=&quot;TAG1,TAG2&quot;` (i.e. no space after `,`)\r\n2. If I use`input=&quot;   TAG1,   TAG2   &quot;`, it keep spaces and don&#39;t trim each match. It should, for each item.\r\n\r\nHow would you do it?",
        "link": "https://stackoverflow.com/questions/57672838/how-to-add-double-quotes-around-the-values-separated-by-a-delimiter",
        "title": "How to add double quotes around the values separated by a delimiter?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 7,
                "is_accepted": true,
                "score": 7,
                "last_activity_date": 1651502652,
                "last_edit_date": 1651502652,
                "creation_date": 1566902715,
                "answer_id": 57672998,
                "question_id": 57672861,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Split `url` by slashes, and use the result for generating new fields.\r\n```\r\n{item} + (.url / &quot;/&quot; | {number: .[-2], room: .[-1]})\r\n```",
                "title": "Split string into fields in JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1651502722,
        "creation_date": 1566902262,
        "last_edit_date": 1651502722,
        "question_id": 57672861,
        "body_markdown": "I have this JSON:\r\n\r\n    {&quot;item&quot;:2, &quot;url&quot;:&quot;domain/house/23/bedroom&quot;}\r\n\r\nI&#39;m trying to use jq to obtain this new JSON:\r\n\r\n    {&quot;item&quot;:2, &quot;number&quot;:&quot;23&quot;, &quot;room&quot;:&quot;bedroom&quot;}\r\n\r\nIs it possible to do this in JQ? As a first step, I tried to use the capture function to catch the substring after &quot;/house/&quot;, but it doesn&#39;t work:\r\n\r\n    cat myjson.json | jq -c &#39;{item:.item,substring:(.url | capture(&quot;/house/.*&quot;).substring)}&#39;\r\n\r\nIs there a way to extract both values and put them in two different fields?",
        "link": "https://stackoverflow.com/questions/57672861/split-string-into-fields-in-jq",
        "title": "Split string into fields in JQ"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1566942717,
                "creation_date": 1566942717,
                "answer_id": 57682677,
                "question_id": 57682306,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You are iterating independently by using results twice, so you get every combination of the errors and messages, instead you want to pipe results elements in as the input to use each result alone:\r\n\r\n    .. | jq  &#39;.results[] | .response.error + &quot; ==&gt; &quot; + .msg&#39;",
                "title": "How to solve this JQ string concatenation issue?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1566942717,
        "creation_date": 1566940194,
        "question_id": 57682306,
        "body_markdown": "I am making an API call, and it returns me a json body. After that, I want to extract some value per each result entry. \r\n \r\nHere the picture of my full API response body:  \r\n\r\n    {\r\n      &quot;count&quot;: 7,\r\n      &quot;results&quot;: [\r\n        {\r\n          &quot;index&quot;: 1,\r\n          &quot;response&quot;: {\r\n            &quot;error&quot;: &quot;Restore full config failed Case1.&quot;\r\n          },\r\n          &quot;status_code&quot;: 500,\r\n          &quot;msg&quot;: &quot;[Fullconfig:POST:blalblablabla:admin] Status code: 500&quot;,\r\n          &quot;sort&quot;: [\r\n            1562572224627\r\n          ]\r\n        },\r\n        {\r\n          &quot;index&quot;: 2,\r\n          &quot;response&quot;: {\r\n            &quot;error&quot;: &quot;Restore full config failed Case2.&quot;\r\n          },\r\n          &quot;status_code&quot;: 500,\r\n          &quot;msg&quot;: &quot;[Fullconfig:POST:blalblabla:admin] Status code: 500&quot;,\r\n          &quot;sort&quot;: [\r\n            1562572216215\r\n          ]\r\n        }\r\n      ]\r\n    }\r\n\r\nI have added this extra jq command after my api call: \r\n\r\n    &lt; my api call here &gt;  | jq  &#39;.results[].response.error + &quot; ==&gt; &quot; + .results[].msg&#39;\r\n\r\nAnd I have got 4 rows, instead of 2.  \r\n\r\n    &quot;Restore full config failed Case1. ==&gt; [Fullconfig:POST:blalblablabla:admin] Status code: 500&quot;\r\n    &quot;Restore full config failed Case2. ==&gt; [Fullconfig:POST:blalblablabla:admin] Status code: 500&quot;\r\n    &quot;Restore full config failed Case1. ==&gt; [Fullconfig:POST:blalblabla:admin] Status code: 500&quot;\r\n    &quot;Restore full config failed Case2. ==&gt; [Fullconfig:POST:blalblabla:admin] Status code: 500&quot;\r\n\r\nHow do I correct that ? \r\n\r\nThanks, \r\n\r\nJack \r\n",
        "link": "https://stackoverflow.com/questions/57682306/how-to-solve-this-jq-string-concatenation-issue",
        "title": "How to solve this JQ string concatenation issue?"
    },
    {
        "tags": [
            "json",
            "bash",
            "curl",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1566989844,
                "last_edit_date": 1566989844,
                "creation_date": 1566987163,
                "answer_id": 57690011,
                "question_id": 57689809,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Trying to keep this in JSON all the way is pretty cumbersome. I would simply try to make Bash construct a new valid JSON fragment inside the loop.\r\n\r\nSo in other words, if `$url` is the URL and `$redirect` is where it redirects to, you can do something like\r\n\r\n    printf &#39;{&quot;url&quot;: &quot;%s&quot;, &quot;redirection&quot;: &quot;%s&quot;}\\n&#39; &quot;$url&quot; &quot;$redirect&quot;\r\n\r\nto produce JSON output from these strings.  So tying it all together\r\n\r\n    jq -r &#39;.[].url&#39; &lt;&lt;&lt;&quot;$json&quot; |\r\n    while read -r url; do\r\n        printf &#39;{&quot;url:&quot; &quot;%s&quot;, &quot;redirection&quot;: &quot;%s&quot;}\\n&#39; \\\r\n            &quot;$url&quot; &quot;$(curl -LSs -o /dev/null -w &#39;%{url_effective}&#39; &quot;$url&quot;)&quot;\r\n    done |\r\n    jq -s\r\n\r\nThis is still pretty brittle; in particular, if either of the `printf` input strings could contain a literal double quote, that should properly be escaped.",
                "title": "use curl/bash command in jq"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1566991586,
                "last_edit_date": 1566991586,
                "creation_date": 1566988467,
                "answer_id": 57690440,
                "question_id": 57689809,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I would generate a dictionary with `jq` per url and slurp those dictionaries into the final list with `jq -s`:\r\n\r\n    json=&#39;[{&quot;url&quot;:&quot;google.com&quot;},{&quot;url&quot;:&quot;microsoft.com&quot;}]&#39;  \r\n\r\n    echo &quot;$json&quot; | jq -r &#39;.[].url&#39; | while read url; do\r\n        redirect=$(curl -LSs \\\r\n                        -o /dev/null \\\r\n                        -w &#39;%{url_effective}&#39; \\\r\n                        &quot;${url}&quot; 2&gt;/dev/null)\r\n        jq --null-input --arg url &quot;${url}&quot; --arg redirect &quot;${redirect}&quot; \\\r\n            &#39;{url:$url, redirect: $redirect}&#39;\r\n    done | jq -s\r\n\r\n---\r\n\r\nAlternative (first) solution:\r\n\r\nYou can output the url and the effective_url as tab separated data and create the output json with `jq`:\r\n\r\n    json=&#39;[{&quot;url&quot;:&quot;google.com&quot;},{&quot;url&quot;:&quot;microsoft.com&quot;}]&#39;\r\n      \r\n    echo &quot;$json&quot; | jq -r &#39;.[].url&#39; | while read line; do\r\n        prefix=&quot;${line}\\t&quot;\r\n        curl -LSs -o /dev/null -w &quot;${prefix}&quot;&#39;%{url_effective}&#39;&quot;\\n&quot; &quot;$line&quot; 2&gt;/dev/null\r\n    done | jq -r --raw-input &#39;split(&quot;\\t&quot;)|{&quot;url&quot;:.[0],&quot;redirection&quot;:.[1]}&#39;\r\n\r\n---\r\n\r\nBoth solutions will generate valid json, independently of whatever characters the url/effective_url might contain.",
                "title": "use curl/bash command in jq"
            },
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1608019270,
                "last_edit_date": 1608019270,
                "creation_date": 1566999339,
                "answer_id": 57693755,
                "question_id": 57689809,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`curl` is capable of making multiple transfers in a single process, and it can also [read command line arguments from a file or stdin](https://curl.haxx.se/docs/manpage.html#-K), so, you don&#39;t need a loop at all, just put that JSON into a file and run this:\r\n```\r\njq -r &#39;&quot;-o /dev/null\\nurl = \\(.[].url)&quot;&#39; file |\r\ncurl -sSLK- -w&#39;%{url_effective}\\n&#39; |\r\njq -R &#39;fromjson | map(. + {redirection: input})&#39; file -\r\n```\r\nThis way only *3* processes will be spawned for the whole task, instead of *n + 2* where *n* is the number of URLs.",
                "title": "use curl/bash command in jq"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 4,
        "last_activity_date": 1608019270,
        "creation_date": 1566986516,
        "last_edit_date": 1567012296,
        "question_id": 57689809,
        "body_markdown": "I am trying to get a list of URL after redirection using `bash` scripting. Say, `google.com` gets redirected to `http://www.google.com` with `301` status.\r\nWhat I have tried is:\r\n```\r\njson=&#39;[{&quot;url&quot;:&quot;google.com&quot;},{&quot;url&quot;:&quot;microsoft.com&quot;}]&#39;\r\n\r\necho &quot;$json&quot; | jq -r &#39;.[].url&#39; | while read line; do\r\n    curl -LSs -o /dev/null -w %{url_effective} $line 2&gt;/dev/null\r\ndone\r\n```\r\nSo, is it possible for us to use commands like `curl` inside `jq` for processing JSON objects.\r\nI want to add the resulting URL to existing JSON structure like:\r\n```\r\n[\r\n  {\r\n    &quot;url&quot;: &quot;google.com&quot;,\r\n    &quot;redirection&quot;: &quot;http://www.google.com&quot;\r\n  },\r\n  {\r\n    &quot;url&quot;: &quot;microsoft.com&quot;,\r\n    &quot;redirection&quot;: &quot;https://www.microsoft.com&quot;\r\n  }\r\n]\r\n\r\n```\r\nThank you in advance..!",
        "link": "https://stackoverflow.com/questions/57689809/use-curl-bash-command-in-jq",
        "title": "use curl/bash command in jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1566998479,
                "creation_date": 1566998479,
                "answer_id": 57693471,
                "question_id": 57691878,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Given the string input string `Twitter,Wikipedia (en)`, you can use jq to update the JSON data:\r\n\r\n    &lt;file jq --arg i &#39;Twitter,Wikipedia (en)&#39; &#39;.policies.SearchEngines += ({ Remove: $i | split(&quot;,&quot;) })&#39;\r\n    {\r\n      &quot;policies&quot;: {\r\n        &quot;SearchBar&quot;: &quot;separate&quot;,\r\n        &quot;SearchEngines&quot;: {\r\n          &quot;PreventInstalls&quot;: false,\r\n          &quot;Remove&quot;: [\r\n            &quot;Twitter&quot;,\r\n            &quot;Wikipedia (en)&quot;\r\n          ]\r\n        }\r\n      }\r\n    }\r\n",
                "title": "How do I add dynamically generated arrays with jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1567015609,
        "creation_date": 1566993434,
        "last_edit_date": 1567015609,
        "question_id": 57691878,
        "body_markdown": "I&#39;m using jq 1.6 on Windows 7 and want to add a dynamically generated array to a json file.\r\nThat array doesn&#39;t yet exist in this file.\r\n\r\nI&#39;ve got the following JSON structure (reduced for reasons of clarity):\r\n\r\n    {\r\n      &quot;policies&quot;: {\r\n        &quot;SearchBar&quot;: &quot;separate&quot;,\r\n        &quot;SearchEngines&quot;: {\r\n          &quot;PreventInstalls&quot;: false\r\n        }\r\n      }\r\n    }\r\n\r\nI&#39;d like to generate an array based on dynamic values and finally create the following output:\r\n\r\n    {\r\n      &quot;policies&quot;: {\r\n        &quot;SearchBar&quot;: &quot;separate&quot;,\r\n        &quot;SearchEngines&quot;: {\r\n          &quot;PreventInstalls&quot;: false,\r\n          &quot;Remove&quot;: [\r\n            &quot;Twitter&quot;,\r\n            &quot;Wikipedia (en)&quot;\r\n          ]\r\n        }\r\n      }\r\n    }\r\n\r\nThe Remove array&#39;s content is stored in a (cmd) %variable%.\r\nI found that the line\r\n\r\n    jq -n --arg items &quot;%variable%&quot; &quot;{ Remove: $items | split(\\&quot;,\\&quot;) }&quot;\r\n\r\nproduces the array I want:\r\n\r\n    {\r\n      &quot;Remove&quot;: [\r\n        &quot;Twitter&quot;,\r\n        &quot;Wikipedia (en)&quot;\r\n      ]\r\n    }\r\n\r\nWhat is the best way to insert this array into the original file?\r\n",
        "link": "https://stackoverflow.com/questions/57691878/how-do-i-add-dynamically-generated-arrays-with-jq",
        "title": "How do I add dynamically generated arrays with jq?"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 16018556,
                    "reputation": 507,
                    "user_id": 11560579,
                    "user_type": "registered",
                    "profile_image": "https://lh5.googleusercontent.com/-69hgqZffjPA/AAAAAAAAAAI/AAAAAAAAADw/Ex5BZxHbXC0/s256-rj/photo.jpg",
                    "display_name": "Wei Seng Tan",
                    "link": "https://stackoverflow.com/users/11560579/wei-seng-tan"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1567003193,
                "post_id": 57694872,
                "comment_id": 101833954,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 16104390,
                    "reputation": 1,
                    "user_id": 11624253,
                    "user_type": "registered",
                    "profile_image": "https://lh5.googleusercontent.com/-75NmZLAtGY0/AAAAAAAAAAI/AAAAAAAAACY/InvWC48VoQ8/s256-rj/photo.jpg",
                    "display_name": "hoang giap",
                    "link": "https://stackoverflow.com/users/11624253/hoang-giap"
                },
                "reply_to_user": {
                    "account_id": 16018556,
                    "reputation": 507,
                    "user_id": 11560579,
                    "user_type": "registered",
                    "profile_image": "https://lh5.googleusercontent.com/-69hgqZffjPA/AAAAAAAAAAI/AAAAAAAAADw/Ex5BZxHbXC0/s256-rj/photo.jpg",
                    "display_name": "Wei Seng Tan",
                    "link": "https://stackoverflow.com/users/11560579/wei-seng-tan"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1567003324,
                "post_id": 57694872,
                "comment_id": 101834017,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1567235803,
                "last_edit_date": 1567235803,
                "creation_date": 1567003631,
                "answer_id": 57695033,
                "question_id": 57694872,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "    jq &#39;.data[] | select(.orderid | startswith(&quot;40007&quot;))&#39; output.json",
                "title": "How can i filter JSON file with nearest object key using JQ?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -2,
        "last_activity_date": 1567235803,
        "creation_date": 1567002973,
        "last_edit_date": 1567003400,
        "question_id": 57694872,
        "body_markdown": "I have to filter JSON file with nearest object name using JQ.\r\n\r\nI already try with command:\r\n\r\n    jq &#39;.data[] |select(.orderid==&quot;40007600&quot;)&#39; output.json\r\n\r\nbut the command only filter the object with exact name. I want to filter the object start with string &quot;40007&quot; like that : `.orderid=&quot;40007&quot;`. \r\n\r\n```JSON\r\n{\r\n  &quot;data&quot;: [\r\n    {\r\n      &quot;orderid&quot;: &quot;40007600&quot;,\r\n      &quot;price&quot;: &quot;9.99&quot;,\r\n      &quot;listingname&quot;: &quot;iPhone 8&quot;,\r\n      &quot;smallphoto&quot;: &quot;https://images-eu.ssl-images-amazon.com/images/I/51b5iaLTjgL._SL160_.jpg&quot;,\r\n      &quot;photo&quot;: &quot;https://images-eu.ssl-images-amazon.com/images/I/51b5iaLTjgL.jpg&quot;\r\n    },\r\n     {\r\n      &quot;orderid&quot;: &quot;40007598&quot;,\r\n      &quot;price&quot;: &quot;9.99&quot;,\r\n      &quot;listingname&quot;: &quot;iPhone 8 Plus&quot;,\r\n      &quot;smallphoto&quot;: &quot;https://images-eu.ssl-images-amazon.com/images/I/51CVLqsSNkL._SL160_.jpg&quot;,\r\n      &quot;photo&quot;: &quot;https://images-eu.ssl-images-amazon.com/images/I/51CVLqsSNkL.jpg&quot;\r\n    },\r\n     {\r\n      &quot;orderid&quot;: &quot;40007595&quot;,\r\n      &quot;price&quot;: &quot;9.39&quot;,\r\n      &quot;listingname&quot;: &quot;Nadelflaschen&quot;,\r\n      &quot;smallphoto&quot;: &quot;https://images-eu.ssl-images-amazon.com/images/I/41OHDP2rAeL._SL160_.jpg&quot;,\r\n      &quot;photo&quot;: &quot;https://images-eu.ssl-images-amazon.com/images/I/41OHDP2rAeL.jpg&quot;\r\n    }\r\n]\r\n}\r\n```",
        "link": "https://stackoverflow.com/questions/57694872/how-can-i-filter-json-file-with-nearest-object-key-using-jq",
        "title": "How can i filter JSON file with nearest object key using JQ?"
    },
    {
        "tags": [
            "json",
            "bash",
            "zsh",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1613587,
                    "reputation": 786618,
                    "user_id": 1491895,
                    "user_type": "registered",
                    "accept_rate": 69,
                    "profile_image": "https://www.gravatar.com/avatar/82f9e178a16364bf561d0ed4da09a35d?s=256&d=identicon&r=PG",
                    "display_name": "Barmar",
                    "link": "https://stackoverflow.com/users/1491895/barmar"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1567007629,
                "post_id": 57696097,
                "comment_id": 101836517,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1613587,
                    "reputation": 786618,
                    "user_id": 1491895,
                    "user_type": "registered",
                    "accept_rate": 69,
                    "profile_image": "https://www.gravatar.com/avatar/82f9e178a16364bf561d0ed4da09a35d?s=256&d=identicon&r=PG",
                    "display_name": "Barmar",
                    "link": "https://stackoverflow.com/users/1491895/barmar"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1567007804,
                "post_id": 57696097,
                "comment_id": 101836612,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1613587,
                    "reputation": 786618,
                    "user_id": 1491895,
                    "user_type": "registered",
                    "accept_rate": 69,
                    "profile_image": "https://www.gravatar.com/avatar/82f9e178a16364bf561d0ed4da09a35d?s=256&d=identicon&r=PG",
                    "display_name": "Barmar",
                    "link": "https://stackoverflow.com/users/1491895/barmar"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1567007858,
                "post_id": 57696097,
                "comment_id": 101836647,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5428620,
                    "reputation": 600,
                    "user_id": 4320184,
                    "user_type": "registered",
                    "accept_rate": 12,
                    "profile_image": "https://www.gravatar.com/avatar/9da43a7cb4f685c3db616ad144f5de69?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "dashenswen",
                    "link": "https://stackoverflow.com/users/4320184/dashenswen"
                },
                "reply_to_user": {
                    "account_id": 1613587,
                    "reputation": 786618,
                    "user_id": 1491895,
                    "user_type": "registered",
                    "accept_rate": 69,
                    "profile_image": "https://www.gravatar.com/avatar/82f9e178a16364bf561d0ed4da09a35d?s=256&d=identicon&r=PG",
                    "display_name": "Barmar",
                    "link": "https://stackoverflow.com/users/1491895/barmar"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1567008023,
                "post_id": 57696097,
                "comment_id": 101836740,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5428620,
                    "reputation": 600,
                    "user_id": 4320184,
                    "user_type": "registered",
                    "accept_rate": 12,
                    "profile_image": "https://www.gravatar.com/avatar/9da43a7cb4f685c3db616ad144f5de69?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "dashenswen",
                    "link": "https://stackoverflow.com/users/4320184/dashenswen"
                },
                "reply_to_user": {
                    "account_id": 1613587,
                    "reputation": 786618,
                    "user_id": 1491895,
                    "user_type": "registered",
                    "accept_rate": 69,
                    "profile_image": "https://www.gravatar.com/avatar/82f9e178a16364bf561d0ed4da09a35d?s=256&d=identicon&r=PG",
                    "display_name": "Barmar",
                    "link": "https://stackoverflow.com/users/1491895/barmar"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1567008251,
                "post_id": 57696097,
                "comment_id": 101836864,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5428620,
                    "reputation": 600,
                    "user_id": 4320184,
                    "user_type": "registered",
                    "accept_rate": 12,
                    "profile_image": "https://www.gravatar.com/avatar/9da43a7cb4f685c3db616ad144f5de69?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "dashenswen",
                    "link": "https://stackoverflow.com/users/4320184/dashenswen"
                },
                "reply_to_user": {
                    "account_id": 1613587,
                    "reputation": 786618,
                    "user_id": 1491895,
                    "user_type": "registered",
                    "accept_rate": 69,
                    "profile_image": "https://www.gravatar.com/avatar/82f9e178a16364bf561d0ed4da09a35d?s=256&d=identicon&r=PG",
                    "display_name": "Barmar",
                    "link": "https://stackoverflow.com/users/1491895/barmar"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1567008423,
                "post_id": 57696097,
                "comment_id": 101836949,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8783277,
                    "reputation": 459,
                    "user_id": 6566252,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/0694788dd694d7e063f0c4d78e566bbd?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Bizzu",
                    "link": "https://stackoverflow.com/users/6566252/bizzu"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1567009184,
                "post_id": 57696097,
                "comment_id": 101837286,
                "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": 1567010941,
                "post_id": 57696097,
                "comment_id": 101837995,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1567008348,
                "creation_date": 1567008348,
                "answer_id": 57696344,
                "question_id": 57696097,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use `.host` to get the `host` properties.\r\n\r\n```\r\n$ hosts_list=&#39;  {\r\n    &quot;status&quot;: &quot;closed&quot;,\r\n    &quot;host&quot;: &quot;host1-availabe_zone_A&quot;\r\n  }\r\n  {\r\n    &quot;status&quot;: &quot;closed&quot;,\r\n    &quot;host&quot;: &quot;host2-availabe_zone_B&quot;\r\n  }\r\n  {\r\n    &quot;status&quot;: &quot;closed&quot;,\r\n    &quot;host&quot;: &quot;host3-availabe_zone_A&quot;\r\n  }&#39;\r\n$ for host in $(jq -r &#39;.host&#39; &lt;&lt;&lt;  &quot;$hosts_list&quot;)\r\ndo\r\n echo &quot;$host&quot;\r\ndone\r\nhost1-availabe_zone_A\r\nhost2-availabe_zone_B\r\nhost3-availabe_zone_A\r\n```\r\n\r\nUse the `-r` option to make it output raw strings, rather than JSON strings surrounded by double quotes.\r\n\r\nAnd don&#39;t forget to quote variables unless you deliberately need word-splitting and wildcard matching to be done on the value.",
                "title": "Loop through json variable"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1567013545,
                "creation_date": 1567013545,
                "answer_id": 57697446,
                "question_id": 57696097,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You&#39;re just counting values in your json. Split out the part you want to count\r\n\r\n    $ jq -nr &#39;inputs.host/&quot;-&quot;|last&#39; input.json\r\n    availabe_zone_A\r\n    availabe_zone_B\r\n    availabe_zone_A\r\n\r\nthen you could either group and count:\r\n\r\n    $ jq -nr &#39;[inputs.host/&quot;-&quot;|last]|group_by(.)[]|&quot;\\(.[0]) -&gt; \\(length)&quot;&#39; input.json\r\n    availabe_zone_A -&gt; 2\r\n    availabe_zone_B -&gt; 1\r\n\r\nhttps://jqplay.org/s/g_8HgqiQ1o\r\n\r\nor iterate the values tallying as you go:\r\n\r\n    $ jq -nr &#39;\r\n    reduce (inputs.host/&quot;-&quot;|last) as $k ({}; .[$k] += 1)|to_entries[]|&quot;\\(.key) -&gt; \\(.value)&quot;\r\n    &#39; input.json\r\n    availabe_zone_A -&gt; 2\r\n    availabe_zone_B -&gt; 1\r\n\r\nhttps://jqplay.org/s/S2oeLfMRNR",
                "title": "Loop through json variable"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1567014488,
                "last_edit_date": 1567014488,
                "creation_date": 1567013973,
                "answer_id": 57697541,
                "question_id": 57696097,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With the following in program.jq:\r\n\r\n    # bag of words\r\n    def bow(stream): \r\n      reduce stream as $word ({}; .[($word|tostring)] += 1);\r\n    \r\n    bow(inputs | .host | sub(&quot;^.*-availabe&quot;;&quot;availabe&quot;))\r\n\r\nthe invocation:\r\n\r\n    jq -n -f program.jq input.json\r\n\r\nproduces\r\n\r\n    {\r\n      &quot;availabe_zone_A&quot;: 2,\r\n      &quot;availabe_zone_B&quot;: 1\r\n    }\r\n\r\nIf you really want the output in the STRING --&gt; N format,\r\nadd -r to the command-line options, and add the following\r\ntwo lines to program.jq: \r\n\r\n    | to_entries[]\r\n    | &quot;\\(.key) --&gt; \\(.value)&quot;\r\n\r\n## Comments\r\n1. You might want to fix the spelling (&quot;available&quot; vs &quot;availabe&quot;)\r\n2. As this example illustrates, jq can handle an input stream consisting of JSON entities -- i.e. a stream of JSON. ",
                "title": "Loop through json variable"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 2,
        "last_activity_date": 1567014488,
        "creation_date": 1567007375,
        "last_edit_date": 1567009818,
        "question_id": 57696097,
        "body_markdown": "I have a json variable which looks like this:\r\n```\r\n{\r\n  &quot;status&quot;: &quot;closed&quot;,\r\n  &quot;host&quot;: &quot;host1-availabe_zone_A&quot;\r\n}\r\n{\r\n  &quot;status&quot;: &quot;closed&quot;,\r\n  &quot;host&quot;: &quot;host2-availabe_zone_B&quot;\r\n}\r\n{\r\n  &quot;status&quot;: &quot;closed&quot;,\r\n  &quot;host&quot;: &quot;host3-availabe_zone_A&quot;\r\n}\r\n```\r\nI am trying to convert it to a hash-like data structure (associate array in zsh/bash) to get number of hosts in each availabe zone. The preferred result will be this based on the data above:\r\n```\r\navailabe_zone_A -&gt; 2\r\navailabe_zone_B -&gt; 1\r\n```\r\n\r\n\r\nI got some problem when trying to iterate the json variable. \r\n```\r\ndeclare -A az_to_number_of_open_hosts\r\nfor host in $(jq . &lt;&lt;&lt;  $hosts_list)\r\ndo\r\n  az=$(rev &lt;&lt;&lt; $(echo $host | jq .host) | cut -d. -f3 | rev)\r\n  ((az_to_number_of_open_hosts[$az]++))\r\ndone\r\n```\r\nThe line to extract available zone is because the host format is always `blabla123213.az.domain.com`.\r\nThe code does not work since it seems the variable ```host``` refers to each line of json string rather than a json entry. Is there a recommended way to iterate each json entry?",
        "link": "https://stackoverflow.com/questions/57696097/loop-through-json-variable",
        "title": "Loop through json variable"
    },
    {
        "tags": [
            "arrays",
            "json",
            "sorting",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1567020062,
                "last_edit_date": 1567020062,
                "creation_date": 1567019761,
                "answer_id": 57698786,
                "question_id": 57698550,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Those are separate entities, you need to slurp them first to make sorting possible, then you can undo the slurping to get the same look as the original input. Like:\r\n```\r\njq -cs &#39;sort_by(.time)[]&#39; log.log\r\n```",
                "title": "How to concatenate elements into an array?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1567020062,
        "creation_date": 1567018599,
        "question_id": 57698550,
        "body_markdown": "I have a file containing structured log lines like so:\r\n\r\n    {&quot;generation_id&quot;:13,&quot;level&quot;:&quot;info&quot;,&quot;member_id&quot;:&quot;sarama-78cdf4cb-ce00-4a67-8b3a-b2bc46c6abb1&quot;,&quot;msg&quot;:&quot;starting consumer&quot;,&quot;time&quot;:&quot;2019-08-28T18:24:46.303Z&quot;}\r\n    {&quot;generation_id&quot;:13,&quot;initial_offset&quot;:178921,&quot;level&quot;:&quot;info&quot;,&quot;member_id&quot;:&quot;sarama-78cdf4cb-ce00-4a67-8b3a-b2bc46c6abb1&quot;,&quot;msg&quot;:&quot;starting to consume from partition&quot;,&quot;partition&quot;:18,&quot;time&quot;:&quot;2019-08-28T18:24:46.304Z&quot;}\r\n    {&quot;generation_id&quot;:13,&quot;initial_offset&quot;:-1,&quot;level&quot;:&quot;info&quot;,&quot;member_id&quot;:&quot;sarama-78cdf4cb-ce00-4a67-8b3a-b2bc46c6abb1&quot;,&quot;msg&quot;:&quot;starting to consume from partition&quot;,&quot;partition&quot;:19,&quot;time&quot;:&quot;2019-08-28T18:24:46.305Z&quot;}\r\n\r\nI&#39;d like to sort them by `.time`. How can I do it with `jq`?\r\n\r\nI&#39;ve tried:\r\n\r\n    jq &#39;. | sort_by(.time)&#39; &lt; log.log\r\n\r\nand\r\n\r\n    jq &#39;. |= sort_by(.time)&#39; &lt; log.log\r\n\r\nbut I keep getting:\r\n\r\n    jq: error (at &lt;stdin&gt;:15630): Cannot index string with string &quot;time&quot;\r\n    jq: error (at &lt;stdin&gt;:15631): Cannot index string with string &quot;time&quot;\r\n\r\nWhat am I missing?",
        "link": "https://stackoverflow.com/questions/57698550/how-to-concatenate-elements-into-an-array",
        "title": "How to concatenate elements into an array?"
    },
    {
        "tags": [
            "json",
            "dictionary",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1741187641,
                "last_edit_date": 1741187641,
                "creation_date": 1567024816,
                "answer_id": 57699760,
                "question_id": 57699438,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With the `key: value` data in input.txt, and the following program in tojson.jq:\r\n```\r\n[inputs | select(length&gt;0) \r\n | [splits(&quot;: *&quot;)]\r\n | {(.[0]): .[1]} ]\r\n| add\r\n```\r\n\r\nthe invocation:\r\n\r\n&lt;!-- language: shell --&gt;\r\n    jq -n -R -f tojson.jq input.txt\r\n\r\nproduces:\r\n```\r\n{\r\n  &quot;k1&quot;: &quot;v1&quot;,\r\n  &quot;k2&quot;: &quot;v2&quot;,\r\n  &quot;k3&quot;: &quot;v3&quot;\r\n}\r\n``` \r\n",
                "title": "Using jq to create JSON objects/dictionaries"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1681242115,
                "creation_date": 1681242115,
                "answer_id": 75989582,
                "question_id": 57699438,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "For those interested, here is a bash function which can create json dicts, by handling basic json types by adding a prefix to the bash values:\r\n\r\n* string (prefix: `s:`)\r\n* boolean (prefix: `b:`)\r\n* number (prefix: `n:`)\r\n\r\nHere&#39;s the code:\r\n\r\n```bash\r\n#!/bin/bash\r\n\r\njson_dict() {\r\n\tfor s in &quot;$@&quot;; do\r\n\t\techo -ne &quot;$s\\0&quot;\r\n\tdone \\\r\n\t| jq  -R &#39;splits(&quot;\\u0000&quot;)&#39; \\\r\n\t| jq -s -c &#39;\r\n        _nwise(2)\r\n        | {\r\n            (.[0]):\r\n            (\r\n                if .[1]|startswith(&quot;s:&quot;) then .[1][2:]\r\n                elif .[1]|startswith(&quot;n:&quot;) then .[1][2:]|tonumber\r\n                elif .[1] == &quot;b:true&quot; then true\r\n                elif .[1] == &quot;b:false&quot; then false\r\n                else .[1]\r\n                end\r\n            )\r\n        }\r\n    &#39; \\\r\n\t| jq -s add\r\n}\r\n\r\nkey_values=(\r\n    k1 s:foo\r\n    k2 b:true\r\n    k3 n:123\r\n)\r\n\r\njson_dict &quot;${key_values[@]}&quot;\r\n```\r\n\r\nOutput:\r\n\r\n```json\r\n{\r\n  &quot;k1&quot;: &quot;foo&quot;,\r\n  &quot;k2&quot;: true,\r\n  &quot;k3&quot;: 123\r\n}\r\n```",
                "title": "Using jq to create JSON objects/dictionaries"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1741187641,
        "creation_date": 1567023042,
        "last_edit_date": 1567064589,
        "question_id": 57699438,
        "body_markdown": "In my bash script I have a dictionary/map like:\r\n\r\n    k1: v1\r\n    k2: v2\r\n    k3: v3\r\n\r\nCan I possibly use `jq --slurp` or `jq --raw-input` to actually convert this to JSON like this:\r\n\r\n```\r\n{\r\n  &quot;k1&quot;: &quot;v1&quot;,\r\n  &quot;k2&quot;: &quot;v2&quot;,\r\n  &quot;k3&quot;: &quot;v3&quot;\r\n}\r\n```\r\n\r\npossibly by piping something like: `echo k1 v1 k2 v2 k3 v3 | jq [???]`",
        "link": "https://stackoverflow.com/questions/57699438/using-jq-to-create-json-objects-dictionaries",
        "title": "Using jq to create JSON objects/dictionaries"
    },
    {
        "tags": [
            "json",
            "export-to-csv",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1567028229,
                "creation_date": 1567028229,
                "answer_id": 57700363,
                "question_id": 57699779,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The ingredient you&#39;re missing is `fromjson`, which converts a stringified JSON to JSON.  Adding enclosing braces around your sample input,\r\nthe invocation:\r\n\r\n    jq -r -f program.jq input.json\r\n\r\nproduces:\r\n\r\n    &quot;Visa&quot;,&quot;1234&quot;,99.99,&quot;2019/08/27 08:41:09&quot;\r\n\r\nwhere program.jq is:\r\n\r\n```\r\n.TransactionDetails[0].Value\r\n| fromjson\r\n| [.cardType, .maskedPan] + (.paymentDetails | [.amount, .dateTime])\r\n| @csv\r\n```\r\n\r\n",
                "title": "Pulling data out of JSON Object via jq to CSV in Bash"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1567050827,
        "creation_date": 1567024931,
        "last_edit_date": 1567050827,
        "question_id": 57699779,
        "body_markdown": "I&#39;m working on a bash script (running via gitBash on Windows technically but I don&#39;t think that matters) that will convert some JSON API data into CSV files.  Most of it has gone fairly well, especially since I&#39;m not particularly familiar with JQ as this is my first time using it.  \r\n\r\nI&#39;ve got some JSON data that looks like the array below.  What I&#39;m trying to do is select the cardType,MaskedPan,amount and datetime out of the data.\r\n\r\nthis is probably the first time in life that my google searching has failed me.  I know(or should I say think) that that is actually an object and not just a simple array.  \r\n\r\nI&#39;ve not really found anything that helps me know how to grab that data I need and export it into a CSV file.  I&#39;ve had no issue grabbing the other data that I need but these few pieces are proving to be a big problem for me.\r\n\r\nThe script I&#39;m trying basically can be boiled down to this:\r\n```\r\njq=&#39;/c/jq-win64.exe -r&#39;;\r\n\r\nheader=&#39;(&quot;cardType&quot;)&#39;;\r\n\r\nfields=&#39;[.TransactionDetails[0].Value[0].cardType]&#39;;\r\n\r\n$jq &#39;&#39;$header&#39;,(.[] | &#39;$fields&#39; | @csv)&#39; &lt; /t/API_Data/JSON/GetByDate-082719.json &gt; \r\n/t/API_Data/CSV/test.csv;\r\n```\r\nIf I do .TransactionDetails[0].Value I can get that whole chunk of data.  But that is problematic in a CSV as it contains commas.  \r\n\r\nI suppose I could make this a TSV and import it into the database as one big string and sub string it out.  But that isn&#39;t the &quot;right&quot; solution.  I&#39;m sure there is a way JQ can give me what I need.  \r\n\r\n\t\t&quot;TransactionDetails&quot;: [\r\n\t\t\t{\r\n\t\t\t\t&quot;TransactionId&quot;: 123456789,\r\n\t\t\t\t&quot;Name&quot;: &quot;BlacklinePaymentDetail&quot;,\r\n\t\t\t\t&quot;Value&quot;: &quot;{\\&quot;cardType\\&quot;:\\&quot;Visa\\&quot;,\\&quot;maskedPan\\&quot;:\\&quot;1234\\&quot;,\\&quot;paymentDetails\\&quot;:{\\&quot;reference\\&quot;:\\&quot;123456789012\\&quot;,\\&quot;amount\\&quot;:99.99,\\&quot;dateTime\\&quot;:\\&quot;2019/08/27 08:41:09\\&quot;}}&quot;,\r\n\t\t\t\t&quot;ShowOnTill&quot;: false,\r\n\t\t\t\t&quot;PrintOnOrder&quot;: false,\r\n\t\t\t\t&quot;PrintOnReceipt&quot;: false\r\n\t\t\t}\r\n\t\t]\r\n\r\nIdeally I&#39;d be able to just have a field in the CSV for cardType,MaskedPan,amount and datetime instead of pulling the &quot;Value&quot; that contains all of it.\r\n\r\nAny advice would be appreciated.",
        "link": "https://stackoverflow.com/questions/57699779/pulling-data-out-of-json-object-via-jq-to-csv-in-bash",
        "title": "Pulling data out of JSON Object via jq to CSV in Bash"
    },
    {
        "tags": [
            "json",
            "edit",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1567083255,
                "last_edit_date": 1567083255,
                "creation_date": 1567082930,
                "answer_id": 57710602,
                "question_id": 57709400,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The problem as stated does not require any recursion.  Using your attempt as a model, one could in fact simply write:\r\n\r\n    .hits[]\r\n    | {index: ._index} \r\n    + (if has(&quot;accordions&quot;) then {accordions} else {} end)\r\n\r\nOr, with quite different semantics:\r\n\r\n    .hits[] | {index: ._index} + . | del(._index)",
                "title": "Recurse for object if exists in JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1567162152,
        "creation_date": 1567078811,
        "last_edit_date": 1567162152,
        "question_id": 57709400,
        "body_markdown": "I have the following structure:\r\n\r\n    {\r\n        &quot;hits&quot;: \r\n        [\r\n            {\r\n                &quot;_index&quot;: &quot;main&quot;\r\n            },\r\n            {\r\n                &quot;_index&quot;: &quot;main&quot;,\r\n                &quot;accordions&quot;: [\r\n                    {\r\n                      &quot;id&quot;: &quot;1&quot;,\r\n                      &quot;accordionBody&quot;: &quot;body1&quot;,\r\n                      &quot;accordionInnerButtonTexts&quot;: [\r\n                        &quot;button11&quot;,\r\n                        &quot;button12&quot;\r\n                      ]\r\n                    },\r\n                    {\r\n                      &quot;id&quot;: &quot;2&quot;,\r\n                      &quot;accordionBody&quot;: &quot;body2&quot;,\r\n                      &quot;accordionInnerButtonTexts&quot;: [\r\n                        &quot;button21&quot;,\r\n                        &quot;button22&quot;\r\n                        ]\r\n                    }\r\n                  ]\r\n            }\r\n        ]\r\n    }\r\n\r\nI want to get to this structure:\r\n\r\n    {\r\n        &quot;index&quot;: &quot;main&quot;\r\n    }\r\n    {\r\n        &quot;index&quot;: &quot;main&quot;,\r\n        &quot;accordions&quot;: \r\n        [\r\n            {\r\n                &quot;id&quot;: &quot;1&quot;,\r\n                &quot;accordionBody&quot;: &quot;body1&quot;,\r\n                &quot;accordionInnerButtonTexts&quot;: [\r\n                    &quot;button11&quot;,\r\n                    &quot;button12&quot;\r\n                 ]\r\n             },\r\n             {\r\n                 &quot;id&quot;: &quot;2&quot;,\r\n                 &quot;accordionBody&quot;: &quot;body2&quot;,\r\n                 &quot;accordionInnerButtonTexts&quot;: [\r\n                     &quot;button21&quot;,\r\n                     &quot;button22&quot;\r\n                 ]\r\n             }\r\n         ]\r\n    }\r\n\r\nWhich means that I always want to include the `_index`-field as `index`, and I want to include the whole `accordions`-list IF IT EXISTS in the object. Here is my attempt:\r\n\r\n    .hits[] | {index: ._index, accordions: recurse(.accordions[]?)}\r\n\r\nIt does not produce what I want:\r\n\r\n    {\r\n      &quot;index&quot;: &quot;main&quot;,\r\n      &quot;accordions&quot;: {\r\n        &quot;_index&quot;: &quot;main&quot;\r\n      }\r\n    }\r\n    {\r\n      &quot;index&quot;: &quot;main&quot;,\r\n      &quot;accordions&quot;: {\r\n        &quot;_index&quot;: &quot;main&quot;,\r\n        &quot;accordions&quot;: [\r\n          {\r\n            &quot;id&quot;: &quot;1&quot;,\r\n            &quot;accordionBody&quot;: &quot;body1&quot;,\r\n            &quot;accordionInnerButtonTexts&quot;: [\r\n              &quot;button11&quot;,\r\n              &quot;button12&quot;\r\n            ]\r\n          },\r\n          {\r\n            &quot;id&quot;: &quot;2&quot;,\r\n            &quot;accordionBody&quot;: &quot;body2&quot;,\r\n            &quot;accordionInnerButtonTexts&quot;: [\r\n              &quot;button21&quot;,\r\n              &quot;button22&quot;\r\n            ]\r\n          }\r\n        ]\r\n      }\r\n    }\r\n    {\r\n      &quot;index&quot;: &quot;main&quot;,\r\n      &quot;accordions&quot;: {\r\n        &quot;id&quot;: &quot;1&quot;,\r\n        &quot;accordionBody&quot;: &quot;body1&quot;,\r\n        &quot;accordionInnerButtonTexts&quot;: [\r\n          &quot;button11&quot;,\r\n          &quot;button12&quot;\r\n        ]\r\n      }\r\n    }\r\n    {\r\n      &quot;index&quot;: &quot;main&quot;,\r\n      &quot;accordions&quot;: {\r\n        &quot;id&quot;: &quot;2&quot;,\r\n        &quot;accordionBody&quot;: &quot;body2&quot;,\r\n        &quot;accordionInnerButtonTexts&quot;: [\r\n          &quot;button21&quot;,\r\n          &quot;button22&quot;\r\n        ]\r\n      }\r\n    }\r\n\r\nIt seems to create a list of all different permutations given by mixing the objects. This is not what I want. What is the correct jq command, and what is my mistake?",
        "link": "https://stackoverflow.com/questions/57709400/recurse-for-object-if-exists-in-jq",
        "title": "Recurse for object if exists in JQ"
    },
    {
        "tags": [
            "shell",
            "curl",
            "jq",
            "github-api"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1852014,
                    "reputation": 24882,
                    "user_id": 1678362,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/8ba023d18099cde022b9e4394d5714c0?s=256&d=identicon&r=PG",
                    "display_name": "Aaron",
                    "link": "https://stackoverflow.com/users/1678362/aaron"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1567089671,
                "post_id": 57712370,
                "comment_id": 101867445,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1088305,
                    "reputation": 811,
                    "user_id": 1083512,
                    "user_type": "registered",
                    "accept_rate": 23,
                    "profile_image": "https://www.gravatar.com/avatar/91197dbbc92b53bbdd84b70f9859645f?s=256&d=identicon&r=PG",
                    "display_name": "gmtek",
                    "link": "https://stackoverflow.com/users/1083512/gmtek"
                },
                "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": 1567091247,
                "post_id": 57712370,
                "comment_id": 101868349,
                "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": 1,
                "creation_date": 1567091348,
                "post_id": 57712370,
                "comment_id": 101868396,
                "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": 1567091457,
                "post_id": 57712370,
                "comment_id": 101868457,
                "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": 1567091990,
                "post_id": 57712370,
                "comment_id": 101868736,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1088305,
                    "reputation": 811,
                    "user_id": 1083512,
                    "user_type": "registered",
                    "accept_rate": 23,
                    "profile_image": "https://www.gravatar.com/avatar/91197dbbc92b53bbdd84b70f9859645f?s=256&d=identicon&r=PG",
                    "display_name": "gmtek",
                    "link": "https://stackoverflow.com/users/1083512/gmtek"
                },
                "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": 1567092799,
                "post_id": 57712370,
                "comment_id": 101869155,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1567091803,
                "last_edit_date": 1567091803,
                "creation_date": 1567091498,
                "answer_id": 57713131,
                "question_id": 57712370,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Replace:\r\n\r\n```\r\ncurl ... -d &#39;{&quot;name&quot;:&quot;$1&quot;, &quot;private&quot;:true}&#39;\r\n```\r\n\r\n...with:\r\n\r\n```\r\ncurl ... -d &quot;$(jq -n --arg name &quot;$1&quot; &#39;{&quot;name&quot;: $name, &quot;private&quot;: true}&#39;)&quot;\r\n```\r\n\r\nThat is to say: Nothing was wrong with how you were using `jq` to *parse* JSON; the problem is that you were trying to *create* JSON *without* using `jq`.\r\n\r\n---\r\n\r\nThe simple-but-wrong way to try to fix this, by the way, would have been to change your quoting type:\r\n\r\n```\r\n#### DO NOT DO THIS\r\ncurl ... -d &#39;{&quot;name&quot;: &quot;&#39;&quot;$1&quot;&#39;&quot;, &quot;private&quot;: true}&#39;\r\n```\r\n\r\n...or...\r\n\r\n```\r\n### DO NOT DO THIS EITHER\r\ncurl ... -d &quot;{\\&quot;name\\&quot;:\\&quot;$1\\&quot;, \\&quot;private\\&quot;:true}&quot;\r\n```\r\n\r\nIn the first example, we have everything *except* the `$1` surrounded in single quotes; but then end those single-quotes before your expansion, switch to a double-quoted context, expand `$1` there, and switch back.\r\n\r\nIn the second example, we just put the whole thing in double quotes, escaping the ones intended to be literal rather than syntactic.\r\n\r\nEither approach, however, is *wrong*; try looking at what it does when your name is `Foo &quot;The Leet&quot; Bar` -- the literal quotes get conflated with JSON quotes, making the generated JSON invalid, unless you use a tool (like `jq`) that knows how to escape them.",
                "title": "Json parsing in shell script"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1567092137,
        "creation_date": 1567088894,
        "last_edit_date": 1567092137,
        "question_id": 57712370,
        "body_markdown": "I am trying to automate github repo creation. Below is my code:\r\n\r\n```\r\npushtogithub() {\r\n        git init\r\n        git config user.name &quot;user name&quot;\r\n        git config user.email &quot;user email&quot;\r\n        git add .\r\n        git commit -m &quot;Initial commit&quot;\r\n        content=$(curl -s -u githubusername:githubaccesstoken https://api.github.com/user/repos -d &#39;{&quot;name&quot;:&quot;$1&quot;, &quot;private&quot;:true}&#39;)\r\n        repo=$(jq -r &#39;.ssh_url&#39; &lt;&lt;&lt; &quot;${content}&quot; )\r\n        echo $repo created\r\n        git remote add origin git@github.com:githubusername/$repo.git\r\n        git push -u origin master\r\n}\r\n```\r\n\r\nMy github repo is always creating with `-1` name.\r\n\r\nWhat I am doing wrong here?",
        "link": "https://stackoverflow.com/questions/57712370/json-parsing-in-shell-script",
        "title": "Json parsing in shell script"
    },
    {
        "tags": [
            "twitter",
            "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": 1567166024,
                "post_id": 57726159,
                "comment_id": 101892578,
                "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": 3,
                "creation_date": 1567166239,
                "post_id": 57726159,
                "comment_id": 101892680,
                "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": 1,
                "creation_date": 1567167243,
                "post_id": 57726159,
                "comment_id": 101893135,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1567679585,
                "creation_date": 1567679585,
                "answer_id": 57803516,
                "question_id": 57726159,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you need nested &#39;text&#39; value from &#39;status&#39; field you should use:\r\n\r\n    .[] | { name: .name, text: .status.text }\r\n\r\nOr shorter version:\r\n\r\n    .[] | { name, text: .status.text }",
                "title": "Parsing Twitter Information with jq (&quot;text&quot;: null)"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1567679585,
        "creation_date": 1567165566,
        "question_id": 57726159,
        "body_markdown": "I am trying to do some Twitter-analysis via Twurl and extract some information via jq.\r\n\r\nI firstly get some tweets via twurl with the command \r\n\r\n```\r\ntwurl /1.1/users/search.json?q=judo\r\n``` \r\n\r\nThen i used the following line to structure the outpot with jq:\r\n\r\n``` \r\ntwurl /1.1/users/search.json?q=judo | jq\r\n``` \r\n\r\n\r\ni get something like this:\r\n``` \r\n[\r\n  {\r\n    &quot;id&quot;: 173752759,\r\n    &quot;id_str&quot;: &quot;173752759&quot;,\r\n    &quot;name&quot;: &quot;#JudoWorlds &#129355;&quot;,\r\n    &quot;screen_name&quot;: &quot;Judo&quot;,\r\n    &quot;location&quot;: &quot;Worldwide&quot;,\r\n    &quot;description&quot;: &quot;The Official Twitter Account of the International Judo Federation &#129355;&quot;,\r\n    &quot;url&quot;: &quot;https:.....&quot;,\r\n    &quot;entities&quot;: {\r\n      &quot;url&quot;: {\r\n        &quot;urls&quot;: [\r\n          {\r\n            &quot;url&quot;: &quot;https://......&quot;,\r\n            &quot;expanded_url&quot;: &quot;https://www.ijf.org/news/show/5-must-see-preliminary-round-clashes-2&quot;,\r\n            &quot;display_url&quot;: &quot;ijf.org/news/show/5-mu…&quot;,\r\n            &quot;indices&quot;: [\r\n              0,\r\n              23\r\n            ]\r\n          }\r\n        ]\r\n      },\r\n      &quot;description&quot;: {\r\n        &quot;urls&quot;: []\r\n      }\r\n    },\r\n    &quot;protected&quot;: false,\r\n    &quot;followers_count&quot;: 59854,\r\n    &quot;friends_count&quot;: 847,\r\n    &quot;listed_count&quot;: 529,\r\n    &quot;created_at&quot;: &quot;Mon Aug 02 07:55:15 +0000 2010&quot;,\r\n    &quot;favourites_count&quot;: 7074,\r\n    &quot;utc_offset&quot;: null,\r\n    &quot;time_zone&quot;: null,\r\n    &quot;geo_enabled&quot;: true,\r\n    &quot;verified&quot;: true,\r\n    &quot;statuses_count&quot;: 16532,\r\n    &quot;lang&quot;: null,\r\n    &quot;status&quot;: {\r\n      &quot;created_at&quot;: &quot;Fri Aug 30 08:27:10 +0000 2019&quot;,\r\n      &quot;id&quot;: 1167353053282013200,\r\n      &quot;id_str&quot;: &quot;1167353053282013184&quot;,\r\n      &quot;text&quot;: &quot;#JudoWorlds The Alternative Promo \\n\\n@NeilAdamsJudo https://.....&quot;,\r\n      &quot;truncated&quot;: false,\r\n      &quot;entities&quot;: {\r\n        &quot;hashtags&quot;: [\r\n          {\r\n            &quot;text&quot;: &quot;JudoWorlds&quot;,\r\n            &quot;indices&quot;: [\r\n              0,\r\n              11\r\n            ]\r\n          }\r\n        ],\r\n        &quot;symbols&quot;: [],\r\n        &quot;user_mentions&quot;: [\r\n          {\r\n            &quot;screen_name&quot;: &quot;NeilAdamsJudo&quot;,\r\n            &quot;name&quot;: &quot;Neil Adams MBE&quot;,\r\n            &quot;id&quot;: 40488733,\r\n            &quot;id_str&quot;: &quot;40488733&quot;,\r\n            &quot;indices&quot;: [\r\n              36,\r\n              50\r\n            ]\r\n          }\r\n        ],\r\n        &quot;urls&quot;: [],\r\n        &quot;media&quot;: [\r\n          {\r\n            &quot;id&quot;: 1167352899267002400,\r\n            &quot;id_str&quot;: &quot;1167352899267002369&quot;,\r\n            &quot;indices&quot;: [\r\n              51,\r\n              74\r\n            ],\r\n            &quot;media_url&quot;: &quot;http://pbs.twimg.com/ext_tw_video_thumb/1167352899267002369/pu/img/6yD1r7uaPV7p3y6a.jpg&quot;,\r\n            &quot;media_url_https&quot;: &quot;https://pbs.twimg.com/ext_tw_video_thumb/1167352899267002369/pu/img/6yD1r7uaPV7p3y6a.jpg&quot;,\r\n            &quot;url&quot;: &quot;https://......&quot;,\r\n            &quot;display_url&quot;: &quot;pic.twitter.com/0RlLbKLkN8&quot;,\r\n            &quot;expanded_url&quot;: &quot;https://twitter.com/Judo/status/1167353053282013184/video/1&quot;,\r\n            &quot;type&quot;: &quot;photo&quot;,\r\n            &quot;sizes&quot;: {\r\n              &quot;thumb&quot;: {\r\n                &quot;w&quot;: 150,\r\n                &quot;h&quot;: 150,\r\n                &quot;resize&quot;: &quot;crop&quot;\r\n              },\r\n              &quot;medium&quot;: {\r\n                &quot;w&quot;: 1200,\r\n                &quot;h&quot;: 675,\r\n                &quot;resize&quot;: &quot;fit&quot;\r\n              },\r\n              &quot;small&quot;: {\r\n                &quot;w&quot;: 680,\r\n                &quot;h&quot;: 383,\r\n                &quot;resize&quot;: &quot;fit&quot;\r\n              },\r\n              &quot;large&quot;: {\r\n                &quot;w&quot;: 1280,\r\n                &quot;h&quot;: 720,\r\n                &quot;resize&quot;: &quot;fit&quot;\r\n              }\r\n            }\r\n          }\r\n        ]\r\n      },\r\n      &quot;extended_entities&quot;: {\r\n        &quot;media&quot;: [\r\n          {\r\n            &quot;id&quot;: 1167352899267002400,\r\n            &quot;id_str&quot;: &quot;1167352899267002369&quot;,\r\n            &quot;indices&quot;: [\r\n              51,\r\n              74\r\n            ],\r\n            &quot;media_url&quot;: &quot;http://pbs.twimg.com/ext_tw_video_thumb/1167352899267002369/pu/img/6yD1r7uaPV7p3y6a.jpg&quot;,\r\n            &quot;media_url_https&quot;: &quot;https://pbs.twimg.com/ext_tw_video_thumb/1167352899267002369/pu/img/6yD1r7uaPV7p3y6a.jpg&quot;,\r\n            &quot;url&quot;: &quot;https://.....&quot;,\r\n            &quot;display_url&quot;: &quot;pic.twitter.com/0RlLbKLkN8&quot;,\r\n            &quot;expanded_url&quot;: &quot;https://twitter.com/Judo/status/1167353053282013184/video/1&quot;,\r\n            &quot;type&quot;: &quot;video&quot;,\r\n            &quot;sizes&quot;: {\r\n              &quot;thumb&quot;: {\r\n                &quot;w&quot;: 150,\r\n                &quot;h&quot;: 150,\r\n                &quot;resize&quot;: &quot;crop&quot;\r\n              },\r\n              &quot;medium&quot;: {\r\n                &quot;w&quot;: 1200,\r\n                &quot;h&quot;: 675,\r\n                &quot;resize&quot;: &quot;fit&quot;\r\n              },\r\n              &quot;small&quot;: {\r\n                &quot;w&quot;: 680,\r\n                &quot;h&quot;: 383,\r\n                &quot;resize&quot;: &quot;fit&quot;\r\n              },\r\n              &quot;large&quot;: {\r\n                &quot;w&quot;: 1280,\r\n                &quot;h&quot;: 720,\r\n                &quot;resize&quot;: &quot;fit&quot;\r\n              }\r\n            },\r\n            &quot;video_info&quot;: {\r\n              &quot;aspect_ratio&quot;: [\r\n                16,\r\n                9\r\n              ],\r\n              &quot;duration_millis&quot;: 48800,\r\n              &quot;variants&quot;: [\r\n                {\r\n                  &quot;bitrate&quot;: 256000,\r\n                  &quot;content_type&quot;: &quot;video/mp4&quot;,\r\n                  &quot;url&quot;: &quot;https://video.twimg.com/ext_tw_video/1167352899267002369/pu/vid/480x270/v4nkTg6qs9rpLq8M.mp4?tag=10&quot;\r\n                },\r\n                {\r\n                  &quot;content_type&quot;: &quot;application/x-mpegURL&quot;,\r\n                  &quot;url&quot;: &quot;https://video.twimg.com/ext_tw_video/1167352899267002369/pu/pl/SQN57QxQFYcKWV7l.m3u8?tag=10&quot;\r\n                },\r\n                {\r\n                  &quot;bitrate&quot;: 2176000,\r\n                  &quot;content_type&quot;: &quot;video/mp4&quot;,\r\n                  &quot;url&quot;: &quot;https://video.twimg.com/ext_tw_video/1167352899267002369/pu/vid/1280x720/8cyNocB_8CRjwVCI.mp4?tag=10&quot;\r\n                },\r\n                {\r\n                  &quot;bitrate&quot;: 832000,\r\n                  &quot;content_type&quot;: &quot;video/mp4&quot;,\r\n                  &quot;url&quot;: &quot;https://video.twimg.com/ext_tw_video/1167352899267002369/pu/vid/640x360/uy2U7D_AEmbLdqEK.mp4?tag=10&quot;\r\n                }\r\n              ]\r\n            },\r\n            &quot;additional_media_info&quot;: {\r\n              &quot;monetizable&quot;: false\r\n            }\r\n          }\r\n        ]\r\n      },\r\n      &quot;source&quot;: &quot;&lt;a href=\\&quot;http://twitter.com/download/android\\&quot; rel=\\&quot;nofollow\\&quot;&gt;Twitter for Android&lt;/a&gt;&quot;,\r\n      &quot;in_reply_to_status_id&quot;: null,\r\n      &quot;in_reply_to_status_id_str&quot;: null,\r\n      &quot;in_reply_to_user_id&quot;: null,\r\n      &quot;in_reply_to_user_id_str&quot;: null,\r\n      &quot;in_reply_to_screen_name&quot;: null,\r\n      &quot;geo&quot;: null,\r\n      &quot;coordinates&quot;: null,\r\n      &quot;place&quot;: null,\r\n      &quot;contributors&quot;: null,\r\n      &quot;is_quote_status&quot;: false,\r\n      &quot;retweet_count&quot;: 4,\r\n      &quot;favorite_count&quot;: 17,\r\n      &quot;favorited&quot;: false,\r\n      &quot;retweeted&quot;: false,\r\n      &quot;possibly_sensitive&quot;: false,\r\n      &quot;lang&quot;: &quot;en&quot;\r\n    },\r\n    &quot;contributors_enabled&quot;: false,\r\n    &quot;is_translator&quot;: false,\r\n    &quot;is_translation_enabled&quot;: false,\r\n    &quot;profile_background_color&quot;: &quot;0099CC&quot;,\r\n    &quot;profile_background_image_url&quot;: &quot;http://abs.twimg.com/images/themes/theme1/bg.png&quot;,\r\n    &quot;profile_background_image_url_https&quot;: &quot;https://abs.twimg.com/images/themes/theme1/bg.png&quot;,\r\n    &quot;profile_background_tile&quot;: false,\r\n    &quot;profile_image_url&quot;: &quot;http://pbs.twimg.com/profile_images/1057928008797970433/O3l2sKj0_normal.jpg&quot;,\r\n    &quot;profile_image_url_https&quot;: &quot;https://pbs.twimg.com/profile_images/1057928008797970433/O3l2sKj0_normal.jpg&quot;,\r\n    &quot;profile_banner_url&quot;: &quot;https://pbs.twimg.com/profile_banners/173752759/1565853008&quot;,\r\n    &quot;profile_link_color&quot;: &quot;0C3C42&quot;,\r\n    &quot;profile_sidebar_border_color&quot;: &quot;8F320A&quot;,\r\n    &quot;profile_sidebar_fill_color&quot;: &quot;F2CF41&quot;,\r\n    &quot;profile_text_color&quot;: &quot;000000&quot;,\r\n    &quot;profile_use_background_image&quot;: true,\r\n    &quot;has_extended_profile&quot;: false,\r\n    &quot;default_profile&quot;: false,\r\n    &quot;default_profile_image&quot;: false,\r\n    &quot;following&quot;: false,\r\n    &quot;follow_request_sent&quot;: false,\r\n    &quot;notifications&quot;: false,\r\n    &quot;translator_type&quot;: &quot;none&quot;\r\n  },\r\n``` \r\n\r\n\r\nBecause i am only interested in certain informations i tried to get the name and the text of the tweet with the following command:\r\n\r\n```\r\ntwurl /1.1/users/search.json?q=judo | jq &quot;.[] | { name: .name, text: .text }&quot;\r\n``` \r\nand i get this:\r\n\r\n```\r\n{\r\n  &quot;name&quot;: &quot;#JudoWorlds &#129355;&quot;,\r\n  &quot;text&quot;: null\r\n}\r\n{\r\n  &quot;name&quot;: &quot;#WeAreGBJudo&quot;,\r\n  &quot;text&quot;: null\r\n}\r\n{\r\n  &quot;name&quot;: &quot;CBJ&quot;,\r\n  &quot;text&quot;: null\r\n}\r\n{\r\n  &quot;name&quot;: &quot;Santos Futebol Clube&quot;,\r\n  &quot;text&quot;: null\r\n}\r\n{\r\n  &quot;name&quot;: &quot;Marius Vizer&quot;,\r\n  &quot;text&quot;: null\r\n}\r\n{\r\n  &quot;name&quot;: &quot;FF Judo&quot;,\r\n  &quot;text&quot;: null\r\n}\r\n{\r\n  &quot;name&quot;: &quot;Santos FC &#127482; &#127480; &#127468; &#127463; &quot;,\r\n  &quot;text&quot;: null\r\n}\r\n{\r\n  &quot;name&quot;: &quot;USA Judo&quot;,\r\n  &quot;text&quot;: null\r\n}\r\n{\r\n  &quot;name&quot;: &quot;全日本柔道連盟 -ゴジラジャパン-&quot;,\r\n  &quot;text&quot;: null\r\n}\r\n{\r\n  &quot;name&quot;: &quot;Vila Belmiro&quot;,\r\n  &quot;text&quot;: null\r\n}\r\n{\r\n  &quot;name&quot;: &quot;Deutscher Judo-Bund&quot;,\r\n  &quot;text&quot;: null\r\n}\r\n{\r\n  &quot;name&quot;: &quot;Bruno Secco&quot;,\r\n  &quot;text&quot;: null\r\n}\r\n{\r\n  &quot;name&quot;: &quot;Bobby Judo&quot;,\r\n  &quot;text&quot;: null\r\n}\r\n{\r\n  &quot;name&quot;: &quot;African Judo Union&quot;,\r\n  &quot;text&quot;: null\r\n}\r\n{\r\n  &quot;name&quot;: &quot;JudoInside.com&quot;,\r\n  &quot;text&quot;: null\r\n}\r\n{\r\n  &quot;name&quot;: &quot;For competitive judo&quot;,\r\n  &quot;text&quot;: null\r\n}\r\n{\r\n  &quot;name&quot;: &quot;Judo Canada&quot;,\r\n  &quot;text&quot;: null\r\n}\r\n{\r\n  &quot;name&quot;: &quot;Neil Adams MBE&quot;,\r\n  &quot;text&quot;: null\r\n}\r\n{\r\n  &quot;name&quot;: &quot;Sophie Cox&quot;,\r\n  &quot;text&quot;: null\r\n}\r\n{\r\n  &quot;name&quot;: &quot;Galatasaray Judo&quot;,\r\n  &quot;text&quot;: null\r\n}\r\n```\r\n\r\nWhy is this and how can i fix it?\r\n\r\n\r\n\r\n\r\nI tried other commands like :\r\n```\r\ntwurl /1.1/search/tweets.json?q=afd | jq &quot;.[] | { name: .name, text: .text }&quot;\r\n```\r\nbut got the error \r\n```\r\njq: error (at &lt;stdin&gt;:0): Cannot index array with string &quot;name&quot;\r\n```",
        "link": "https://stackoverflow.com/questions/57726159/parsing-twitter-information-with-jq-text-null",
        "title": "Parsing Twitter Information with jq (&quot;text&quot;: null)"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1567392681,
                "last_edit_date": 1567392681,
                "creation_date": 1567370984,
                "answer_id": 57749415,
                "question_id": 57748823,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The following produces the CSV shown below. It would be easy to tweak the program to remove the double-quotation marks, etc.\r\n\r\n```\r\n.Person[]\r\n| .Roles.Role\r\n| if type == &quot;array&quot; then .[] else . end\r\n| [.[&quot;@Id&quot;], .Name]\r\n| @csv\r\n```\r\n## Output\r\n```\r\n&quot;1&quot;,&quot;Job1&quot;\r\n&quot;2&quot;,&quot;Job2&quot;\r\n&quot;3&quot;,&quot;Job3&quot;\r\n```\r\n\r\n\r\n## Adding the index in .Person\r\n```\r\n.Person\r\n| range(0; length) as $ix\r\n| .[$ix]\r\n| .Roles.Role\r\n| if type == &quot;array&quot; then .[] else . end\r\n| [$ix, .[&quot;@Id&quot;], .Name]\r\n| @csv\r\n```\r\n",
                "title": "Filter object or array"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1567412989,
        "creation_date": 1567365718,
        "last_edit_date": 1567370452,
        "question_id": 57748823,
        "body_markdown": "I would like to list all the Ids and roles in a given json but where there  is only a single role, rather than an array of 1 it provides it as an object, so if I run &quot;[]?&quot; I get the error Cannot index string with string &quot;Name&quot;. \r\n\r\nExtract (example.json):\r\n\r\n    {\r\n      &quot;Person&quot;: [\r\n        {\r\n          &quot;Roles&quot;: {\r\n            &quot;Role&quot;: {\r\n              &quot;@Id&quot;: &quot;1&quot;,\r\n              &quot;Name&quot;: &quot;Job1&quot;\r\n            }\r\n          }\r\n        },\r\n        {\r\n          &quot;Roles&quot;: {\r\n            &quot;Role&quot;: [\r\n              {\r\n                &quot;@Id&quot;: &quot;2&quot;,\r\n                &quot;Name&quot;: &quot;Job2&quot;\r\n              },\r\n              {\r\n                &quot;@Id&quot;: &quot;3&quot;,\r\n                &quot;Name&quot;: &quot;Job3&quot;\r\n              }\r\n            ]\r\n          }\r\n        }\r\n      ]\r\n    }\r\n\r\nI hoped this may work:\r\n```\r\njq -r . | &#39;.Roles.Role[]?&gt;.@Id + &quot;,&quot; + .Roles.Role[]?&gt;.Name&#39;\r\n```\r\nThis is the output I&#39;d like (so I can pipe to a csv)\r\n```\r\n1,Job1\r\n2,Job2\r\n3,Job3\r\n```",
        "link": "https://stackoverflow.com/questions/57748823/filter-object-or-array",
        "title": "Filter object or array"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1567457093,
                "last_edit_date": 1567457093,
                "creation_date": 1567456744,
                "answer_id": 57762484,
                "question_id": 57762380,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The right syntax for variable (or filter) interpolation with `jq` looks like this:\r\n\r\n    &quot;foo \\(filter_or_var) bar&quot;\r\n\r\nIn your case:\r\n\r\n    jq --raw-output --arg TOSEARCH &quot;$TXTIWANT&quot; &#39;.[]select(.name|test(&quot;\\($TOSEARCH).&quot;;&quot;i&quot;)) .name&#39;)\r\n\r\n---\r\n\r\nside-note: [By convention, environment variables (PAGER, EDITOR, ...) and internal shell variables (SHELL, BASH_VERSION, ...) are capitalized. All other variable names should be lower case.][1]\r\n\r\n\r\n  [1]: https://stackoverflow.com/a/673940/171318",
                "title": "How to pass arguments inside select and test function?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1567492006,
                "last_edit_date": 1567492006,
                "creation_date": 1567491070,
                "answer_id": 57765902,
                "question_id": 57762380,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If (as suggested by the name TXTIWANT and by the example, as well as by the wording of the question) the value of &quot;$TXTIWANT&quot; is supposed to be literal text, then using `test` is problematic, as `test` will search for a regular expression.  \r\n\r\nSince it is not clear from the question why you are adding a period to TOSEARCH, in the remainder of this first section, I will ignore whatever requirement you have in mind regarding that.\r\n\r\nSo if you simply want to find the `.name` values that contain $TXTIWANT literally (ignoring case), then you could convert both `.name` and the value of $TXTIWANT to the same case, and then check for containment.\r\n\r\nIn jq, ignoring the mysterious &quot;.&quot;, this could be done like so:\r\n\r\n```\r\n\r\n\r\njq --raw-output --arg TOSEARCH &quot;$TXTIWANT&quot; &#39;\r\n  ($TOSEARCH|ascii_upcase) as $up\r\n  | .[]\r\n  | .name\r\n  | select(ascii_upcase|index($up))&#39;\r\n\r\n```\r\n\r\n## Search for non-terminal occurrence of $TXTIWANT ignoring case\r\n\r\nIf the &quot;.&quot; signifies there must be an additional character after $TXTIWANT, then you could just add another `select` as follows:\r\n\r\n```\r\n  ($TOSEARCH|length) as $len\r\n  | ($TOSEARCH|ascii_upcase) as $up\r\n  | .[]\r\n  | .name\r\n  | (ascii_upcase|index($up)) as $ix\r\n  | select($ix)\r\n  | select($ix + $len &lt; length)\r\n```\r\n\r\n\r\n\r\n",
                "title": "How to pass arguments inside select and test function?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 3,
        "last_activity_date": 1567492006,
        "creation_date": 1567456045,
        "last_edit_date": 1567491332,
        "question_id": 57762380,
        "body_markdown": "I&#39;ve this JSON data, extracted from qbittorrent:\r\n\r\n    [\r\n      {\r\n        &quot;hash&quot;: &quot;333333333333333333333333333&quot;,\r\n        &quot;name&quot;: &quot;testtosearchcaseinsensitive&quot;,\r\n        &quot;magnet_uri&quot;: &quot;magnet:somedata&quot;,\r\n        &quot;size&quot;: 1243989552,\r\n        &quot;progress&quot;: 1.0,\r\n        &quot;dlspeed&quot;: 0,\r\n        &quot;upspeed&quot;: 0,\r\n        &quot;priority&quot;: 0,\r\n        &quot;num_seeds&quot;: 0,\r\n        &quot;num_complete&quot;: 2,\r\n        &quot;num_leechs&quot;: 0,\r\n        &quot;num_incomplete&quot;: 32,\r\n        &quot;ratio&quot;: 0.0,\r\n        &quot;eta&quot;: &quot;1.01:11:52&quot;,\r\n        &quot;state&quot;: &quot;stalledUP&quot;,\r\n        &quot;seq_dl&quot;: false,\r\n        &quot;f_l_piece_prio&quot;: false,\r\n        &quot;category&quot;: &quot;category&quot;,\r\n        &quot;tags&quot;: &quot;&quot;,\r\n        &quot;super_seeding&quot;: false,\r\n        &quot;force_start&quot;: false,\r\n        &quot;save_path&quot;: &quot;/data/path/&quot;,\r\n        &quot;added_on&quot;: 1567358333,\r\n        &quot;completion_on&quot;: 1567366287,\r\n        &quot;tracker&quot;: &quot;somedata&quot;,\r\n        &quot;dl_limit&quot;: null,\r\n        &quot;up_limit&quot;: null,\r\n        &quot;downloaded&quot;: 1244073666,\r\n        &quot;uploaded&quot;: 0,\r\n        &quot;downloaded_session&quot;: 0,\r\n        &quot;uploaded_session&quot;: 0,\r\n        &quot;amount_left&quot;: 0,\r\n        &quot;completed&quot;: 1243989552,\r\n        &quot;ratio_limit&quot;: 1.0,\r\n        &quot;seen_complete&quot;: 1567408837,\r\n        &quot;last_activity&quot;: 1567366979,\r\n        &quot;time_active&quot;: &quot;1.01:00:41&quot;,\r\n        &quot;auto_tmm&quot;: true,\r\n        &quot;total_size&quot;: 1243989552,\r\n        &quot;max_ratio&quot;: 1,\r\n        &quot;max_seeding_time&quot;: 2880,\r\n        &quot;seeding_time_limit&quot;: 2880\r\n      },\r\n      {\r\n        &quot;hash&quot;: &quot;44444444444444&quot;,\r\n        &quot;name&quot;: &quot;dontmatch&quot;,\r\n        &quot;magnet_uri&quot;: &quot;magnet:somedata&quot;,\r\n        &quot;size&quot;: 2996838603,\r\n        &quot;progress&quot;: 1.0,\r\n        &quot;dlspeed&quot;: 0,\r\n        &quot;upspeed&quot;: 0,\r\n        &quot;priority&quot;: 0,\r\n        &quot;num_seeds&quot;: 0,\r\n        &quot;num_complete&quot;: 12,\r\n        &quot;num_leechs&quot;: 0,\r\n        &quot;num_incomplete&quot;: 0,\r\n        &quot;ratio&quot;: 0.06452786606740063,\r\n        &quot;eta&quot;: &quot;100.00:00:00&quot;,\r\n        &quot;state&quot;: &quot;stalledUP&quot;,\r\n        &quot;seq_dl&quot;: false,\r\n        &quot;f_l_piece_prio&quot;: false,\r\n        &quot;category&quot;: &quot;category&quot;,\r\n        &quot;tags&quot;: &quot;&quot;,\r\n        &quot;super_seeding&quot;: false,\r\n        &quot;force_start&quot;: false,\r\n        &quot;save_path&quot;: &quot;/data/path/&quot;,\r\n        &quot;added_on&quot;: 1566420155,\r\n        &quot;completion_on&quot;: 1566424710,\r\n        &quot;tracker&quot;: &quot;some data&quot;,\r\n        &quot;dl_limit&quot;: null,\r\n        &quot;up_limit&quot;: null,\r\n        &quot;downloaded&quot;: 0,\r\n        &quot;uploaded&quot;: 193379600,\r\n        &quot;downloaded_session&quot;: 0,\r\n        &quot;uploaded_session&quot;: 0,\r\n        &quot;amount_left&quot;: 0,\r\n        &quot;completed&quot;: 2996838603,\r\n        &quot;ratio_limit&quot;: -2.0,\r\n        &quot;seen_complete&quot;: 4294967295,\r\n        &quot;last_activity&quot;: 1566811636,\r\n        &quot;time_active&quot;: &quot;10.23:07:42&quot;,\r\n        &quot;auto_tmm&quot;: true,\r\n        &quot;total_size&quot;: 2996838603,\r\n        &quot;max_ratio&quot;: -1,\r\n        &quot;max_seeding_time&quot;: -1,\r\n        &quot;seeding_time_limit&quot;: -2\r\n      }\r\n    ]\r\n\r\nSo I want to match all data where the name have some text, so, in Bash I write this but I can&#39;t make it work.\r\n\r\nSome declaration to start, actually I pass data via arguments, so I use `$1`:\r\n\r\n    TXTIWANT=&quot;test&quot;\r\n    MYJSONDATA= Here I put my JSON data\r\n\r\nThen this `jq` equation that doesn&#39;t work for me is this:\r\n\r\n    RESULTS=$(echo &quot;$MYJSONDATA&quot; | jq --raw-output --arg TOSEARCH &quot;$TXTIWANT&quot; &#39;.[] | select(.name|test(&quot;$TOSEARCH.&quot;;&quot;i&quot;)) .name&#39;)\r\n\r\nBut I always got an error or all data, I think because `$TOSEARCH` is not expanded.\r\n\r\nMaybe there&#39;s a better way to search a string inside a value?\r\n\r\nWhat I do wrong?",
        "link": "https://stackoverflow.com/questions/57762380/how-to-pass-arguments-inside-select-and-test-function",
        "title": "How to pass arguments inside select and test function?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1567464901,
                "creation_date": 1567464901,
                "answer_id": 57763328,
                "question_id": 57763285,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Just locate where in the tree you want to set the values and set them.\r\n\r\n    .headers = {}\r\n      | .shoporders[].ext_ad_info_mappings = []\r\n      | .payment_channel_info.grouping_info.groups[].display_info.enabled = true\r\n\r\nhttps://jqplay.org/s/ugF5foO90N",
                "title": "How to add multiple json object with the jq command?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1567464901,
        "creation_date": 1567464260,
        "question_id": 57763285,
        "body_markdown": "I want to edit this json file:\r\n```\r\n{\r\n\t&quot;shipping_orders&quot;: [{\r\n\t}],\r\n\t&quot;timestamp&quot;: 100,\r\n\t&quot;shoporders&quot;: [{\r\n\t\t&quot;buyer_remark&quot;: null\r\n\t}],\r\n\t&quot;payment_channel_info&quot;: {\r\n\t\t&quot;shipping_method&quot;: 28,\r\n\t\t&quot;grouping_info&quot;: {\r\n\t\t\t&quot;groups&quot;: [{\r\n\t\t\t\t&quot;display_info&quot;: {\r\n\t\t\t\t\t&quot;discount&quot;: 1\r\n\t\t\t\t}\r\n\t\t\t}]\r\n\t\t}\r\n\t}\r\n}\r\n```\r\nAnd I want to add these json objects to the file:\r\n\r\n 1. `&quot;headers&quot;: {}`\r\n 2. `&quot;ext_ad_info_mappings&quot;: []`\r\n 3. `&quot;enabled&quot;: true`\r\n\r\nThe output I want is like this:\r\n```\r\n{\r\n\t&quot;headers&quot;: {},\r\n\t&quot;shipping_orders&quot;: [{\r\n\t}],\r\n\t&quot;timestamp&quot;: 100,\r\n\t&quot;shoporders&quot;: [{\r\n\t\t&quot;buyer_remark&quot;: null,\r\n\t\t&quot;ext_ad_info_mappings&quot;: []\r\n\t}],\r\n\t&quot;payment_channel_info&quot;: {\r\n\t\t&quot;shipping_method&quot;: 28,\r\n\t\t&quot;grouping_info&quot;: {\r\n\t\t\t&quot;groups&quot;: [{\r\n\t\t\t\t&quot;display_info&quot;: {\r\n\t\t\t\t\t&quot;discount&quot;: 1,\r\n\t\t\t\t\t&quot;enabled&quot;: true\r\n\t\t\t\t}\r\n\t\t\t}]\r\n\t\t}\r\n\t}\r\n}\r\n```\r\nI tried this command but the result only shows `true` https://jqplay.org/s/0aVbFzMttK\r\n```\r\njq &#39;.+{&quot;headers&quot;: {}} and .shoporders[] + {&quot;ext_ad_info_mappings&quot;: []} and .payment_channel_info.grouping_info.groups[].display_info + {&quot;enabled&quot;: true}&#39;\r\n```\r\n\r\nHow should I edit the json file so that it&#39;ll output like the one I want above ?",
        "link": "https://stackoverflow.com/questions/57763285/how-to-add-multiple-json-object-with-the-jq-command",
        "title": "How to add multiple json object with the jq command?"
    },
    {
        "tags": [
            "json",
            "csv",
            "parsing",
            "unique",
            "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": 1567506349,
                "post_id": 57769610,
                "comment_id": 101974557,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 11494389,
                    "reputation": 101,
                    "user_id": 8424244,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/716438db9a7e192153d9dd05ad4f31a2?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Ah Lag",
                    "link": "https://stackoverflow.com/users/8424244/ah-lag"
                },
                "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": 1567506408,
                "post_id": 57769610,
                "comment_id": 101974590,
                "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": 1,
                "creation_date": 1567506561,
                "post_id": 57769610,
                "comment_id": 101974686,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 11494389,
                    "reputation": 101,
                    "user_id": 8424244,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/716438db9a7e192153d9dd05ad4f31a2?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Ah Lag",
                    "link": "https://stackoverflow.com/users/8424244/ah-lag"
                },
                "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": 1567518101,
                "post_id": 57769610,
                "comment_id": 101980996,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1567531515,
                "creation_date": 1567531515,
                "answer_id": 57776270,
                "question_id": 57769610,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "A reasonable approach would be to use `unique_by`, e.g.:\r\n\r\n```\r\nunique_by(.Id)[]\r\n| [.Id, .Name]\r\n| @tsv\r\n```\r\n\r\nAlternatively, you could form the pairs first:\r\n```\r\nmap([.Id, .Name])\r\n| unique_by(.[0])[]\r\n| @tsv\r\n```\r\n### `uniques_by/2`\r\nFor very large arrays, though, or if you want to respect the original ordering, a sort-free alternative to `unique_by` should be considered.  Here is a suitable, generic, stream-oriented alternative:\r\n  \r\n```\r\ndef uniques_by(stream; f):\r\n  foreach stream as $x ({};\r\n     ($x|f) as $s\r\n     | ($s|type) as $t\r\n     | (if $t == &quot;string&quot; then $s\r\n        else ($s|tostring) end) as $y\r\n     | if .[$t][$y] then .emit = false\r\n       else .emit = true | (.item = $x) | (.[$t][$y] = true)\r\n       end;\r\n     if .emit then .item else empty end );\r\n\r\n```\r\n\r\n\r\n\r\n\r\n",
                "title": "jq: error (at &lt;stdin&gt;:0): Cannot iterate over string, cannot execute unique problem"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1567580718,
        "creation_date": 1567505705,
        "last_edit_date": 1567580718,
        "question_id": 57769610,
        "body_markdown": "We are trying to parse a JSON file to a tsv file. We are having problems trying to eliminate duplicate Id with unique.\r\n\r\nJSON file\r\n\r\n    [\r\n       {&quot;Id&quot;: &quot;101&quot;,\r\n        &quot;Name&quot;: &quot;Yugi&quot;},   \r\n       {&quot;Id&quot;: &quot;101&quot;,\r\n        &quot;Name&quot;: &quot;Yugi&quot;},\r\n       {&quot;Id&quot;: &quot;102&quot;,\r\n        &quot;Name&quot;: &quot;David&quot;},      \r\n    ]\r\n\r\n```bash\r\ncat getEvent_all.json | jq -cr &#39;.[] | [.Id] | unique_by(.[].Id)&#39;\r\n```\r\n\r\njq: error (at &lt;stdin&gt;:0): Cannot iterate over string (&quot;101&quot;)",
        "link": "https://stackoverflow.com/questions/57769610/jq-error-at-stdin0-cannot-iterate-over-string-cannot-execute-unique-prob",
        "title": "jq: error (at &lt;stdin&gt;:0): Cannot iterate over string, cannot execute unique problem"
    },
    {
        "tags": [
            "bash",
            "shell",
            "awk",
            "grep",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1567563541,
                "last_edit_date": 1567563541,
                "creation_date": 1567559767,
                "answer_id": 57780326,
                "question_id": 57780262,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use [jq][1],\r\n\r\n**Example**\r\n\r\n    {\r\n     &quot;nodes&quot;: {\r\n      &quot;server.local&quot;: {\r\n      &quot;:ip&quot;: &quot;192.168.56.5&quot;,\r\n      &quot;ports&quot;: [],\r\n      &quot;:memory&quot;: 1024,\r\n      &quot;:bootstrap&quot;: &quot;bootstrap-master.sh&quot;\r\n    },\r\n    &quot;client1.local&quot;: {\r\n      &quot;:ip&quot;: &quot;192.168.56.10&quot;,\r\n      &quot;ports&quot;: [],\r\n      &quot;:memory&quot;: 1024,\r\n      &quot;:bootstrap&quot;: &quot;bootstrap-node.sh&quot;\r\n    },\r\n    &quot;client1.local&quot;: {\r\n      &quot;:ip&quot;: &quot;192.168.56.15&quot;,\r\n      &quot;ports&quot;: [],\r\n      &quot;:memory&quot;: 1024,\r\n      &quot;:bootstrap&quot;: &quot;bootstrap-node.sh&quot;\r\n    }\r\n    }}\r\n\r\nAnd run,\r\n\r\n    cat file | jq -r &#39;.nodes | keys[]&#39;\r\n\r\n\r\n**Output**\r\n\r\n    client1.abc\r\n    client1.def\r\n    server.xyz\r\n\r\n\r\n\r\n\r\n\r\n**Edit:**\r\n\r\nIf you want `ip` as well,\r\n\r\n    cat file | jq -r &#39;.nodes | to_entries[] | [.key, .value.&quot;:ip&quot;] | @tsv&#39; \r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/download/\r\n",
                "title": "Print data of a file"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1567578854,
                "creation_date": 1567578854,
                "answer_id": 57782722,
                "question_id": 57780262,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "you can execute the file as commands\r\nand have echo in the file so like\r\n```{\r\n &quot;nodes&quot;: {\r\n    echo&quot;server.xyz&quot;: {\r\n     echo &quot;:ip&quot;: &quot;192.168.56.5&quot;,\r\n     ```\r\nand so on then you do\r\n```eval $(cat file location)```\r\nbut i think the has to be in one line",
                "title": "Print data of a file"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1567610716,
        "creation_date": 1567559062,
        "last_edit_date": 1567561365,
        "question_id": 57780262,
        "body_markdown": "Print data of a file\r\nThis it the file content \r\n\r\n    {\r\n     &quot;nodes&quot;: {\r\n        &quot;server.xyz&quot;: {\r\n          &quot;:ip&quot;: &quot;192.168.56.5&quot;,\r\n          &quot;ports&quot;: [],\r\n          &quot;:memory&quot;: 1024,\r\n          &quot;:bootstrap&quot;: &quot;bootstrap-master.sh&quot;\r\n        },\r\n        &quot;client1.abc&quot;: {\r\n          &quot;:ip&quot;: &quot;192.168.56.10&quot;,\r\n          &quot;ports&quot;: [],\r\n          &quot;:memory&quot;: 1024,\r\n          &quot;:bootstrap&quot;: &quot;bootstrap-node.sh&quot;\r\n        },\r\n        &quot;client1.def&quot;: {\r\n          &quot;:ip&quot;: &quot;192.168.56.15&quot;,\r\n          &quot;ports&quot;: [],\r\n          &quot;:memory&quot;: 1024,\r\n          &quot;:bootstrap&quot;: &quot;bootstrap-node.sh&quot;\r\n        }\r\n      }\r\n    }\r\n\r\nI only want to print \r\n\r\n**server.xyz**\r\n\r\n**client1.abc**\r\n\r\n**client2.def**\r\n\r\nand this IP\r\n\r\n**192.168.56.5**\r\n\r\n**192.168.56.10**\r\n\r\n**192.168.56.15**",
        "link": "https://stackoverflow.com/questions/57780262/print-data-of-a-file",
        "title": "Print data of a file"
    },
    {
        "tags": [
            "json",
            "bash",
            "key",
            "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": 1567610844,
                "post_id": 57791502,
                "comment_id": 102016349,
                "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": 1567610954,
                "post_id": 57791502,
                "comment_id": 102016398,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1567611045,
                "last_edit_date": 1567611045,
                "creation_date": 1567610909,
                "answer_id": 57791569,
                "question_id": 57791502,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Instead of `.applications.$title` or `.applications.[$title]`, use `.applications[$title]`, as in:\r\n\r\n```\r\njq --arg title &quot;$title&quot; \\\r\n   --arg filename &quot;$filename&quot; \\\r\n   --arg version &quot;$version&quot; \\\r\n   --arg date &quot;$date&quot; \\\r\n   --arg id &quot;$id&quot; &#39;\r\n  .applications[$title] += [{$id, $filename, $version, $date}]&#39;\r\n```\r\n\r\n...and output is correctly:\r\n\r\n```\r\n{\r\n  &quot;applications&quot;: {\r\n    &quot;app1&quot;: [\r\n      {\r\n        &quot;id&quot;: &quot;1&quot;,\r\n        &quot;filename&quot;: &quot;install_latest_app.pkg&quot;,\r\n        &quot;version&quot;: &quot;1.2.3&quot;,\r\n        &quot;date&quot;: &quot;20190903&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: &quot;2&quot;,\r\n        &quot;filename&quot;: &quot;install_latest_app.pkg&quot;,\r\n        &quot;version&quot;: &quot;1.2.4&quot;,\r\n        &quot;date&quot;: &quot;20190904&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: &quot;3&quot;,\r\n        &quot;filename&quot;: &quot;install_latest_app.pkg&quot;,\r\n        &quot;version&quot;: &quot;1.2.5&quot;,\r\n        &quot;date&quot;: &quot;20190905&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: &quot;6&quot;,\r\n        &quot;filename&quot;: &quot;install_latest_app.pkg&quot;,\r\n        &quot;version&quot;: &quot;1.2.6&quot;,\r\n        &quot;date&quot;: &quot;20190906&quot;\r\n      }\r\n    ]\r\n  }\r\n}\r\n```",
                "title": "jq: use variable to identify an inner object key to append to"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1567615412,
        "creation_date": 1567610633,
        "last_edit_date": 1567615412,
        "question_id": 57791502,
        "body_markdown": "I&#39;ve been researching this for a bit and I&#39;ve seen answers that have gotten me closer to solving this, but nothing that actually gets me all the way there. \r\n\r\nI have the following JSON file:\r\n\r\n    {\r\n      &quot;applications&quot;: {\r\n        &quot;app1&quot;: [\r\n          {\r\n            &quot;id&quot;: &quot;1&quot;,\r\n            &quot;filename&quot;: &quot;install_latest_app.pkg&quot;,\r\n            &quot;version&quot;: &quot;1.2.3&quot;,\r\n            &quot;date&quot;: &quot;20190903&quot;\r\n          },\r\n          {\r\n            &quot;id&quot;: &quot;2&quot;,\r\n            &quot;filename&quot;: &quot;install_latest_app.pkg&quot;,\r\n            &quot;version&quot;: &quot;1.2.4&quot;,\r\n            &quot;date&quot;: &quot;20190904&quot;\r\n          },\r\n          {\r\n            &quot;id&quot;: &quot;3&quot;,\r\n            &quot;filename&quot;: &quot;install_latest_app.pkg&quot;,\r\n            &quot;version&quot;: &quot;1.2.5&quot;,\r\n            &quot;date&quot;: &quot;20190905&quot;\r\n          }\r\n        ]\r\n      }\r\n    }\r\n\r\nI am trying to use jq in a Bash script to dynamically add entries to this file under the specific &quot;app&quot;. In my example there&#39;s only one &quot;app&quot; defined (app1) but in a real world scenario there would be more.\r\n\r\n    #!/bin/bash\r\n    \r\n    title=&quot;app1&quot;\r\n    filename=&quot;install_latest_app.pkg&quot;\r\n    version=&quot;1.2.6&quot;\r\n    date=&quot;20190906&quot;\r\n    id=&quot;6&quot;\r\n    \r\n    jq --arg title &quot;$title&quot; \\\r\n    --arg filename &quot;$filename&quot; \\\r\n    --arg version &quot;$version&quot; \\\r\n    --arg date &quot;$date&quot; \\\r\n    --arg id &quot;$id&quot; \\\r\n    &#39;.applications.$title += [{&quot;id&quot;: $id, &quot;filename&quot;: $filename, &quot;version&quot;: $version, &quot;date&quot;: $date}]&#39; data.json &gt;&gt; data.json\r\n\r\nwhen trying to run this, I get a compile error.\r\n\r\n    jq: error: syntax error, unexpected &#39;$&#39;, expecting FORMAT or QQSTRING_START (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n    .applications.$title += [{&quot;id&quot;: $id, &quot;filename&quot;: $filename, &quot;version&quot;: $version, &quot;date&quot;: $date}]\r\n\r\nSame when running it in ways like `.applications.[$title]` or `(.applications.[$title])` (all based on other discussions).\r\n\r\nIf I do something like `.applications | .[$title] |= ...` I get a lot closer as it actually returns the JSON with the correct entries, however it doesn&#39;t add it to the current &quot;app1&quot;, instead adding a new entry for &quot;app1&quot;. I would be fine overwriting the entire file every time with the added entry, but I am struggling to get it to print the entire JSON + the new entry. Any help or ideas would be appreciated!",
        "link": "https://stackoverflow.com/questions/57791502/jq-use-variable-to-identify-an-inner-object-key-to-append-to",
        "title": "jq: use variable to identify an inner object key to append to"
    },
    {
        "tags": [
            "json",
            "shell",
            "nested",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 9118190,
                    "reputation": 31,
                    "user_id": 6784619,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/9c63a342bc9eaae209636de720ba119d?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "nimisha",
                    "link": "https://stackoverflow.com/users/6784619/nimisha"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1567658986,
                "post_id": 57798565,
                "comment_id": 102029764,
                "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": 1567661547,
                "post_id": 57798565,
                "comment_id": 102030416,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1567658999,
                "creation_date": 1567658999,
                "answer_id": 57798597,
                "question_id": 57798565,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "First you have to find the microservice object of interest:\r\n\r\n    .microservices[] | select(.appId == &quot;builds&quot;)\r\n\r\nThen with that, you could then update the `volumesFrom` value:\r\n\r\n    (.microservices[] | select(.appId == &quot;builds&quot;)).volumesFrom = ...\r\n\r\nhttps://jqplay.org/s/zLsEYAQrFC",
                "title": "Query nested json using jq"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1567662103,
        "creation_date": 1567658680,
        "last_edit_date": 1567662103,
        "question_id": 57798565,
        "body_markdown": "I have the json file `about.json` as below\r\n```\r\n{\r\n  &quot;build&quot;: {\r\n    &quot;tag&quot;: &quot;189&quot;,\r\n    &quot;buildtime&quot;: &quot;2019-07-19-08-05&quot;\r\n  },\r\n  &quot;microservices&quot;: [\r\n    {\r\n      &quot;appId&quot;: &quot;builds&quot;,\r\n      &quot;imageName&quot;: &quot;build-server:8&quot;,\r\n      &quot;volumesFrom&quot;: []\r\n    },\r\n    {\r\n      &quot;appId&quot;: &quot;studio&quot;,\r\n      &quot;imageName&quot;: &quot;tci-webserver:4074&quot;,\r\n      &quot;volumesFrom&quot;: [\r\n        &quot;tci-download-studio:xxx&quot;\r\n      ]\r\n    },\r\n    {\r\n      &quot;appId&quot;: &quot;site&quot;,\r\n      &quot;imageName&quot;: &quot;site:22&quot;,\r\n      &quot;volumesFrom&quot;: null\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nI want to substitute value for volumesFrom for for example for first appId: &quot;builds&quot;, but I am not able to fetch the key in the first place.\r\nCould anyone help me with the command to do this.\r\n\r\nI have the value stored in volumes variable. I want to assign this variable as a value to volumesFrom key for first appId:builds.\r\n\r\n\r\nI tried accessing the volumesFrom object using syntax such as\r\n```\r\njq .microservices.volumesFrom about.json\r\n```\r\n```\r\njq .microservices.[0].volumesfrom\r\n```\r\nBut none seems to fetch the key which I am expecting.",
        "link": "https://stackoverflow.com/questions/57798565/query-nested-json-using-jq",
        "title": "Query nested json using jq"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1567673565,
                "post_id": 57800829,
                "comment_id": 102035499,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1567672793,
                "last_edit_date": 1567672793,
                "creation_date": 1567671189,
                "answer_id": 57801143,
                "question_id": 57800829,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Your assinging the orders value as string. that&#39;s the reason you won&#39;t be able to loop through. remove the **double quote** when your assiging the orders vlaue like below.\r\n\r\n  \r\n\r\n     {\r\n        &quot;orders&quot;: [{&quot;items&quot;:[{&quot;itemid&quot;:&quot;&quot;,&quot;quantity&quot;:&quot;&quot;,&quot;price&quot;:&quot;&quot;,&quot;currency&quot;:&quot;IDR&quot;,&quot;shopid&quot;:&quot;&quot;,&quot;item_group_id&quot;:null,&quot;add_on_deal_id&quot;:null,&quot;checkout&quot;:true}],&quot;shopid&quot;:&quot;&quot;}],\r\n        &quot;check_voucher_payment_criteria&quot;: false,\r\n        &quot;need_wallet_active_info&quot;: false\r\n    }\r\n\r\n**Output**\r\n\r\n[![enter image description here][1]][1]\r\n \r\n\r\n\r\n  [1]: https://i.sstatic.net/89VRP.png",
                "title": "How to replace JSON value with the jq command?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1567674109,
                "last_edit_date": 1567674109,
                "creation_date": 1567673669,
                "answer_id": 57801819,
                "question_id": 57800829,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "In order to let `jq` understand the the json string inside the `orders` element, you have to replace the single quote `&#39;` in your json file by backslash double quote `\\&quot;`.\r\n\r\nThen you can use `jq` to replace the wanted values by transforming the json string to object and back to string:\r\n\r\n    sed &#39;s/\\x27/\\\\&quot;/g&#39; file | \\\r\n    jq &#39;.orders|=(fromjson|map(((.items[].itemid|=321)|(.items[].quantity|=1)|(.items[].price|=10000)|(.items[].shopid|=789)))|tojson)&#39;\r\n    {\r\n      &quot;orders&quot;: &quot;[{\\&quot;items\\&quot;:[{\\&quot;itemid\\&quot;:321,\\&quot;quantity\\&quot;:1,\\&quot;price\\&quot;:10000,   \\&quot;currency\\&quot;:\\&quot;IDR\\&quot;,\\&quot;shopid\\&quot;:789,\\&quot;item_group_id\\&quot;:null,\\&quot;add_on_deal_id\\&quot;:null,\\&quot;checkout\\&quot;:true}],\\&quot;shopid\\&quot;:\\&quot;\\&quot;}]&quot;,\r\n      &quot;check_voucher_payment_criteria&quot;: false,\r\n      &quot;need_wallet_active_info&quot;: false\r\n    }\r\n",
                "title": "How to replace JSON value with the jq command?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1567687242,
                "last_edit_date": 1567687242,
                "creation_date": 1567686913,
                "answer_id": 57805639,
                "question_id": 57800829,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The complication here is that your stringified JSON isn&#39;t properly stringified.  One option would be to make it valid stringified JSON, perform the updates, and stringify it again.\r\nIn the example, all the occurrences of `&#39;&#39;` are replaced by JSON values, so it doesn&#39;t matter whether this last step (restringification) is done normally (using `tojson`) or not, so in the following, only the normal stringification is performed.\r\n\r\n```\r\n.orders |= (gsub(&quot;&#39;&#39;&quot;;&quot;\\&quot;\\&quot;&quot;) | fromjson)\r\n| .orders[0].items[0] |= (.itemid = 321 | .quantity=1 | .price = 100000 | .shopid = 789)\r\n| .orders[0].shopid = 789\r\n| .orders |= tojson\r\n\r\n```\r\n\r\nWhether that first `gsub` should be as shown or\r\n`(gsub(&quot;&#39;&quot;;&quot;\\&quot;&quot;)` or something else will depend on the processes that produce and consume that mish-mash.",
                "title": "How to replace JSON value with the jq command?"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1567687242,
        "creation_date": 1567669962,
        "question_id": 57800829,
        "body_markdown": "I have this json file:\r\n\r\n    {\r\n    \t&quot;orders&quot;: &quot;[{\\&quot;items\\&quot;:[{\\&quot;itemid\\&quot;:&#39;&#39;,\\&quot;quantity\\&quot;:&#39;&#39;,\\&quot;price\\&quot;:&#39;&#39;,\\&quot;currency\\&quot;:\\&quot;IDR\\&quot;,\\&quot;shopid\\&quot;:&#39;&#39;,\\&quot;item_group_id\\&quot;:null,\\&quot;add_on_deal_id\\&quot;:null,\\&quot;checkout\\&quot;:true}],\\&quot;shopid\\&quot;:&#39;&#39;}]&quot;,\r\n    \t&quot;check_voucher_payment_criteria&quot;: false,\r\n    \t&quot;need_wallet_active_info&quot;: false\r\n    }\r\n\r\nI want to replace:\r\n\r\n 1. `itemid` with the value of `321`\r\n 2. `quantity` with the value of `1`\r\n 3. `price` with the value of `100000`\r\n 4. `shopid` with the value of `789`\r\n\r\nSo the result I want is:\r\n```\r\n{\r\n\t&quot;orders&quot;: &quot;[{\\&quot;items\\&quot;:[{\\&quot;itemid\\&quot;:321,\\&quot;quantity\\&quot;:1,\\&quot;price\\&quot;:100000,\\&quot;currency\\&quot;:\\&quot;IDR\\&quot;,\\&quot;shopid\\&quot;:789,\\&quot;item_group_id\\&quot;:null,\\&quot;add_on_deal_id\\&quot;:null,\\&quot;checkout\\&quot;:true}],\\&quot;shopid\\&quot;:789}]&quot;,\r\n\t&quot;check_voucher_payment_criteria&quot;: false,\r\n\t&quot;need_wallet_active_info&quot;: false\r\n}\r\n```\r\nI tried https://jqplay.org/s/x3IArefkyH:\r\n```\r\njq --raw-output &#39;.orders[].items = 321&#39; file.json\r\n```\r\nBut it gave me this error:\r\n```\r\njq: error (at &lt;stdin&gt;:4): Cannot iterate over string (&quot;[{\\&quot;items\\...)\r\nexit status 5\r\n```\r\nHow should I fix it ?",
        "link": "https://stackoverflow.com/questions/57800829/how-to-replace-json-value-with-the-jq-command",
        "title": "How to replace JSON value with the jq command?"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1567710210,
                "last_edit_date": 1567710210,
                "creation_date": 1567708839,
                "answer_id": 57811320,
                "question_id": 57811213,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You&#39;re expanding `.secrule` twice, thus every combination of its elements get checked. Use `any` instead:\r\n```\r\n.[] | select(any(.secrule[]; .source==&quot;0.0.0.0/0&quot; and .tcpOptions.destinationPortRange.min==80)).displayName\r\n```",
                "title": "jq parse for multiple values"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1574354296,
        "creation_date": 1567708297,
        "last_edit_date": 1574354296,
        "question_id": 57811213,
        "body_markdown": "I&#39;m trying to output displayName from JSON which has both  \r\n&lt;pre&gt;\r\n&lt;code&gt;&quot;source&quot;: &quot;0.0.0.0/0&quot; and\r\ntcpOptions&quot;: &quot;destinationPortRange&quot;: &quot;min&quot;: 80&lt;/code&gt;\r\n&lt;/pre&gt;\r\nThe result should display only\r\n&lt;pre&gt;\r\n&lt;code&gt;rule-1&lt;/code&gt;\r\n&lt;/pre&gt;\r\neg: JSON\r\n&lt;pre&gt;\r\n&lt;code&gt;[\r\n  {\r\n    &quot;displayName&quot;: &quot;rule-1&quot;,\r\n    &quot;secrule&quot;: [\r\n      {\r\n        &quot;source&quot;: &quot;0.0.0.0/0&quot;,\r\n        &quot;tcpOptions&quot;: {\r\n          &quot;destinationPortRange&quot;: {\r\n            &quot;min&quot;: 80,\r\n            &quot;max&quot;: 80\r\n          }\r\n        }\r\n      },\r\n      {\r\n        &quot;source&quot;: &quot;0.0.0.0/0&quot;,\r\n        &quot;tcpOptions&quot;: {\r\n          &quot;destinationPortRange&quot;: {\r\n            &quot;min&quot;: 443,\r\n            &quot;max&quot;: 443\r\n          }\r\n        }\r\n      }\r\n    ]\r\n  },\r\n  {\r\n    &quot;displayName&quot;: &quot;rule-2&quot;,\r\n    &quot;secrule&quot;: [\r\n      {\r\n        &quot;source&quot;: &quot;0.0.0.0/0&quot;,\r\n        &quot;tcpOptions&quot;: {\r\n          &quot;destinationPortRange&quot;: {\r\n            &quot;min&quot;: 443,\r\n            &quot;max&quot;: 443\r\n          }\r\n        }\r\n      },\r\n      {\r\n        &quot;source&quot;: &quot;20.0.0.0/0&quot;,\r\n        &quot;tcpOptions&quot;: {\r\n          &quot;destinationPortRange&quot;: {\r\n            &quot;min&quot;: 80,\r\n            &quot;max&quot;: 80\r\n          }\r\n        }\r\n      }\r\n    ]\r\n  }\r\n]&lt;/code&gt;\r\n&lt;/pre&gt;\r\nI have tried \r\n&lt;pre&gt;\r\n&lt;code&gt;jq -r &#39;.[] | select(.secrule[].source == &quot;0.0.0.0/0&quot; and .secrule[].tcpOptions.destinationPortRange.min == 80) | .displayName&#39; JSON | sort -u&lt;/code&gt;\r\n&lt;/pre&gt;\r\nBut it displays both rules (which is incorrect)\r\n&lt;pre&gt;\r\n&lt;code&gt;rule-1\r\nrule-2&lt;/code&gt;\r\n&lt;/pre&gt;",
        "link": "https://stackoverflow.com/questions/57811213/jq-parse-for-multiple-values",
        "title": "jq parse for multiple values"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 166270,
                    "reputation": 135171,
                    "user_id": 390278,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/84715fec547362389d02f5be0ed12814?s=256&d=identicon&r=PG",
                    "display_name": "Jeff Mercado",
                    "link": "https://stackoverflow.com/users/390278/jeff-mercado"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1567722985,
                "post_id": 57813671,
                "comment_id": 102058627,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 112208,
                    "reputation": 1028,
                    "user_id": 296078,
                    "user_type": "registered",
                    "accept_rate": 44,
                    "profile_image": "https://www.gravatar.com/avatar/e6940f7f25e810fb528487e2850bc3a9?s=256&d=identicon&r=PG",
                    "display_name": "Sergey",
                    "link": "https://stackoverflow.com/users/296078/sergey"
                },
                "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": 1567723172,
                "post_id": 57813671,
                "comment_id": 102058665,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1270084,
                    "reputation": 5516,
                    "user_id": 1226605,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/ad052087f658c0667ac37deca1ee61fb?s=256&d=identicon&r=PG",
                    "display_name": "devang",
                    "link": "https://stackoverflow.com/users/1226605/devang"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1567723820,
                "post_id": 57813671,
                "comment_id": 102058781,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1567723246,
                "creation_date": 1567723246,
                "answer_id": 57813758,
                "question_id": 57813671,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Assuming you&#39;re just taking the objects and transforming them to pairs of the index in the array and the `ID` value, you could do this:\r\n\r\n    map([to_entries[] | [.key + 1, .value.ID | tostring]])\r\n\r\nhttps://jqplay.org/s/RBac7SPfdG\r\n\r\nUsing `to_entries/0` on an array gives you an array of key/value (index/value) pairs. You could then shift the indices by 1 and convert to strings.",
                "title": "Change subelement with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1567723246,
        "creation_date": 1567722461,
        "question_id": 57813671,
        "body_markdown": "I have a structure that looks like so\r\n```\r\n[\r\n  [\r\n    {\r\n      &quot;ID&quot;: &quot;grp1-001&quot;,\r\n    },\r\n    {\r\n      &quot;ID&quot;: &quot;grp1-002&quot;,\r\n    },\r\n    {\r\n      &quot;ID&quot;: &quot;grp1-003&quot;,\r\n    },\r\n    {\r\n      &quot;ID&quot;: &quot;grp1-004&quot;,\r\n    },\r\n    {\r\n      &quot;ID&quot;: &quot;grp1-005&quot;,\r\n    },\r\n    {\r\n      &quot;ID&quot;: &quot;grp1-006&quot;,\r\n    }\r\n  ],\r\n  [\r\n    {\r\n      &quot;ID&quot;: &quot;grp2-001&quot;,\r\n    },\r\n    {\r\n      &quot;ID&quot;: &quot;grp2-002&quot;,\r\n    },\r\n    {\r\n      &quot;ID&quot;: &quot;grp2-003&quot;,\r\n    },\r\n    {\r\n      &quot;ID&quot;: &quot;grp2-004&quot;,\r\n    },\r\n    {\r\n      &quot;ID&quot;: &quot;grp2-005&quot;,\r\n    },\r\n    {\r\n      &quot;ID&quot;: &quot;grp2-006&quot;,\r\n    }\r\n.......\r\n```\r\nwhat I need to get as a result of the modification is this\r\n```\r\n[\r\n  [\r\n    [&quot;1&quot;, &quot;grp1-001&quot;],\r\n    [&quot;2&quot;, &quot;grp1-002&quot;],\r\n    [&quot;3&quot;, &quot;grp1-003&quot;],\r\n    [&quot;4&quot;, &quot;grp1-004&quot;],\r\n    [&quot;5&quot;, &quot;grp1-005&quot;],\r\n    [&quot;6&quot;, &quot;grp1-006&quot;],\r\n  ],\r\n  [\r\n    [&quot;1&quot;, &quot;grp2-001&quot;],\r\n    [&quot;2&quot;, &quot;grp2-002&quot;],\r\n    [&quot;3&quot;, &quot;grp2-003&quot;],\r\n    [&quot;4&quot;, &quot;grp2-004&quot;],\r\n    [&quot;5&quot;, &quot;grp2-005&quot;],\r\n    [&quot;6&quot;, &quot;grp2-006&quot;],\r\n  ],\r\n```\r\nWhich means I need to keep the external structure (outside array and an internal grouping) but convert the inner dict to an array and replace the &quot;ID&quot; key with a value (that will come from external source like `--argjson`). I am not even sure how to start - any ideas/resources are highly appreciated.",
        "link": "https://stackoverflow.com/questions/57813671/change-subelement-with-jq",
        "title": "Change subelement with jq"
    },
    {
        "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": 1567764191,
                "post_id": 57819081,
                "comment_id": 102070003,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 15535508,
                    "reputation": 445,
                    "user_id": 11207803,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/-FJ4WGmO0jKs/AAAAAAAAAAI/AAAAAAAAAAA/ACHi3rellG-NbGxyx1QYHIwx94nRxx6j2g/mo/s256-rj/photo.jpg",
                    "display_name": "AK123",
                    "link": "https://stackoverflow.com/users/11207803/ak123"
                },
                "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": 1567764627,
                "post_id": 57819081,
                "comment_id": 102070212,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1567765950,
                "last_edit_date": 1567765950,
                "creation_date": 1567764905,
                "answer_id": 57820090,
                "question_id": 57819081,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Your requirements are not entirely clear to me, but the following variant of your program does match one interpretation of your description of the problem and illustrates how to use `map_values` and `all/2`:\r\n```\r\n.paths |= with_entries(\r\n  if (.key|startswith(&quot;/&quot;))\r\n  then .value |= map_values(\r\n    if has(&quot;parameters&quot;) and all(.parameters[]; .name != &quot;Authorization&quot;)\r\n    then .parameters += $auth\r\n    else . end ) \r\n  else . end )\r\n```\r\n\r\nAnd here&#39;s a program that matches one interpretation of your second set of requirements regarding removal of &quot;Authorization&quot; entries:\r\n``` \r\n.paths |= with_entries(\r\n  if (.key|startswith(&quot;/&quot;))\r\n  then .value |= map_values(\r\n    if has(&quot;parameters&quot;)\r\n    then\r\n    # first delete and then add\r\n      .parameters |= map(select( .name != &quot;Authorization&quot;))\r\n      | .parameters += $auth\r\n    else  . end )\r\n  else . end)\r\n```",
                "title": "Replace object from a file into the main.json along with wildcards using jq 1.5"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1567765950,
        "creation_date": 1567761274,
        "last_edit_date": 1567765376,
        "question_id": 57819081,
        "body_markdown": "I have been able to add a json object - that is saved in a file named auth.json - into the Main.json file.\r\nAuth.json\r\n\r\n    { \r\n        &quot;name&quot;: &quot;Authorization&quot;,\r\n        &quot;description&quot;: &quot;this is authorization&quot;,\r\n         &quot;in&quot;: &quot;header&quot;,\r\n    }\r\nMain.json\r\n\r\n    {\r\n      &quot;swagger&quot;: &quot;2.0&quot;,\r\n        &quot;paths&quot;: {\r\n        &quot;/agents/delta&quot;: {\r\n          &quot;get&quot;: {\r\n            &quot;description&quot;: &quot;lorem ipsum doram&quot;,\r\n            &quot;parameters&quot;: [\r\n              {\r\n                &quot;name&quot;: &quot;since&quot;,\r\n                &quot;in&quot;: &quot;query&quot;,\r\n              }\r\n            ]\r\n            }\r\n            }\r\n            }\r\n            }\r\n\r\nUsing the below command, I have been able to add it in the below path `.paths.&lt;any method that starts with /&gt;.get.parameters`. Also it is getting added only if the parameters array does not already contain the &#39;Authorization&#39; object.\r\nWorking command: \r\n\r\n    jq --slurpfile auth auth.json &#39; .paths |= with_entries(  if (.key|startswith(&quot;/&quot;)) and (.value.get.parameters[].name != &quot;Authorization&quot;) then  .value.get.parameters += $auth  else  . end )&#39; test.json &gt; test1.json\r\n\r\nBut now I have to added it under every object within the  `.paths.&lt;any method that starts with /&gt;.&lt;any value&gt;.parameters`.\r\n\r\nSo for a input json like below.\r\n\r\n    {\r\n          &quot;swagger&quot;: &quot;2.0&quot;,\r\n            &quot;paths&quot;: {\r\n            &quot;/agents/delta&quot;: {\r\n              &quot;get&quot;: {\r\n                &quot;description&quot;: &quot;lorem ipsum doram&quot;,\r\n                &quot;parameters&quot;: [\r\n                  {\r\n                    &quot;name&quot;: &quot;since&quot;,\r\n                    &quot;in&quot;: &quot;query&quot;,\r\n                  }\r\n                ]\r\n                }\r\n    \t\t\t&quot;put&quot;: {\r\n    \t\t\t            &quot;description&quot;: &quot;lorem ipsum doram&quot;,\r\n                &quot;parameters&quot;: [\r\n                  {\r\n                    &quot;name&quot;: &quot;since&quot;,\r\n                    &quot;in&quot;: &quot;query&quot;,\r\n                  }\r\n                ]\r\n                }\r\n                }\r\n                }\r\n                }\r\n\r\nexpected output should be like:\r\n\r\n    {\r\n          &quot;swagger&quot;: &quot;2.0&quot;,\r\n            &quot;paths&quot;: {\r\n            &quot;/agents/delta&quot;: {\r\n              &quot;get&quot;: {\r\n                &quot;description&quot;: &quot;lorem ipsum doram&quot;,\r\n                &quot;parameters&quot;: [\r\n                  {\r\n                    &quot;name&quot;: &quot;since&quot;,\r\n                    &quot;in&quot;: &quot;query&quot;,\r\n                  },\r\n    \t\t\t  { \r\n                    &quot;name&quot;: &quot;Authorization&quot;,\r\n                    &quot;description&quot;: &quot;this is authorization&quot;,\r\n                    &quot;in&quot;: &quot;header&quot;,\r\n                  }\r\n                ]\r\n                }\r\n    \t\t\t&quot;put&quot;: {\r\n    \t\t\t            &quot;description&quot;: &quot;lorem ipsum doram&quot;,\r\n                &quot;parameters&quot;: [\r\n                  {\r\n                    &quot;name&quot;: &quot;since&quot;,\r\n                    &quot;in&quot;: &quot;query&quot;,\r\n                  },\r\n    \t\t\t  { \r\n                    &quot;name&quot;: &quot;Authorization&quot;,\r\n                    &quot;description&quot;: &quot;this is authorization&quot;,\r\n                    &quot;in&quot;: &quot;header&quot;,\r\n                  }\r\n                ]\r\n                }\r\n                }\r\n                }\r\n                }\r\n\r\n\r\nSo I tried the below command.\r\n\r\n    jq --slurpfile auth auth.json &#39; .paths |= with_entries(  if (.key|startswith(&quot;/&quot;)) and (.value | .. | .parameters[]?.name != &quot;Authorization&quot;) then  .value| .. |.parameters? += $auth  else  . end )&#39; test.json\r\n\r\nBut I get the error \r\n\r\n    jq: error (at test.json:3027): object ({&quot;name&quot;:&quot;si...) and array ([{&quot;name&quot;:&quot;A...) cannot be added\r\n\r\nI tried using `inside` like the below\r\n\r\n    jq --slurpfile auth auth.json &#39;.paths |= with_entries(  if (.key|startswith(&quot;/&quot;)) and (.value | inside ([&quot;get&quot;,&quot;put&quot;,&quot;post&quot;]) |.parameters[].name != &quot;Authorization&quot;) then  .value.get.parameters += $auth  else  . end )&#39; test.json\r\n\r\nBut I get this error:\r\n\r\n    jq: error (at test.json:3027): array ([&quot;get&quot;,&quot;put...) and object ({&quot;get&quot;:{&quot;de...) cannot have their containment checked\r\n\r\n\r\nI also have to be able to remove any object with `&quot;name&quot;: &quot;Authorization&quot;` if it exists and replace it with the contents of auth.json.\r\n\r\nAny leads will be helpful.\r\n\r\nSo the expected output is as below:\r\n",
        "link": "https://stackoverflow.com/questions/57819081/replace-object-from-a-file-into-the-main-json-along-with-wildcards-using-jq-1-5",
        "title": "Replace object from a file into the main.json along with wildcards using jq 1.5"
    },
    {
        "tags": [
            ".net",
            "shell",
            "sh",
            "ubuntu-16.04",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 266703,
                    "reputation": 18823,
                    "user_id": 1149423,
                    "user_type": "registered",
                    "accept_rate": 83,
                    "profile_image": "https://i.sstatic.net/KmNLc.png?s=256",
                    "display_name": "Sufiyan Ghori",
                    "link": "https://stackoverflow.com/users/1149423/sufiyan-ghori"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1567986820,
                "post_id": 57820251,
                "comment_id": 102120239,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1660419750,
                "creation_date": 1660419750,
                "answer_id": 73347206,
                "question_id": 57820251,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "When you run `jq .version` you get the output `&quot;1.2.0-dev.29&quot;`. You need it without the quotes. To get that, add `-r` (`--raw-output`) to your jq call:\r\n\r\n    jq -r &#39;.version&#39; yourfile",
                "title": "How to pass version number from jq for dotnet tool install command in Ubuntu?"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1660419750,
        "creation_date": 1567765512,
        "question_id": 57820251,
        "body_markdown": "This question is related to my previous question here:\r\nhttps://stackoverflow.com/questions/57818783/how-to-pass-a-value-from-json-to-a-command-in-shell-script-at-docker?noredirect=1#comment102068283_57818783\r\n\r\nI have a shell script file as below:\r\n\r\n    name=$(jq &#39;.name&#39; /xxx/deploy-tool.json)\r\n    nugetFileVersion=$(jq &#39;.version&#39; /xxx/deploy-tool.json)\r\n    #bash\r\n    #echo $name\r\n    \r\n    # TODO how to pass value from JSON to the command below\r\n    # install dot net nuget\r\n    dotnet tool install -g $name --version $nugetFileVersion --add-source /xxx/\r\n\r\nHere is my `deploy-tool.json` file\r\n\r\n    {\r\n        &quot;name&quot;: &quot;xxx.DEPLOY&quot;,\r\n        &quot;version&quot;: &quot;1.2.0-dev.29&quot;\r\n    }\r\n\r\nWhen I run the script above in the dockerfile, I got an error message saying:   \r\n\r\n&gt; Specified version &#39;&quot;1.2.0-dev.29&quot;&#39; is not a valid NuGet version range.\r\n\r\nI tried to check `dotnet-tool install` documentation here: https://learn.microsoft.com/en-us/dotnet/core/tools/dotnet-tool-install\r\nHowever, I could not find anything useful.\r\n\r\nHow do I pass the `nugetFileVersion` from the `jq` command to the `dotnet tool install`&#39;s version parameter like how I managed to do so in powershell like the image below:\r\n[![powershell command OK][1]][1]\r\n\r\nThank you\r\n\r\n\r\n  [1]: https://i.sstatic.net/YcNj3.png",
        "link": "https://stackoverflow.com/questions/57820251/how-to-pass-version-number-from-jq-for-dotnet-tool-install-command-in-ubuntu",
        "title": "How to pass version number from jq for dotnet tool install command in Ubuntu?"
    },
    {
        "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": 1567766149,
                "post_id": 57820379,
                "comment_id": 102070929,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3084863,
                    "reputation": 29502,
                    "user_id": 2612235,
                    "user_type": "registered",
                    "accept_rate": 84,
                    "profile_image": "https://i.sstatic.net/dpsjq.jpg?s=256",
                    "display_name": "nowox",
                    "link": "https://stackoverflow.com/users/2612235/nowox"
                },
                "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": 1567766202,
                "post_id": 57820379,
                "comment_id": 102070963,
                "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": 1,
                "creation_date": 1567766380,
                "post_id": 57820379,
                "comment_id": 102071048,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3084863,
                    "reputation": 29502,
                    "user_id": 2612235,
                    "user_type": "registered",
                    "accept_rate": 84,
                    "profile_image": "https://i.sstatic.net/dpsjq.jpg?s=256",
                    "display_name": "nowox",
                    "link": "https://stackoverflow.com/users/2612235/nowox"
                },
                "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": 2,
                "creation_date": 1567766557,
                "post_id": 57820379,
                "comment_id": 102071130,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "reply_to_user": {
                    "account_id": 15778755,
                    "reputation": 1303,
                    "user_id": 11385808,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/321f8b770bfd0099048493cebba39edd?s=256&d=identicon&r=PG",
                    "display_name": "Dmitry",
                    "link": "https://stackoverflow.com/users/11385808/dmitry"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1567768955,
                "post_id": 57820379,
                "comment_id": 102072185,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 15778755,
                    "reputation": 1303,
                    "user_id": 11385808,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/321f8b770bfd0099048493cebba39edd?s=256&d=identicon&r=PG",
                    "display_name": "Dmitry",
                    "link": "https://stackoverflow.com/users/11385808/dmitry"
                },
                "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": 1567769055,
                "post_id": 57820379,
                "comment_id": 102072234,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "reply_to_user": {
                    "account_id": 15778755,
                    "reputation": 1303,
                    "user_id": 11385808,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/321f8b770bfd0099048493cebba39edd?s=256&d=identicon&r=PG",
                    "display_name": "Dmitry",
                    "link": "https://stackoverflow.com/users/11385808/dmitry"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1567769541,
                "post_id": 57820379,
                "comment_id": 102072460,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 15778755,
                    "reputation": 1303,
                    "user_id": 11385808,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/321f8b770bfd0099048493cebba39edd?s=256&d=identicon&r=PG",
                    "display_name": "Dmitry",
                    "link": "https://stackoverflow.com/users/11385808/dmitry"
                },
                "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": 1567770476,
                "post_id": 57820379,
                "comment_id": 102072895,
                "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"
                },
                "reply_to_user": {
                    "account_id": 15778755,
                    "reputation": 1303,
                    "user_id": 11385808,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/321f8b770bfd0099048493cebba39edd?s=256&d=identicon&r=PG",
                    "display_name": "Dmitry",
                    "link": "https://stackoverflow.com/users/11385808/dmitry"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1567770867,
                "post_id": 57820379,
                "comment_id": 102073050,
                "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"
                },
                "reply_to_user": {
                    "account_id": 15778755,
                    "reputation": 1303,
                    "user_id": 11385808,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/321f8b770bfd0099048493cebba39edd?s=256&d=identicon&r=PG",
                    "display_name": "Dmitry",
                    "link": "https://stackoverflow.com/users/11385808/dmitry"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1567776533,
                "post_id": 57820379,
                "comment_id": 102076056,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 15778755,
                    "reputation": 1303,
                    "user_id": 11385808,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/321f8b770bfd0099048493cebba39edd?s=256&d=identicon&r=PG",
                    "display_name": "Dmitry",
                    "link": "https://stackoverflow.com/users/11385808/dmitry"
                },
                "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": 1567784593,
                "post_id": 57820379,
                "comment_id": 102080207,
                "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"
                },
                "reply_to_user": {
                    "account_id": 15778755,
                    "reputation": 1303,
                    "user_id": 11385808,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/321f8b770bfd0099048493cebba39edd?s=256&d=identicon&r=PG",
                    "display_name": "Dmitry",
                    "link": "https://stackoverflow.com/users/11385808/dmitry"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1567785004,
                "post_id": 57820379,
                "comment_id": 102080427,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1567797249,
                "last_edit_date": 1567797249,
                "creation_date": 1567766567,
                "answer_id": 57820495,
                "question_id": 57820379,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "How about \r\n\r\n    &lt; config.json jq &#39;.. | objects | .topics[]?&#39;\r\n\r\nIf you want to remove duplicates, you could pipe the above into `sort -u`, or use jq to do the same, e.g. using `unique`.\r\n\r\n## Without ..\r\n\r\nIn some contexts, `..` may be inappropriate, so here is a `..`-free solution to the problem at hand: \r\n\r\n    &lt; config.json jq &#39;[.[][]?.topics[]?] | unique[]&#39;",
                "title": "Get all values from a list of list with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1567797249,
        "creation_date": 1567766047,
        "last_edit_date": 1567766544,
        "question_id": 57820379,
        "body_markdown": "I would like to get all `topics` in this `json`:\r\n\r\n    $ wget https://raw.githubusercontent.com/exercism/c/master/config.json\r\n    $ cat config.json | jq merge(.[].topics)\r\n\r\nBut obviously the above code does not work...\r\n\r\nAt the end I would like a list of all the topics:\r\n\r\n    arrays\r\n    control_flow_loops\r\n    ...\r\n\r\nI am more familiar with regexp and one solution not involving `jq` could be:\r\n\r\n    $ perl -0777 -ne &#39;print $_ =~ s/[ &quot;,]//gr for \r\n        m/topics.*?\\[\\K.*?(?=\\])/smg&#39; config.json | sort -u\r\n\r\n**Example**\r\n\r\nWith this input:\r\n\r\n    {\r\n        &quot;exercises&quot;: [\r\n            {\r\n                &quot;topics&quot;: [\r\n                    &quot;foo&quot;\r\n                ]\r\n            },\r\n            {\r\n    \r\n                &quot;topics&quot;: [\r\n                    &quot;bar&quot;,\r\n                    &quot;baz&quot;\r\n                ]\r\n            },\r\n            {\r\n                &quot;topics&quot;: [\r\n                    &quot;foo&quot;,\r\n                    &quot;qux&quot;\r\n                ]\r\n            }\r\n        ]\r\n    }\r\n\r\nI would like this output:\r\n\r\n    foo\r\n    bar\r\n    baz\r\n    qux",
        "link": "https://stackoverflow.com/questions/57820379/get-all-values-from-a-list-of-list-with-jq",
        "title": "Get all values from a list of list with jq"
    },
    {
        "tags": [
            "json",
            "export-to-csv",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1567884137,
                "creation_date": 1567884137,
                "answer_id": 57836819,
                "question_id": 57836648,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You don&#39;t need a loop. And jq can produce CSV out of arrays.\r\n```\r\njq -r &#39;.documents[].pages[].fields[] | [.name, .transcription.normalized] | @csv&#39; file\r\n```",
                "title": "How to loop through JSON objects to extract specific key values with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1567888723,
        "creation_date": 1567882730,
        "last_edit_date": 1567888723,
        "question_id": 57836648,
        "body_markdown": "I am new to Bash scripting and jq.  I am trying to extract the key value pairs `name` and `transcription.normalized` from a JSON object.  \r\n\r\nI have learned how to get a list of all the values from name and normalized separately but it is not really what I am looking for.  \r\n\r\n```\r\ncat submission.json | jq &#39;.documents[] .pages[] .fields[] .name, .documents[] .pages[] .fields[] .transcription.normalized&#39;\r\n```\r\n\r\nI am wondering if I need to perform some sort of loop but just not sure. I really want a single script that pulls those 2 fields in a format that I can easily dump to a CSV file.  \r\n\r\n\r\nThis is the example of what the JSON looks like.  \r\n\r\n```\r\n{\r\n  &quot;id&quot;: 1,\r\n  &quot;state&quot;: &quot;complete&quot;,\r\n  &quot;substate&quot;: null,\r\n  &quot;exceptions&quot;: [],\r\n  &quot;name&quot;: &quot;Sender Account Number&quot;,\r\n  &quot;output_name&quot;: null,\r\n  &quot;field_definition_attributes&quot;: {\r\n    &quot;required&quot;: false,\r\n    &quot;data_type&quot;: &quot;Account Number&quot;,\r\n    &quot;multiline&quot;: false,\r\n    &quot;consensus_required&quot;: false,\r\n    &quot;supervision_override&quot;: null\r\n  },\r\n  &quot;transcription&quot;: {\r\n    &quot;raw&quot;: &quot;1685-0441-1&quot;,\r\n    &quot;normalized&quot;: &quot;168504411&quot;,\r\n    &quot;source&quot;: &quot;machine_transcription&quot;,\r\n    &quot;data_deleted&quot;: false,\r\n    &quot;user_transcribed&quot;: null,\r\n    &quot;row_index&quot;: null\r\n  },\r\n  &quot;field_image_url&quot;: &quot;/api/v4/image/be167a88-9d1d-43bc-82b2-3d96d8c06656?start_x=0.3110429607297866&amp;start_y=0.1052441592299208&amp;end_x=0.5696909842243418&amp;end_y=0.16043316955780607&quot;\r\n}\r\n```",
        "link": "https://stackoverflow.com/questions/57836648/how-to-loop-through-json-objects-to-extract-specific-key-values-with-jq",
        "title": "How to loop through JSON objects to extract specific key values with jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1567954911,
                "last_edit_date": 1567954911,
                "creation_date": 1567937668,
                "answer_id": 57841001,
                "question_id": 57840933,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Make an array out of each object under `actions` and add it to `idMembers`.\r\n```\r\n.[] | .idMembers + (.actions[] | map(.))\r\n```\r\n`map(.)` can also be written as `[.[]]`. For clarification, above is the same as:\r\n```\r\n.[] | .idMembers + (.actions[0] | map(.)),\r\n      .idMembers + (.actions[1] | map(.)),\r\n      .idMembers + (.actions[2] | map(.)),\r\n                            ...\r\n      .idMembers + (.actions[n] | map(.))\r\n```\r\nwhere `n` is the number of elements in `actions`.",
                "title": "how to parse json with various arrays"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1567954911,
        "creation_date": 1567936948,
        "last_edit_date": 1567939079,
        "question_id": 57840933,
        "body_markdown": "I have a json file that looks like:\r\n\r\n\r\n```\r\n[\r\n  {\r\n    &quot;id&quot;: &quot;aaa&quot;,\r\n    &quot;idMembers&quot;: [\r\n      &quot;David&quot;,\r\n      &quot;Mary&quot;\r\n    ],\r\n    &quot;actions&quot;: [\r\n      {\r\n        &quot;id&quot;: &quot;1&quot;,\r\n        &quot;date&quot;: &quot;2019-08-28&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: &quot;2&quot;,\r\n        &quot;date&quot;: &quot;2019-08-29&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: &quot;3&quot;,\r\n        &quot;date&quot;: &quot;2019-08-30&quot;\r\n      }\r\n    ]\r\n  },\r\n  {\r\n    &quot;id&quot;: &quot;bbb&quot;,\r\n    &quot;idMembers&quot;: [\r\n      &quot;Mar&quot;,\r\n      &quot;Alex&quot;\r\n    ],\r\n    &quot;actions&quot;: [\r\n      {\r\n        &quot;id&quot;: &quot;1&quot;,\r\n        &quot;date&quot;: &quot;2019-07-28&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: &quot;2&quot;,\r\n        &quot;date&quot;: &quot;2019-07-29&quot;\r\n      }\r\n    ]\r\n  }\r\n]\r\n```\r\n\r\nI would like to obtain a result like:\r\n```\r\n[&quot;David&quot;, &quot;Mary&quot;, &quot;1&quot;, &quot;2019-08-28&quot;]\r\n[&quot;David&quot;, &quot;Mary&quot;, &quot;2&quot;, &quot;2019-08-29&quot;]\r\n[&quot;David&quot;, &quot;Mary&quot;, &quot;3&quot;, &quot;2019-08-30&quot;]\r\n[&quot;Mar&quot;, &quot;Alex&quot;, &quot;1&quot;, &quot;2019-07-28&quot;]\r\n[&quot;Mar&quot;, &quot;Alex&quot;, &quot;2&quot;, &quot;2019-07-29&quot;]\r\n```\r\n\r\n\r\nI tried:\r\n\r\n```\r\njq -c &#39;.[] | [ .idMembers[], .actions[].id, .actions[].date] &#39;\r\n```\r\nBut results are:\r\n```\r\n[&quot;David&quot;, &quot;Mary&quot;, &quot;1&quot;, &quot;2&quot;, &quot;3&quot;, &quot;2019-08-28&quot;, &quot;2019-08-29&quot;, &quot;2019-08-30&quot;]\r\n[&quot;Mar&quot;, &quot;Alex&quot;, &quot;1&quot;, &quot;2&quot;, &quot;2019-07-28&quot;, &quot;2019-07-29&quot;]\r\n```\r\n\r\nI would like do someting like:\r\n```\r\njq -c &#39;.[] | .idMembers[], .actions[] | [ .id, .date] &#39;\r\n```\r\nbut it return me \r\n\r\njq: error (at &lt;stdin&gt;:1268): Cannot index string with string &quot;id&quot;\r\n\r\n\r\nIs possible to do something similar to this?\r\n```\r\njq -c &#39;.[] | .actions[] | [.idMembers[], .id, .date] &#39;\r\n```",
        "link": "https://stackoverflow.com/questions/57840933/how-to-parse-json-with-various-arrays",
        "title": "how to parse json with various arrays"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 5802424,
                    "reputation": 3211,
                    "user_id": 5976614,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f80aa6f4efc2243a68393d2f3e518916?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Pacifist",
                    "link": "https://stackoverflow.com/users/5976614/pacifist"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1568001651,
                "post_id": 57847233,
                "comment_id": 102122390,
                "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": 1,
                "creation_date": 1568006937,
                "post_id": 57847233,
                "comment_id": 102123399,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1629867,
                    "reputation": 3,
                    "user_id": 1504658,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d75933dd85c5a47e545c499465c6b68e?s=256&d=identicon&r=PG",
                    "display_name": "wahiggins3",
                    "link": "https://stackoverflow.com/users/1504658/wahiggins3"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1568031184,
                "post_id": 57847233,
                "comment_id": 102133741,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 15778755,
                    "reputation": 1303,
                    "user_id": 11385808,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/321f8b770bfd0099048493cebba39edd?s=256&d=identicon&r=PG",
                    "display_name": "Dmitry",
                    "link": "https://stackoverflow.com/users/11385808/dmitry"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1568034725,
                "post_id": 57847233,
                "comment_id": 102135703,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": -3,
                "last_activity_date": 1568006667,
                "creation_date": 1568006667,
                "answer_id": 57848279,
                "question_id": 57847233,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could pipe the output of jq to `grep` and then to `wc`:\r\n\r\n    curl example.com | jq | grep &#39;&quot;source&quot;: &quot;machine_transcription&quot;&#39; | wc -l\r\n\r\nthis will output the number of lines containing the pattern `&quot;source&quot;: &quot;machine_transcription&quot;`",
                "title": "How do I get a count of fields with a specific value in JSON file with jq?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1568010675,
                "last_edit_date": 1568010675,
                "creation_date": 1568008927,
                "answer_id": 57848563,
                "question_id": 57847233,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "As pointed out in the comments, it&#39;s unclear what you mean by `record` but the following jq-only solution (which assumes the input JSON is an object with a key named &quot;fields&quot; as shown in the question) should get you on your way. Notice that the output is a percentage.\r\n\r\n```\r\ndef sigma( s ): reduce s as $x (0; . + $x);\r\ndef count( s ): sigma(if s then 1 else 0 end);\r\n\r\n.fields\r\n| length as $length\r\n| count( .[]|.transcription.source == &quot;machine_transcription&quot; ) as $count\r\n| if $length &gt; 0 then $count*100/$length else null end\r\n```\r\n",
                "title": "How do I get a count of fields with a specific value in JSON file with jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1568011105,
        "creation_date": 1567996575,
        "last_edit_date": 1568011105,
        "question_id": 57847233,
        "body_markdown": "I would like to get a count of how many times a specific value is listed in JSON file.  My ultimate goal is really to get a percentage.  But, I will start with just getting a count.  I am pretty sure I am making this harder than it really is, but I am new to bash and jq.\r\n\r\n    &quot;fields&quot;: [\r\n            {\r\n              &quot;id&quot;: 1,\r\n              &quot;state&quot;: &quot;complete&quot;,\r\n              &quot;substate&quot;: null,\r\n              &quot;exceptions&quot;: [],\r\n              &quot;name&quot;: &quot;Sender Account Number&quot;,\r\n              &quot;output_name&quot;: null,\r\n              &quot;field_definition_attributes&quot;: {\r\n                &quot;required&quot;: false,\r\n                &quot;data_type&quot;: &quot;Account Number&quot;,\r\n                &quot;multiline&quot;: false,\r\n                &quot;consensus_required&quot;: false,\r\n                &quot;supervision_override&quot;: null\r\n              },\r\n              &quot;transcription&quot;: {\r\n                &quot;raw&quot;: &quot;1685-0441-1&quot;,\r\n                &quot;normalized&quot;: &quot;168504411&quot;,\r\n                &quot;source&quot;: &quot;machine_transcription&quot;,\r\n                &quot;data_deleted&quot;: false,\r\n                &quot;user_transcribed&quot;: null,\r\n                &quot;row_index&quot;: null\r\n              },\r\n              &quot;field_image_url&quot;: &quot;/api/v4/image/be167a88-9d1d-43bc-82b2-3d96d8c06656?start_x=0.3110429607297866&amp;start_y=0.1052441592299208&amp;end_x=0.5696909842243418&amp;end_y=0.16043316955780607&quot;\r\n            },\r\n\r\nThis is an example of my &quot;fields&quot; object in the JSON. I want to get a count of all the records that are &quot;source&quot;: &quot;machine_transcription&quot;,\r\n\r\nI then should be able to calculate a percentage of the total.  ",
        "link": "https://stackoverflow.com/questions/57847233/how-do-i-get-a-count-of-fields-with-a-specific-value-in-json-file-with-jq",
        "title": "How do I get a count of fields with a specific value in JSON file with jq?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1568020104,
                "creation_date": 1568020104,
                "answer_id": 57850933,
                "question_id": 57850797,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You need to use square parens `[..]` instead of `(..)` as reported in the error message. Just do\r\n\r\n    jq --arg key &quot;foo&quot; --arg value &quot;bar&quot; &#39;.[$key] += [$value]&#39;\r\n\r\nThis error line is quite verbose to recommend you the right syntax to use. The emphasis with `#` is mine\r\n\r\n    jq: error: try .[&quot;field&quot;] instead of .field for unusually named fields at &lt;top-level&gt;, line 1\r\n    #              ^^^^^^^^^^^^^  ",
                "title": "Adding values to dynamic keys with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1568023321,
        "creation_date": 1568019593,
        "last_edit_date": 1568023321,
        "question_id": 57850797,
        "body_markdown": "I try to construct a json object with jq. I start with an empty object and want to add keys and values dynamically.\r\n\r\nThis works but the key is not variable. It&#39;s fixed to &quot;foo&quot;:\r\n    \r\n    echo &#39;{&quot;foo&quot;: [&quot;baz&quot;]}&#39; | jq --arg value &quot;bar&quot; &#39;.foo += [$value]&#39;\r\n\r\noutput as expected: \r\n\r\n    {&quot;foo&quot;: [&quot;baz&quot;, &quot;bar&quot;]}\r\n\r\nWhat I actually want do do is something like this:\r\n\r\n    echo &#39;{&quot;foo&quot;: [&quot;baz&quot;]}&#39; | jq --arg key &quot;foo&quot; --arg value &quot;bar&quot; &#39;.($key) += [$value]&#39;\r\n\r\nUnfortunately this does not work. Here is the output:\r\n\r\n    jq: error: syntax error, unexpected &#39;(&#39; (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n\r\n    .($key) += [$value]\r\n\r\n    jq: error: try .[&quot;field&quot;] instead of .field for unusually named fields at &lt;top-level&gt;, line 1:\r\n\r\n    .($key) += [$value]\r\n\r\n    jq: 2 compile errors\r\n\r\nI couldn&#39;t find a solution or figure it out.\r\n\r\nI know that this works: `jq --null-input --arg key foo &#39;{($key): &quot;bar&quot;}&#39;` but it doesn&#39;t solve my problem since I want to append values to existing lists as you can see in the examples. \r\n\r\n",
        "link": "https://stackoverflow.com/questions/57850797/adding-values-to-dynamic-keys-with-jq",
        "title": "Adding values to dynamic keys with jq"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 5351266,
                    "reputation": 73064,
                    "user_id": 4265352,
                    "user_type": "registered",
                    "profile_image": "https://lh4.googleusercontent.com/-lzAUc5pYb24/AAAAAAAAAAI/AAAAAAAAAGQ/q3h7bZUnqrs/s256-rj/photo.jpg",
                    "display_name": "axiac",
                    "link": "https://stackoverflow.com/users/4265352/axiac"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1568036920,
                "post_id": 57854868,
                "comment_id": 102136925,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 15778755,
                    "reputation": 1303,
                    "user_id": 11385808,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/321f8b770bfd0099048493cebba39edd?s=256&d=identicon&r=PG",
                    "display_name": "Dmitry",
                    "link": "https://stackoverflow.com/users/11385808/dmitry"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1568037668,
                "post_id": 57854868,
                "comment_id": 102137398,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "user_type": "does_not_exist",
                    "display_name": "user4918296"
                },
                "reply_to_user": {
                    "account_id": 15778755,
                    "reputation": 1303,
                    "user_id": 11385808,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/321f8b770bfd0099048493cebba39edd?s=256&d=identicon&r=PG",
                    "display_name": "Dmitry",
                    "link": "https://stackoverflow.com/users/11385808/dmitry"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1568040982,
                "post_id": 57854868,
                "comment_id": 102139306,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1568037528,
                "creation_date": 1568037528,
                "answer_id": 57855541,
                "question_id": 57854868,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The `jq` filter you are looking for is:\r\n\r\n    del(.outer[] | select(.inner | map(.value) | sort == [&quot;val1&quot;, &quot;val2&quot;]))\r\n\r\n`.inner | map(.value)` produces an array that contains the values associated to the `value` key from all objects contained by `.inner`.\r\n\r\n`sort` is needed because `==` does a one-to-one comparison of arrays. This way it matches the objects contained in `.inner` no matter their order. Of course, you have to use a sorted array on the right-hand side (i.e. `[&quot;val1&quot;, &quot;val2&quot;]` and not `[&quot;val2&quot;, &quot;val1&quot;]`).\r\n\r\nSee it [in action](https://jqplay.org/s/FDrKj8AIf2).",
                "title": "Delete json array elements based on values of subarray"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1568057842,
                "creation_date": 1568057842,
                "answer_id": 57860272,
                "question_id": 57854868,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is a solution which should work on all versions of jq at least from version 1.3 onwards, and which is readily adapted to take into account additional criteria, as mentioned in the Q:\r\n\r\n```\r\n# A helper function for defining the retention criteria.\r\n# It is assumed that the input is the array to be checked and that\r\n# `match` is already sorted.\r\ndef retain( match ): (map(.value) | sort) != match;\r\n\r\n.outer |= map( select( .inner | retain( [&quot;val1&quot;, &quot;val2&quot;] ) ))\r\n```",
                "title": "Delete json array elements based on values of subarray"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1568057842,
        "creation_date": 1568035099,
        "question_id": 57854868,
        "body_markdown": "I have the following json file which contains this array structure:\r\n\r\n\r\n    {\r\n      &quot;outer&quot;: [\r\n        {\r\n          &quot;inner&quot;: [\r\n            {\r\n              &quot;value&quot;: &quot;val1&quot;\r\n            },\r\n            {\r\n              &quot;value&quot;: &quot;val3&quot;\r\n            }\r\n          ]\r\n        },\r\n        {\r\n          &quot;inner&quot;: [\r\n            {\r\n              &quot;value&quot;: &quot;val2&quot;\r\n            },\r\n            {\r\n              &quot;value&quot;: &quot;val1&quot;\r\n            }\r\n          ]\r\n        },\r\n        {\r\n          &quot;inner&quot;: [\r\n            {\r\n              &quot;value&quot;: &quot;val2&quot;\r\n            },\r\n            {\r\n              &quot;value&quot;: &quot;val1&quot;\r\n            },\r\n            {\r\n              &quot;value&quot;: &quot;val3&quot;\r\n            }\r\n          ]\r\n        }\r\n      ]\r\n    }\r\n\r\nI want to delete the `inner` array from the `outer` array whose elements have specific values and and is of certain length. E.g., if I want to delete the `inner` array which contains values `&quot;val1&quot;` and `&quot;val2&quot;` the result should be:\r\n\r\n\r\n    {\r\n      &quot;outer&quot;: [\r\n        {\r\n          &quot;inner&quot;: [\r\n            {\r\n              &quot;value&quot;: &quot;val1&quot;\r\n            },\r\n            {\r\n              &quot;value&quot;: &quot;val3&quot;\r\n            }\r\n          ]\r\n        },\r\n        {\r\n          &quot;inner&quot;: [\r\n            {\r\n              &quot;value&quot;: &quot;val2&quot;\r\n            },\r\n            {\r\n              &quot;value&quot;: &quot;val1&quot;\r\n            },\r\n            {\r\n              &quot;value&quot;: &quot;val3&quot;\r\n            }\r\n          ]\r\n        }\r\n      ]\r\n    }\r\n\r\n\r\nI have tried\r\n\r\n    jq &#39;del( .outer[]|select(.inner[0].value == &quot;val1&quot;))&#39;\r\n\r\nbut I do not know how to check for the second condition, the length and on top of that the values may appear in any order.\r\n",
        "link": "https://stackoverflow.com/questions/57854868/delete-json-array-elements-based-on-values-of-subarray",
        "title": "Delete json array elements based on values of subarray"
    },
    {
        "tags": [
            "arrays",
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 15778755,
                    "reputation": 1303,
                    "user_id": 11385808,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/321f8b770bfd0099048493cebba39edd?s=256&d=identicon&r=PG",
                    "display_name": "Dmitry",
                    "link": "https://stackoverflow.com/users/11385808/dmitry"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1568066397,
                "post_id": 57858399,
                "comment_id": 102149503,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1568183848,
                "last_edit_date": 1568183848,
                "creation_date": 1568049243,
                "answer_id": 57858455,
                "question_id": 57858399,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Generate objects for each country, and merge them at the end.\r\n```\r\n.data[] | [\r\n  { (.countries[]): .currencies }\r\n] | add\r\n```\r\nOr use this alternative approach with `reduce`:\r\n```\r\n.data[] | reduce { (.countries[]): .currencies } as $f ({}; . + $f)\r\n```",
                "title": "Using jq to show 2nd array for all elements in the first array"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1568183848,
        "creation_date": 1568048923,
        "last_edit_date": 1568049275,
        "question_id": 57858399,
        "body_markdown": "I&#39;m trying to use jq to take 2 arrays and for each element in the first array, show the entire second array.  The input json would look like:\r\n```json\r\n{\r\n  &quot;data&quot;: [\r\n    {\r\n      &quot;countries&quot;: [&quot;GB&quot;, &quot;JE&quot;],\r\n      &quot;currencies&quot;: [&quot;GBP&quot;, &quot;EUR&quot;]\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nThe output json should look like:\r\n```\r\n{\r\n  &quot;GB&quot;: [&quot;GBP&quot;, &quot;EUR&quot;],\r\n  &quot;JE&quot;: [&quot;GBP&quot;, &quot;EUR&quot;]\r\n}\r\n```\r\n\r\nThanks for any help.",
        "link": "https://stackoverflow.com/questions/57858399/using-jq-to-show-2nd-array-for-all-elements-in-the-first-array",
        "title": "Using jq to show 2nd array for all elements in the first array"
    },
    {
        "tags": [
            "json",
            "object",
            "merge",
            "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": 1,
                "creation_date": 1568129156,
                "post_id": 57872562,
                "comment_id": 102172714,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1568214677,
                "last_edit_date": 1592644375,
                "creation_date": 1568129608,
                "answer_id": 57874037,
                "question_id": 57872562,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With the permission of the OP, I&#39;m publishing here an _alternative_ solution for the JSON manipulation in the question, based on a `walk-path` unix utility **[`jtc`](https://github.com/ldn-softdev/jtc)**:\n\nAs I understand the question, it&#39;s required to merge &quot;nicely&quot; records containing `SomeAPIUser` (if the term appears also outside of record, the walk-path could be easily enhanced).  Here is a solution:\n\n    $ &lt;file.json jtc -w&#39;&lt;SomeAPIUser&gt;[-1]&#39; -pmi&#39;&lt;SomeAPIUser&gt;1:[-1]&#39; |\n                 jtc -w&#39;&lt;SomeAPIUser&gt;[-2][:]&lt;q&gt;Q:&#39; -p |\n                 jtc -x&#39;&lt;SomeAPIUser&gt;[-2]&lt;&gt;i:&lt;&gt;f[1]&lt;&gt;F&#39; -y&#39; &#39; -y&#39;[0]&#39; -s\n\nThis solution has three steps:\n\n1\\. `jtc -w&#39;&lt;SomeAPIUser&gt;[-1]&#39; -pmi&#39;&lt;SomeAPIUser&gt;1:[-1]&#39;`  \n\\- here the record with the first occurrence of `SomeAPIUser` is merged (recursively) with all the others (even if there are more than one)\n\n2\\. `jtc -w&#39;&lt;SomeAPIUser&gt;[-2][:]&lt;q&gt;Q:&#39; -p`  \n\\- this step removes all the duplicate records that resulted from the merging in step 1.\n\n3\\. `jtc -x&#39;&lt;SomeAPIUser&gt;[-2]&lt;&gt;i:&lt;&gt;f[1]&lt;&gt;F&#39; -y&#39; &#39; -y&#39;[0]&#39; -s`  \n\\- in this final step, all arrays with a single JSON element (resulting from step 2), e.g.: `Effect&quot;: [ &quot;Allow&quot; ]`, are converted into non-array records, like `Effect&quot;: &quot;Allow&quot;`\n\n## UPDATE:\n\nwith the latest version of `jtc`, this solution provides a more robust behavior:\n\n    $ &lt;file.json jtc -w&#39;[Sid]:&lt;SomeAPIUser&gt;[-1]&#39; -pmi&#39;[Sid]:&lt;SomeAPIUser&gt;1:[-1]&#39; |\n                 jtc -w&#39;[Sid]:&lt;&gt;i&gt;SomeAPIUser&lt;[-2]&lt;&gt;i:&gt;&lt;Q:&#39; -p |\n                 jtc -x&#39;[Sid]:&lt;&gt;i&gt;SomeAPIUser&lt;[-2]&lt;&gt;i:&lt;&gt;f[1]&lt;&gt;F&#39; -y&#39; &#39; -y&#39;[0]&#39; -s\n\n\\- it will confine searches of `SomeAPIUser` only to `&quot;Sid&quot;` labels (so it&#39;s resistant to case when clashing `SomeAPIUser` may appear with other labels); plus, it will work also correctly when only one (or none) record containing `&quot;Sid&quot;:&quot;SomeAPIUser&quot;` is present in source JSON\n\nPS. I&#39;m the developer of the unix **[`jtc`](https://github.com/ldn-softdev/jtc)** tool for JSON manipulations.\n\n",
                "title": "jq combine duplicates with nested objects"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1568179805,
                "last_edit_date": 1568179805,
                "creation_date": 1568138117,
                "answer_id": 57876028,
                "question_id": 57872562,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Since no specific requirements regarding the merge algorithm have\r\nbeen given, this response will focus instead on an architecture for\r\nsolving the class of problems suggested by the question.\r\n\r\nFor the sake of illustration and specificity, though, a commutative, pairwise merge function will be defined as follows:\r\n\r\n```\r\ndef merge(a; b):\r\n  def merge_objects($x;$y):\r\n    (($x|keys_unsorted) + ($y|keys_unsorted) | unique) as $keys\r\n    | reduce $keys[] as $k (null; . + {($k): merge($x[$k]; $y[$k])});\r\n  if a == b then a\r\n  elif a == null then b\r\n  elif b == null then a\r\n  elif (a|type) | (. == (b|type)) and (. == &quot;object&quot;) \r\n    then merge_objects(a;b)\r\n  elif (a|type == &quot;array&quot;) and (b|type) == &quot;array&quot;\r\n    then (a + b) | unique\r\n  elif (a|type == &quot;array&quot;) then a + [b] | unique\r\n  elif (b|type == &quot;array&quot;) then [a] + b | unique\r\n  else [a, b] | unique\r\n  end ;\r\n```\r\n\r\nWith any such definition, we may now proceed to an answer:\r\n```\r\n# input is assumed to be an array of objects to be merged based on the filter f\r\ndef merge(f):\r\n  def merge: reduce .[] as $object (null; merge(.; $object));\r\n  group_by(f)\r\n  | map(merge) ;\r\n\r\n.Statement |= merge(.Sid)\r\n```",
                "title": "jq combine duplicates with nested objects"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1578471721,
        "creation_date": 1568124400,
        "last_edit_date": 1578471721,
        "question_id": 57872562,
        "body_markdown": "I&#39;ve scoured similar questions/answers trying to solve this issue over the past few days and I believe my amateur `jq` skills are preventing me from solving this. \r\n\r\nI&#39;m trying to merge duplicate entries; for example... I&#39;d like:\r\n\r\n    {\r\n      &quot;Version&quot;: &quot;2008-10-17&quot;,\r\n      &quot;Id&quot;: &quot;SomeBucketPolicy&quot;,\r\n      &quot;Statement&quot;: [\r\n        {\r\n          &quot;Sid&quot;: &quot;Stmt1234567890987&quot;,\r\n          &quot;Effect&quot;: &quot;Allow&quot;,\r\n          &quot;Principal&quot;: {\r\n            &quot;AWS&quot;: &quot;arn:aws:iam::726481726312:root&quot;\r\n          },\r\n          &quot;Action&quot;: [\r\n            &quot;s3:GetBucketAcl&quot;,\r\n            &quot;s3:GetBucketPolicy&quot;\r\n          ],\r\n          &quot;Resource&quot;: &quot;arn:aws:s3:::it-lab-test&quot;\r\n        },\r\n        {\r\n          &quot;Sid&quot;: &quot;Stmt3423424566754&quot;,\r\n          &quot;Effect&quot;: &quot;Allow&quot;,\r\n          &quot;Principal&quot;: {\r\n            &quot;AWS&quot;: &quot;arn:aws:iam::726481726312:root&quot;\r\n          },\r\n          &quot;Action&quot;: &quot;s3:PutObject&quot;,\r\n          &quot;Resource&quot;: &quot;arn:aws:s3:::it-lab-test/*&quot;\r\n        },\r\n        {\r\n          &quot;Sid&quot;: &quot;SomeAPIUser&quot;,\r\n          &quot;Effect&quot;: &quot;Allow&quot;,\r\n          &quot;Principal&quot;: {\r\n            &quot;AWS&quot;: &quot;arn:aws:iam::536415397313:user/SomeAPIUser&quot;\r\n          },\r\n          &quot;Action&quot;: [\r\n            &quot;s3:GetObject&quot;,\r\n            &quot;s3:GetObjectVersion&quot;,\r\n            &quot;s3:GetObjectRetention&quot;\r\n          ],\r\n          &quot;Resource&quot;: &quot;arn:aws:s3:::it-lab-test/*&quot;\r\n        },\r\n        {\r\n          &quot;Sid&quot;: &quot;SomeAPIUser&quot;,\r\n          &quot;Effect&quot;: &quot;Allow&quot;,\r\n          &quot;Principal&quot;: {\r\n            &quot;AWS&quot;: &quot;arn:aws:iam::536415397313:user/SomeAPIUser&quot;\r\n          },\r\n          &quot;Action&quot;: [\r\n            &quot;s3:GetObject&quot;,\r\n            &quot;s3:GetObjectVersion&quot;,\r\n            &quot;s3:GetObjectTagging&quot;\r\n          ],\r\n          &quot;Resource&quot;: [\r\n            &quot;arn:aws:s3:::it-lab-test/*&quot;,\r\n            &quot;arn:aws:s3:::another-test-bucket/*&quot;,\r\n            &quot;arn:aws:s3:::someother-test-bucket/*&quot;\r\n          ]\r\n        }\r\n      ]\r\n    }\r\n\r\n...to become:\r\n\r\n    {\r\n      &quot;Version&quot;: &quot;2008-10-17&quot;,\r\n      &quot;Id&quot;: &quot;SomeBucketPolicy&quot;,\r\n      &quot;Statement&quot;: [\r\n        {\r\n          &quot;Sid&quot;: &quot;Stmt1234567890987&quot;,\r\n          &quot;Effect&quot;: &quot;Allow&quot;,\r\n          &quot;Principal&quot;: {\r\n            &quot;AWS&quot;: &quot;arn:aws:iam::726481726312:root&quot;\r\n          },\r\n          &quot;Action&quot;: [\r\n            &quot;s3:GetBucketAcl&quot;,\r\n            &quot;s3:GetBucketPolicy&quot;\r\n          ],\r\n          &quot;Resource&quot;: &quot;arn:aws:s3:::it-lab-test&quot;\r\n        },\r\n        {\r\n          &quot;Sid&quot;: &quot;Stmt3423424566754&quot;,\r\n          &quot;Effect&quot;: &quot;Allow&quot;,\r\n          &quot;Principal&quot;: {\r\n            &quot;AWS&quot;: &quot;arn:aws:iam::726481726312:root&quot;\r\n          },\r\n          &quot;Action&quot;: &quot;s3:PutObject&quot;,\r\n          &quot;Resource&quot;: &quot;arn:aws:s3:::it-lab-test/*&quot;\r\n        },\r\n        {\r\n          &quot;Sid&quot;: &quot;SomeAPIUser&quot;,\r\n          &quot;Effect&quot;: &quot;Allow&quot;,\r\n          &quot;Principal&quot;: {\r\n            &quot;AWS&quot;: &quot;arn:aws:iam::536415397313:user/SomeAPIUser&quot;\r\n          },\r\n          &quot;Action&quot;: [\r\n            &quot;s3:GetObject&quot;,\r\n            &quot;s3:GetObjectVersion&quot;,\r\n            &quot;s3:GetObjectRetention&quot;,\r\n            &quot;s3:GetObjectTagging&quot;\r\n          ],\r\n          &quot;Resource&quot;: [\r\n            &quot;arn:aws:s3:::it-lab-test/*&quot;,\r\n            &quot;arn:aws:s3:::another-test-bucket/*&quot;,\r\n            &quot;arn:aws:s3:::someother-test-bucket/*&quot;\r\n          ]\r\n        }\r\n      ]\r\n    }\r\n\r\nI&#39;d like it to be as flexible and forgiving as possible; if arrays need to be created for multiple entries, if there are duplicates within the nested objects they are merged properly as well, etc.\r\n\r\nI&#39;ve tried a variety of approaches, using a multitude of examples/techniques (grouping, mapping, using functions), but I can&#39;t come up with the results I&#39;m looking for (I&#39;m either left with the duplicate or the data is no longer present and not merged). The closest I&#39;ve come has been through playing around with this solution https://stackoverflow.com/questions/53409951/remove-duplicate-values-from-json-with-jq ... but having issues with dealing with multiple objects nested within the blocks. Any help would be appreciated in ",
        "link": "https://stackoverflow.com/questions/57872562/jq-combine-duplicates-with-nested-objects",
        "title": "jq combine duplicates with nested objects"
    },
    {
        "tags": [
            "arrays",
            "json",
            "batch-processing",
            "jq",
            "conditional-operator"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 15778755,
                    "reputation": 1303,
                    "user_id": 11385808,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/321f8b770bfd0099048493cebba39edd?s=256&d=identicon&r=PG",
                    "display_name": "Dmitry",
                    "link": "https://stackoverflow.com/users/11385808/dmitry"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1568221808,
                "post_id": 57893412,
                "comment_id": 102209149,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1568235913,
                "last_edit_date": 1568235913,
                "creation_date": 1568219982,
                "answer_id": 57893504,
                "question_id": 57893412,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You don&#39;t need regex for this particular case, use `startswith`:\r\n``` lang-none\r\nfirst(.arr[] | select(startswith(&quot;foo&quot;))) // false\r\n```\r\nIf you need all matching elements:\r\n``` lang-none\r\n(.arr[] | select(startswith(&quot;foo&quot;))) // false\r\n```",
                "title": "Check for a random element in an array and return it if true"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1568264992,
        "creation_date": 1568219629,
        "last_edit_date": 1568264992,
        "question_id": 57893412,
        "body_markdown": "I&#39;ve got several arrays of varying length that may contain an element which begins with `foo` (the name length varying as well), if this element exists I want to return it, e.g. `foo-f-o-o`.\r\n\r\nI know how to check for its existence, I successfully tested in\r\n\r\n    {\r\n        &quot;arr&quot;: [\r\n            &quot;foo-f-o-o&quot;, &quot;bar&quot;, &quot;baz&quot;, &quot;qux&quot;, &quot;quux&quot;, &quot;corge&quot;, &quot;grault&quot;\r\n        ]\r\n    }\r\n\r\n&lt;!-- end snippet --&gt;\r\n\r\nwith the command `type file.json | jq &quot;.arr|contains([\\&quot;foo\\&quot;])&quot;` and I correctly received `true`.\r\n\r\nHowever, I&#39;m looking for these steps:\r\n\r\n 1. Detect if an element `foo*` exists\r\n 2. If *yes*, return that element&#39;s name, in the given case: `foo-f-o-o`\r\n 3. If *not*, return `false`\r\n\r\nThe element `foo.*` could be at any position of the array, that means something like `jq -r &quot;.arr|.[0]&quot;` is not an option here.\r\n\r\nIs there a way to apply a regex like `/^foo.*/` in jq for the matching value?",
        "link": "https://stackoverflow.com/questions/57893412/check-for-a-random-element-in-an-array-and-return-it-if-true",
        "title": "Check for a random element in an array and return it if true"
    },
    {
        "tags": [
            "linux",
            "bash",
            "awk",
            "command-line",
            "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": 1568315233,
                "post_id": 57913058,
                "comment_id": 102245334,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4741979,
                    "reputation": 31542,
                    "user_id": 3834415,
                    "user_type": "registered",
                    "accept_rate": 78,
                    "profile_image": "https://i.sstatic.net/jKHGm.jpg?s=256",
                    "display_name": "Chris",
                    "link": "https://stackoverflow.com/users/3834415/chris"
                },
                "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": 1568315403,
                "post_id": 57913058,
                "comment_id": 102245388,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 19343,
                    "reputation": 67989,
                    "user_id": 45249,
                    "user_type": "registered",
                    "accept_rate": 75,
                    "profile_image": "https://www.gravatar.com/avatar/81039d357ce18bee9dd8fac6c1c56290?s=256&d=identicon&r=PG",
                    "display_name": "mouviciel",
                    "link": "https://stackoverflow.com/users/45249/mouviciel"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1568315531,
                "post_id": 57913058,
                "comment_id": 102245440,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4741979,
                    "reputation": 31542,
                    "user_id": 3834415,
                    "user_type": "registered",
                    "accept_rate": 78,
                    "profile_image": "https://i.sstatic.net/jKHGm.jpg?s=256",
                    "display_name": "Chris",
                    "link": "https://stackoverflow.com/users/3834415/chris"
                },
                "reply_to_user": {
                    "account_id": 19343,
                    "reputation": 67989,
                    "user_id": 45249,
                    "user_type": "registered",
                    "accept_rate": 75,
                    "profile_image": "https://www.gravatar.com/avatar/81039d357ce18bee9dd8fac6c1c56290?s=256&d=identicon&r=PG",
                    "display_name": "mouviciel",
                    "link": "https://stackoverflow.com/users/45249/mouviciel"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1568315569,
                "post_id": 57913058,
                "comment_id": 102245455,
                "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": 1568334782,
                "post_id": 57913058,
                "comment_id": 102250420,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1568321614,
                "last_edit_date": 1568321614,
                "creation_date": 1568320014,
                "answer_id": 57914062,
                "question_id": 57913058,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The following might count as trivial but it does not preserve the precision of the numbers.  It assumes the separator is the regex &quot; +&quot;, but you could easily change that, e.g. to &quot;\\t&quot; if the value separator is a tab:\r\n\r\n    jq -n -R &#39;[inputs | [splits(&quot; +&quot;) | select(length&gt;0)]]\r\n      | transpose | map({(.[0]): .[1]|tonumber}) | add&#39;\r\n\r\n## Handling multiple data rows\r\nThe following assumes a `jq -nR` invocation:\r\n\r\n```\r\ndef zip(headers):\r\n  . as $in\r\n  | reduce range(0; headers|length) as $i ({}; .[headers[$i]] = ($in[$i]) );\r\n\r\ndef s2a: [splits(&quot; +&quot;) | select(length&gt;0)];\r\n\r\n(input | s2a) as $h\r\n| inputs | s2a | map(tonumber) | zip($h)\r\n```",
                "title": "How to convert columnar labeled data to json using Bash?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1568328340,
        "creation_date": 1568314913,
        "last_edit_date": 1568328340,
        "question_id": 57913058,
        "body_markdown": "Suppose I have the following stdout output from an expression\r\n\r\n```\r\n Min 1st_Qu Median Mean 3rd_Qu Max NAs \r\n  1.000 1.000 2.000 1.875 2.250 3.000       1 \r\n```\r\n\r\nAnd the goal is: \r\n```\r\n{ &quot;Min&quot;:1.0, &quot;1st_Qu&quot;:1.0, ..., &quot;NAs&quot;:1 }\r\n```\r\n\r\nIs there a **trivial** way to do this with bash? (also trying to limit dependencies, and would prefer to just cherry pick what I need using awk over adding any non-native linux dependencies). ",
        "link": "https://stackoverflow.com/questions/57913058/how-to-convert-columnar-labeled-data-to-json-using-bash",
        "title": "How to convert columnar labeled data to json using Bash?"
    },
    {
        "tags": [
            "json",
            "key",
            "special-characters",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1568357909,
                "creation_date": 1568357909,
                "answer_id": 57918697,
                "question_id": 57918504,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use [generic object index](https://stedolan.github.io/jq/manual/#GenericObjectIndex:.[&lt;string&gt;]) syntax, e.g:\r\n```\r\n.[&quot;stat.taco&quot;]\r\n```",
                "title": "Issues with JSON format while using jq commandline processor"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1568396008,
                "creation_date": 1568396008,
                "answer_id": 57928067,
                "question_id": 57918504,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you use the `generic object syntax`, e.g. `.[&quot;stat.taco&quot;]`, then chaining is done either using pipes as usual, or without the dot, e.g.\r\n\r\n    .[&quot;stat.taco&quot;][&quot;inner.key&quot;]\r\n\r\nIf your jq is sufficiently recent, then you can use the chained-dot notation by quoting the keys with special characters, e.g.\r\n\r\n    .&quot;stat.taco&quot;.&quot;inner.key&quot;\r\n\r\nYou can also mix-and-match except that expressions such as:  `.[&quot;stat.taco&quot;].[&quot;inner.key&quot;]` are not (as of jq 1.6) supported.\r\n",
                "title": "Issues with JSON format while using jq commandline processor"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1568396152,
        "creation_date": 1568356914,
        "last_edit_date": 1568396152,
        "question_id": 57918504,
        "body_markdown": "I am trying to use the jq command line JSON processor https://shapeshed.com/jq-json/ (which works great) to process a JSON file that seems to have been made using some poor choices.\r\n\r\nNormally your id and value in the JSON file would not contain any periods such as:\r\n\r\n    {&quot;id&quot;:&quot;d9s7g9df7sd9&quot;,&quot;name&quot;:&quot;Tacos&quot;}\r\n\r\nTo get Tacos from the file you would do the following in bash:\r\n\r\n    echo $json | jq -r &#39;.name&#39;\r\n\r\nThis will give you Tacos (There may be some extra code missing from that example but you get the point.)\r\n\r\nI have a JSON file that looks like this:\r\n\r\n    {&quot;stat.blah&quot;:123,&quot;stat.taco&quot;:495,&quot;stat.yum... etc.\r\n\r\nNotice how they decided to use a period in the identifying field associated with the value? This makes using jq very difficult because it associates the period as a separator to dig down into child values in the JSON. Sure, I could first load my file, replace all &quot;.&quot; with &quot;_&quot; and that would fix the problem, but this seems like a really dumb and hackish solution. I have no way to change how the initial JSON file is generated. I just have to deal with it. Is there a way in bash I can do some special escape to make it ignore the period?\r\n\r\nThanks",
        "link": "https://stackoverflow.com/questions/57918504/issues-with-json-format-while-using-jq-commandline-processor",
        "title": "Issues with JSON format while using jq commandline processor"
    },
    {
        "tags": [
            "json",
            "math",
            "vector",
            "jq",
            "vector-multiplication"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1568359697,
                "creation_date": 1568359697,
                "answer_id": 57919116,
                "question_id": 57918971,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "    jq &#39;. | transpose | map(reduce .[] as $item (1; . * $item))&#39; &lt;&lt;&lt; &quot;[[1,2],[3,4]]&quot;\r\n\r\nTranspose gives us the elements that need to be multiplied together: `[[1, 3], [2, 4]]`. Then we can map each subarray to its product by using reduce.\r\n\r\nThe object version is just a bit different, as we need to get those values off of properties:\r\n\r\n    jq &#39;[.[]] | transpose | map(reduce .[] as $item (1; . * $item))&#39; &lt;&lt;&lt; &quot;{\\&quot;a\\&quot;:[1,2], \\&quot;b\\&quot;:[3,4]}&quot;",
                "title": "Vector math arithmetic operations in jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1568368083,
                "last_edit_date": 1568368083,
                "creation_date": 1568365637,
                "answer_id": 57920551,
                "question_id": 57918971,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "For this type of problem, it makes sense to define a generic function:\r\n```\r\n# Input is assumed to be an array of two numeric arrays of the same length\r\ndef pairwise: transpose | map(.[0] * .[1]);\r\n```\r\n\r\nWe can now easily use this in a variety of ways:\r\n\r\n    [[1,2],[3,4]] | pairwise\r\n\r\n    {&quot;a&quot;:[1,2], &quot;b&quot;:[3,4]} | [.a,.b] | pairwise\r\n\r\n    {&quot;a&quot;:[1,2], &quot;b&quot;:[3,4]} | [.[]] | pairwise\r\n\r\nThe result in each of these cases is of course `[3,8]`.\r\n\r\n\r\n## Efficiency\r\nFor very large inputs, it might be worthwhile avoiding `transpose`:\r\n```\r\ndef pairwise:\r\n   .[0] as $x | .[1] as $y \r\n   | reduce range(0; $x|length) as $i ([]; . + [$x[$i] * $y[$i]]);\r\n```\r\n\r\nTypically with vectors one is interested in the inner product, which for efficiency would best be defined directly, e.g. as follows:\r\n\r\n    def inner($a; $b):\r\n      reduce range(0;$a|length) as $i (0; . + $a[$i]*$b[$i]);\r\n",
                "title": "Vector math arithmetic operations in jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1568368146,
        "creation_date": 1568359027,
        "last_edit_date": 1568368146,
        "question_id": 57918971,
        "body_markdown": "I&#39;d like to perform vector math operations on a json array that stores numbers. In short how can we achieve one to one arithmetic operations by using jq?\r\n\r\nI tried something with &#39;map&#39; filter however could not achieved what I expect.\r\n\r\n```\r\njq &#39;map(one-to-one)&#39; &lt;&lt;&lt; &quot;{\\&quot;a\\&quot;:[1,2], \\&quot;b\\&quot;:[3,4]}&quot;\r\n```\r\nor\r\n```\r\njq &#39;map(one-to-one)&#39; &lt;&lt;&lt; &quot;[[1,2],[3,4]]&quot;\r\n```\r\n\r\n\r\nshould produce\r\n```\r\n[3,8]\r\n```",
        "link": "https://stackoverflow.com/questions/57918971/vector-math-arithmetic-operations-in-jq",
        "title": "Vector math arithmetic operations in jq"
    },
    {
        "tags": [
            "json",
            "jq",
            "lookup"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 904170,
                    "reputation": 5454,
                    "user_id": 939457,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/56f2edd7d1cc2cf254fd6a4674c2538b?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Sorin",
                    "link": "https://stackoverflow.com/users/939457/sorin"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1568483476,
                "post_id": 57935298,
                "comment_id": 102291634,
                "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": 1568493438,
                "post_id": 57935298,
                "comment_id": 102293588,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 15778755,
                    "reputation": 1303,
                    "user_id": 11385808,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/321f8b770bfd0099048493cebba39edd?s=256&d=identicon&r=PG",
                    "display_name": "Dmitry",
                    "link": "https://stackoverflow.com/users/11385808/dmitry"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1568622622,
                "post_id": 57935298,
                "comment_id": 102318180,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1568463815,
                "last_edit_date": 1568463815,
                "creation_date": 1568462870,
                "answer_id": 57935340,
                "question_id": 57935298,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use select:\r\n\r\n    jq -r  --arg query Burrito &#39;.[] | select( .name == $query ) | .uuid &#39; tst.json\r\n",
                "title": "Search and extract value using JQ command line processor"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -2,
        "last_activity_date": 1597209396,
        "creation_date": 1568462467,
        "last_edit_date": 1597209396,
        "question_id": 57935298,
        "body_markdown": "I have a JSON file very similar to the following:\r\n\r\n    [\r\n      {\r\n        &quot;uuid&quot;: &quot;832390ed-58ed-4338-bf97-eb42f123d9f3&quot;,\r\n        &quot;name&quot;: &quot;Nacho&quot;\r\n      },\r\n      {\r\n        &quot;uuid&quot;: &quot;5b55ea5e-96f4-48d3-a258-75e152d8236a&quot;,\r\n        &quot;name&quot;: &quot;Taco&quot;\r\n      },\r\n      {\r\n        &quot;uuid&quot;: &quot;a68f5249-828c-4265-9317-fc902b0d65b9&quot;,\r\n        &quot;name&quot;: &quot;Burrito&quot;\r\n      }\r\n    ]\r\n\r\nI am trying to figure out how to use the JQ command line processor to first find the UUID that I input and based on that output the name of the associated item. So for example, if I input UUID a68f5249-828c-4265-9317-fc902b0d65b9 it should search the JSON file, find the matching UUID and then return the name Burrito. I am doing this in Bash. I realize it may require some outside logic in addition to JQ. I will keep thinking about it and put an update here in a bit. I know I could do it in an overly complicated way, but I know there is probably a really simple JQ method of doing this in one or two lines. Please help me.\r\n\r\nhttps://shapeshed.com/jq-json/#how-to-find-a-key-and-value",
        "link": "https://stackoverflow.com/questions/57935298/search-and-extract-value-using-jq-command-line-processor",
        "title": "Search and extract value using JQ command line processor"
    },
    {
        "tags": [
            "json",
            "bash",
            "escaping",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1568561335,
                "last_edit_date": 1568561335,
                "creation_date": 1568555609,
                "answer_id": 57944753,
                "question_id": 57944483,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use the --slurp/-s command-line option.\r\n\r\n```\r\n$ printf &quot;\\&quot;aaa\\&quot;\\nbbb&quot;| jq -asR \r\n&quot;\\&quot;aaa\\&quot;\\nbbb&quot;\r\n```\r\n\r\nOf course in this case, the `-a` option makes no difference.",
                "title": "Escaping multi-line text with &quot;jq&quot;"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1568561335,
        "creation_date": 1568553492,
        "last_edit_date": 1568554646,
        "question_id": 57944483,
        "body_markdown": "Suppose, I need to escape a multi-line text:\r\n\r\n   &lt;!-- language: lang-none --&gt;\r\n\r\n    printf &quot;\\&quot;aaa\\&quot;\\nbbb&quot;  \r\n    &quot;aaa&quot;\r\n    bbb\r\n\r\nI&#39;m trying to escape it with `jq -aR`:\r\n\r\n   &lt;!-- language: lang-none --&gt;\r\n\r\n    printf &quot;\\&quot;aaa\\&quot;\\nbbb&quot;| jq -aR \r\n    &quot;\\&quot;aaa\\&quot;&quot;\r\n    &quot;bbb&quot;\r\n\r\nUnfortunately it&#39;s not what I want. I want to get `&quot;\\&quot;aaa\\&quot;\\nbbb&quot;` instead.  \r\nHow can I escape `&quot;aaa&quot;\\nbbb` with `jq` properly ?",
        "link": "https://stackoverflow.com/questions/57944483/escaping-multi-line-text-with-jq",
        "title": "Escaping multi-line text with &quot;jq&quot;"
    },
    {
        "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": 2,
                "creation_date": 1568590900,
                "post_id": 57945921,
                "comment_id": 102310788,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8273870,
                    "reputation": 11747,
                    "user_id": 6220759,
                    "user_type": "registered",
                    "accept_rate": 83,
                    "profile_image": "https://i.sstatic.net/0yuve.jpg?s=256",
                    "display_name": "Josh Friedlander",
                    "link": "https://stackoverflow.com/users/6220759/josh-friedlander"
                },
                "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": 1568621076,
                "post_id": 57945921,
                "comment_id": 102317457,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 15778755,
                    "reputation": 1303,
                    "user_id": 11385808,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/321f8b770bfd0099048493cebba39edd?s=256&d=identicon&r=PG",
                    "display_name": "Dmitry",
                    "link": "https://stackoverflow.com/users/11385808/dmitry"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1568623221,
                "post_id": 57945921,
                "comment_id": 102318476,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1568579068,
                "last_edit_date": 1568579068,
                "creation_date": 1568572117,
                "answer_id": 57947069,
                "question_id": 57945921,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; Cannot index object with number\r\n\r\nThis error message says it all, you can&#39;t index objects with numbers. If you want to get the value of `by` field, you need to do\r\n```\r\njq &#39;.by&#39; file\r\n```\r\n\r\n---\r\nWrt\r\n&gt; `echo 8863.json | jq &#39;.[0]&#39;` gives me `parse error: Invalid numeric literal at line 2, column 0.`\r\n\r\nIt&#39;s normal since you didn&#39;t specify -R/--raw-input flag, and so jq sees the shell string `8863.json` as a JSON string, and one cannot apply array indexing to JSON strings. (To get the first character as a string, you&#39;d write `.[0:1]`.)\r\n\r\n---\r\nIf your input file consists of several separate entities, to get the first one:\r\n```\r\njq -n &#39;input&#39; file\r\n```\r\nor,\r\n```\r\njq -n &#39;first(inputs)&#39; file\r\n```\r\nTo get nth (let&#39;s say 5th for example):\r\n```\r\njq -n &#39;nth(5; inputs)&#39; file\r\n```",
                "title": "Retrieving the first entity out of several ones"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1568688438,
                "last_edit_date": 1568688438,
                "creation_date": 1568624906,
                "answer_id": 57953612,
                "question_id": 57945921,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; a large JSON file will contain many objects, each of which is quite big, and I&#39;d like to view the first complete object, to see which fields exist, what types, how much nesting, etc.\r\n\r\nAs implied in @OguzIsmail&#39;s response, there are important differences between:\r\n\r\n    - a JSON file (i.e, a file containing exactly one JSON entity);\r\n    - a file containing a sequence (i.e., stream) of JSON entities; \r\n    - a file containing an array of JSON entities.\r\n\r\nIn the first two cases, you can write `jq -n input` to select the first entity, and in the case of an array of entities, `jq .[0]` will suffice.\r\n\r\n(In JSON-speak, a &quot;JSON object&quot; is a kind of dictionary, and is not to be confused with JSON entities in general.)\r\n\r\nIf you have a bunch of JSON objects (whether as a stream or array or whatever), just looking at the first often doesn&#39;t really give an accurate picture of all them.  For getting a bird&#39;s eye view of a bunch of objects, using a &quot;schema inference engine&quot; is often the way to go.  For this purpose, you might like to consider my `schema.jq` schema inference engine.  It&#39;s usually very simple to use but of course how you use it will depend on whether you have a stream or array of JSON entities. For basic details, see https://gist.github.com/pkoppstein/a5abb4ebef3b0f72a6ed; for related topics (e.g. verification), see the entry for JESS at https://github.com/stedolan/jq/wiki/Modules\r\n\r\n\r\nPlease note that `schema.jq` infers a structural schema that mirrors the entities under consideration.  Such structural schemas have little in common with `JSON Schema` schemas, which you might also like to consider.",
                "title": "Retrieving the first entity out of several ones"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1568710968,
        "creation_date": 1568563987,
        "last_edit_date": 1568710968,
        "question_id": 57945921,
        "body_markdown": "I am a rank beginner with `jq`, and I&#39;ve been going through the tutorial, but I think there is a conceptual difference I don&#39;t understand. A common problem I encounter is that a large JSON file will contain many objects, each of which is quite big, and I&#39;d like to view the first complete object, to see which fields exist, what types, how much nesting, etc.\r\n\r\nIn the [tutorial](https://stedolan.github.io/jq/tutorial/), they do this:\r\n\r\n    # We can use jq to extract just the first commit.\r\n    $ curl &#39;https://api.github.com/repos/stedolan/jq/commits?per_page=5&#39; | jq &#39;.[0]&#39;  \r\n\r\nHere is an example with one object - here, I&#39;d like to return the whole array (just like `my_array=[&#39;foo&#39;]; my_array[0]` would return `foo` in Python). \r\n\r\n    wget https://hacker-news.firebaseio.com/v0/item/8863.json\r\n\r\nI can access and pretty-print the whole thing with `.`\r\n\r\n    $ cat 8863.json | jq &#39;.&#39;\r\n    $\r\n    {\r\n      &quot;by&quot;: &quot;dhouston&quot;,\r\n      &quot;descendants&quot;: 71,\r\n      &quot;id&quot;: 8863,\r\n      &quot;kids&quot;: [\r\n        9224,\r\n         ...\r\n        8876\r\n      ],\r\n      &quot;score&quot;: 104,\r\n      &quot;time&quot;: 1175714200,\r\n      &quot;title&quot;: &quot;My YC app: Dropbox - Throw away your USB drive&quot;,\r\n      &quot;type&quot;: &quot;story&quot;,\r\n      &quot;url&quot;: &quot;http://www.getdropbox.com/u/2/screencast.html&quot;\r\n    }\r\n\r\nBut trying to get the first element fails:\r\n\r\n    $ cat 8863.json| jq &#39;.[0]&#39; \r\n    $ jq: error (at &lt;stdin&gt;:0): Cannot index object with number\r\n\r\nI get the same error `jq &#39;.[0]&#39; 8863.json`, but strangely `echo 8863.json | jq &#39;.[0]&#39;` gives me `parse error: Invalid numeric literal at line 2, column 0`. What is the difference? Also, is this not the correct way to get the zeroth member of the JSON?\r\n\r\nI&#39;ve looked at other SO posts with this error message and at the manual, but I&#39;m still confused. I think of the file as an _array_ of JSON objects, and I&#39;d like to get the first. But it looks like `jq` works with something called a &quot;stream&quot;, and does operations on all of it (say, return one given field from every object).\r\n\r\n## Clarification:\r\n\r\nLet&#39;s say I have 2 objects in my JSON:\r\n\r\n    {\r\n      &quot;by&quot;: &quot;pg&quot;,\r\n      &quot;id&quot;: 160705,\r\n      &quot;poll&quot;: 160704,\r\n      &quot;score&quot;: 335,\r\n      &quot;text&quot;: &quot;Yes, ban them; I&#39;m tired of seeing Valleywag stories on News.YC.&quot;,\r\n      &quot;time&quot;: 1207886576,\r\n      &quot;type&quot;: &quot;pollopt&quot;\r\n    }\r\n    {\r\n      &quot;by&quot;: &quot;dpapathanasiou&quot;,\r\n      &quot;id&quot;: 16070,\r\n      &quot;kids&quot;: [\r\n        16078\r\n      ],\r\n      &quot;parent&quot;: 16069,\r\n      &quot;text&quot;: &quot;Dividends don&#39;t mean that much: Microsoft in its dominant years (when they had 40%-plus margins and were raking in the cash) never paid a dividend (they did so only recently).&quot;,\r\n      &quot;time&quot;: 1177355133,\r\n      &quot;type&quot;: &quot;comment&quot;\r\n    }\r\n\r\nHow would I get the entire first object (lines 1-9) with `jq`?",
        "link": "https://stackoverflow.com/questions/57945921/retrieving-the-first-entity-out-of-several-ones",
        "title": "Retrieving the first entity out of several ones"
    }
]