[
    {
        "tags": [
            "json",
            "linux",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1533506302,
                "last_edit_date": 1533506302,
                "creation_date": 1533401057,
                "answer_id": 51687657,
                "question_id": 51684565,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "    jq &#39;\r\n    ([.[] | { (.filename): {(.dir): true} }] | reduce .[] as $item ({}; . * $item)) as $seen |\r\n    map(\r\n      if $seen[.filename][&quot;foo&quot;] and $seen[.filename][&quot;bar&quot;] then\r\n        .type = 2\r\n      elif $seen[.filename][&quot;bar&quot;] then\r\n        .type = 1\r\n      else\r\n        .type = 0\r\n      end\r\n    )\r\n    &#39;\r\n\r\n---\r\n\r\nIf it helps in understanding how this works -- `$seen` has a value that looks like the following:\r\n\r\n    {\r\n      &quot;a&quot;: {\r\n        &quot;foo&quot;: true,\r\n        &quot;bar&quot;: true\r\n      },\r\n      &quot;b&quot;: {\r\n        &quot;foo&quot;: true\r\n      },\r\n      &quot;c&quot;: {\r\n        &quot;bar&quot;: true\r\n      }\r\n    }\r\n\r\n...thus giving us easy access to look at which dir entries a given filename has ever been seen with.",
                "title": "How set a JSON value based on a second value and also number of occurrences of a third value"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1533402856,
                "last_edit_date": 1533402856,
                "creation_date": 1533401916,
                "answer_id": 51687781,
                "question_id": 51684565,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "One approach would be to use `group_by`.  In the following, `group_by` is used naively, so the ordering of the final results in the array is determined by .filename; if that is unsatisfactory, one could use the same technique to construct a lookup table, which would then be used against the original array.\r\n\r\n    [group_by(.filename)[]\r\n     | (map(.dir) \r\n        | unique\r\n        | if length&gt;1 then length\r\n          elif .[0] == &quot;foo&quot; then 0\r\n          elif .[0] == &quot;bar&quot; then 1\r\n          else .[0]          # just in case\r\n          end) as $type\r\n        | (.[] + {type: $type} ) ]\r\n\r\n## Output\r\n\r\n    [\r\n      {\r\n        &quot;filename&quot;: &quot;a&quot;,\r\n        &quot;dir&quot;: &quot;foo&quot;,\r\n        &quot;type&quot;: 2\r\n      },\r\n      {\r\n        &quot;filename&quot;: &quot;a&quot;,\r\n        &quot;dir&quot;: &quot;bar&quot;,\r\n        &quot;type&quot;: 2\r\n      },\r\n      {\r\n        &quot;filename&quot;: &quot;b&quot;,\r\n        &quot;dir&quot;: &quot;foo&quot;,\r\n        &quot;type&quot;: 0\r\n      },\r\n      {\r\n        &quot;filename&quot;: &quot;c&quot;,\r\n        &quot;dir&quot;: &quot;bar&quot;,\r\n        &quot;type&quot;: 1\r\n      }\r\n    ]\r\n\r\n",
                "title": "How set a JSON value based on a second value and also number of occurrences of a third value"
            },
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1533840598,
                "last_edit_date": 1533840598,
                "creation_date": 1533439204,
                "answer_id": 51691137,
                "question_id": 51684565,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is a solution that is similar to that by @CharlesDuffy but a little shorter and more &quot;jq-ish&quot;:\r\n\r\n    (reduce .[] as $x ({}; .[$x.filename] += [$x.dir])\r\n     | map_values(unique)) as $dirs\r\n    | map( $dirs[.filename] as $d\r\n           | .type |= if $d|length &gt; 1 then 2\r\n                      elif $d[0] == &quot;bar&quot; then 1\r\n                      else 0\r\n                      end)\r\n\r\n## Using `catalog/3`\r\n\r\nWith the help of the generic helper function `catalog/3`:\r\n\r\n    def catalog(s; keyp; valuep):\r\n       reduce s as $x ({}; (.[$x|keyp|tostring]) += [$x|valuep]);\r\n\r\nthe solution becomes a bit more readable:\r\n\r\n    (catalog(.[]; .filename; .dir) | map_values(unique)) as $dirs\r\n    | map( $dirs[.filename] as $d\r\n           | .type |= if $d|length &gt; 1 then 2\r\n                      elif $d[0] == &quot;bar&quot; then 1\r\n                      else 0\r\n                      end)\r\n\r\n\r\n\r\n\r\n",
                "title": "How set a JSON value based on a second value and also number of occurrences of a third value"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1533840598,
        "creation_date": 1533377584,
        "last_edit_date": 1533405334,
        "question_id": 51684565,
        "body_markdown": "Initial `files.json` document state:\r\n\r\n    [\r\n      {\r\n        &quot;filename&quot;: &quot;a&quot;,\r\n        &quot;dir&quot;: &quot;foo&quot;,\r\n        &quot;type&quot;: &quot;unknown&quot;\r\n      },\r\n      {\r\n        &quot;filename&quot;: &quot;b&quot;,\r\n        &quot;dir&quot;: &quot;foo&quot;,\r\n        &quot;type&quot;: &quot;unknown&quot;\r\n      },\r\n      {\r\n        &quot;filename&quot;: &quot;c&quot;,\r\n        &quot;dir&quot;: &quot;bar&quot;,\r\n        &quot;type&quot;: &quot;unknown&quot;\r\n      },\r\n      {\r\n        &quot;filename&quot;: &quot;a&quot;,\r\n        &quot;dir&quot;: &quot;bar&quot;,\r\n        &quot;type&quot;: &quot;unknown&quot;\r\n      }\r\n    ]\r\n\r\nWhen a &quot;filename&quot; value occurs just once in the document, the &quot;type&quot; value will only depend on the &quot;dir&quot; value: `&quot;dir&quot; == &quot;foo&quot; --&gt; &quot;type&quot; = 0` and `&quot;dir&quot; == &quot;bar&quot; --&gt; &quot;type&quot; = 1`\r\n\r\nWhen a &quot;filename&quot; value exists both in &quot;foo&quot; and also in &quot;bar&quot; directories, &quot;type&quot; must have value == 2, like here:\r\n\r\n    [\r\n      {\r\n        &quot;filename&quot;: &quot;a&quot;,\r\n        &quot;dir&quot;: &quot;foo&quot;,\r\n        &quot;type&quot;: &quot;2&quot;\r\n      },\r\n      {\r\n        &quot;filename&quot;: &quot;b&quot;,\r\n        &quot;dir&quot;: &quot;foo&quot;,\r\n        &quot;type&quot;: &quot;0&quot;\r\n      },\r\n      {\r\n        &quot;filename&quot;: &quot;c&quot;,\r\n        &quot;dir&quot;: &quot;bar&quot;,\r\n        &quot;type&quot;: &quot;1&quot;\r\n      },\r\n      {\r\n        &quot;filename&quot;: &quot;a&quot;,\r\n        &quot;dir&quot;: &quot;bar&quot;,\r\n        &quot;type&quot;: &quot;2&quot;\r\n      }\r\n    ]\r\n\r\nThe &quot;dir&quot; value will always be limited to the two possible alternatives of &quot;foo&quot; or &quot;bar&quot; values and will never be null.  \r\nEven the &quot;filename&quot; value will be ever set, and since these are really files, can not be present in document more than twice at most.\r\n  \r\nI want to do this with jq 1.5 (16 Aug 2015 stable release) running from a Bash script in Linux.\r\n",
        "link": "https://stackoverflow.com/questions/51684565/how-set-a-json-value-based-on-a-second-value-and-also-number-of-occurrences-of-a",
        "title": "How set a JSON value based on a second value and also number of occurrences of a third value"
    },
    {
        "tags": [
            "json",
            "amazon-web-services",
            "jq",
            "json-query"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3594383,
                    "reputation": 11066,
                    "user_id": 2999566,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/2355cb8d30b82296663928fdff698e38?s=256&d=identicon&r=PG",
                    "display_name": "Mike Patrick",
                    "link": "https://stackoverflow.com/users/2999566/mike-patrick"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1533491124,
                "post_id": 51696480,
                "comment_id": 90354903,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1230255,
                    "reputation": 6121,
                    "user_id": 1702942,
                    "user_type": "registered",
                    "accept_rate": 88,
                    "profile_image": "https://i.sstatic.net/ICkw8.jpg?s=256",
                    "display_name": "Itai Ganot",
                    "link": "https://stackoverflow.com/users/1702942/itai-ganot"
                },
                "reply_to_user": {
                    "account_id": 3594383,
                    "reputation": 11066,
                    "user_id": 2999566,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/2355cb8d30b82296663928fdff698e38?s=256&d=identicon&r=PG",
                    "display_name": "Mike Patrick",
                    "link": "https://stackoverflow.com/users/2999566/mike-patrick"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1533491254,
                "post_id": 51696480,
                "comment_id": 90354935,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1533492745,
                "creation_date": 1533492745,
                "answer_id": 51697028,
                "question_id": 51696480,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It looks like the command you are using is `aws ec2 describe-vpcs`.\r\n\r\nThis command actually returns the following structure:\r\n\r\n    {\r\n        &quot;Vpcs&quot;: [\r\n            {\r\n                &quot;VpcId&quot;: &quot;vpc-xxxxxxxx&quot;, \r\n            }\r\n        ]\r\n    }\r\n\r\nSo you want to reach into the `Vpcs` key before you iterate over the array, Like this:\r\n\r\n    aws ec2 describe-vpcs | jq -r &#39;.Vpcs | .[] | .VpcId&#39;\r\n\r\n",
                "title": "Trying to extract values from aws-cli response using jq but failing, what am I doing wrong?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1533496601,
                "creation_date": 1533496601,
                "answer_id": 51697509,
                "question_id": 51696480,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "An alternative to consider would be to use `..`, e.g.\r\n\r\n    .. | .VpcId? // empty\r\n\r\nwill print the values of all &quot;VpcId&quot; keys, except for `null` and `false` values.\r\n\r\nIncidentally, `.Vpcs | .[] | .VpcId` can be abbreviated to `.Vpcs[].VpcId`",
                "title": "Trying to extract values from aws-cli response using jq but failing, what am I doing wrong?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1533599867,
        "creation_date": 1533488717,
        "last_edit_date": 1533599867,
        "question_id": 51696480,
        "body_markdown": "I have the following json structure:\r\n\r\n    [\r\n      {\r\n        &quot;IsDefault&quot;: false,\r\n        &quot;CidrBlock&quot;: &quot;172.19.0.0/16&quot;,\r\n        &quot;DhcpOptionsId&quot;: &quot;dopt-37fd70550&quot;,\r\n        &quot;State&quot;: &quot;available&quot;,\r\n        &quot;CidrBlockAssociationSet&quot;: [\r\n          {\r\n            &quot;CidrBlockState&quot;: {\r\n              &quot;State&quot;: &quot;associated&quot;\r\n            },\r\n            &quot;CidrBlock&quot;: &quot;172.19.0.0/16&quot;,\r\n            &quot;AssociationId&quot;: &quot;vpc-cidr-assoc-f3c1559a&quot;\r\n          }\r\n        ],\r\n        &quot;Tags&quot;: [\r\n          {\r\n            &quot;Key&quot;: &quot;Name&quot;,\r\n            &quot;Value&quot;: &quot;product-Production&quot;\r\n          }\r\n        ],\r\n        &quot;InstanceTenancy&quot;: &quot;default&quot;,\r\n        &quot;VpcId&quot;: &quot;vpc-1f0e197d&quot;\r\n      },\r\n      {\r\n        &quot;IsDefault&quot;: false,\r\n        &quot;CidrBlock&quot;: &quot;10.0.0.0/16&quot;,\r\n        &quot;DhcpOptionsId&quot;: &quot;dopt-0a550861&quot;,\r\n        &quot;State&quot;: &quot;available&quot;,\r\n        &quot;CidrBlockAssociationSet&quot;: [\r\n          {\r\n            &quot;CidrBlockState&quot;: {\r\n              &quot;State&quot;: &quot;associated&quot;\r\n            },\r\n            &quot;CidrBlock&quot;: &quot;10.0.0.0/16&quot;,\r\n            &quot;AssociationId&quot;: &quot;vpc-cidr-assoc-8955dae0&quot;\r\n          }\r\n        ],\r\n        &quot;Tags&quot;: [\r\n          {\r\n            &quot;Key&quot;: &quot;Name&quot;,\r\n            &quot;Value&quot;: &quot;Marketing VPC&quot;\r\n          }\r\n        ],\r\n        &quot;InstanceTenancy&quot;: &quot;default&quot;,\r\n        &quot;VpcId&quot;: &quot;vpc-36b5585d&quot;\r\n      },\r\n      .\r\n      .\r\n      .\r\n    ]\r\n\r\nI&#39;m trying to print all VpcId&#39;s using jq but I can&#39;t find the right way to do it.\r\n\r\nHere&#39;s what I&#39;ve tried:\r\n\r\n    command | jq -r &#39;.VpcId[]&#39;\r\n    command | jq -r &#39;.VpcId&#39;\r\n    command | jq -r &#39;.[] | .VpcId&#39;\r\n\r\nWhat am I doing wrong?",
        "link": "https://stackoverflow.com/questions/51696480/trying-to-extract-values-from-aws-cli-response-using-jq-but-failing-what-am-i-d",
        "title": "Trying to extract values from aws-cli response using jq but failing, what am I doing wrong?"
    },
    {
        "tags": [
            "json",
            "jq",
            "json-query"
        ],
        "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": 1533545230,
                "post_id": 51703572,
                "comment_id": 90368337,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1533546076,
                "last_edit_date": 1533546076,
                "creation_date": 1533544939,
                "answer_id": 51703679,
                "question_id": 51703572,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You are so-close but not quite the right filter. You need to use a `select` expression here to match the object matching your string condition and filter the value out of it.\r\n\r\n    jq &#39;.Vpcs[] | select( .Tags[].Value| contains(&quot;Product-Production&quot;)) | .VpcId&#39;\r\n\r\nIf you break down the filter,\r\n\r\n 1. The part `.Vpcs[]` lists all the elements within the array on which we apply the condition.\r\n 2. We filter that object whose `.Value` contains the string you need here. So at the end of first pipe-line output you get the actual element from the list of the elements in the array, matching the condition defined.\r\n 3. From the object returned, you just print out the `.VpcId` with the last pipeline.\r\n\r\n\r\nIf you haven&#39;t used [jqplay.org](https://jqplay.org/s/TRWwWJVS5x) before, you should try it and get your filters into action and work it out online.",
                "title": "How can I catch VpcId if I know a related tag&#39;s value ahead?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1533599830,
        "creation_date": 1533544531,
        "last_edit_date": 1533599830,
        "question_id": 51703572,
        "body_markdown": "I have the following output of `aws ec2 describe-vpcs`:\r\n\r\n    {\r\n        &quot;Vpcs&quot;: [\r\n            {\r\n                &quot;VpcId&quot;: &quot;vpc-1f0e197d&quot;,\r\n                &quot;InstanceTenancy&quot;: &quot;default&quot;,\r\n                &quot;Tags&quot;: [\r\n                    {\r\n                        &quot;Value&quot;: &quot;Product-Production&quot;,\r\n                        &quot;Key&quot;: &quot;Name&quot;\r\n                    }\r\n                ],\r\n                &quot;CidrBlockAssociationSet&quot;: [\r\n                    {\r\n                        &quot;AssociationId&quot;: &quot;vpc-cidr-assoc-f3c5509a&quot;,\r\n                        &quot;CidrBlock&quot;: &quot;172.19.0.0/16&quot;,\r\n                        &quot;CidrBlockState&quot;: {\r\n                            &quot;State&quot;: &quot;associated&quot;\r\n                        }\r\n                    }\r\n                ],\r\n                &quot;State&quot;: &quot;available&quot;,\r\n                &quot;DhcpOptionsId&quot;: &quot;dopt-37fd5550&quot;,\r\n                &quot;CidrBlock&quot;: &quot;172.19.0.0/16&quot;,\r\n                &quot;IsDefault&quot;: false\r\n            },\r\n            {\r\n             another vpc...\r\n            }\r\n        ]\r\n    }\r\n\r\nI&#39;m using `jq` to catch the &quot;VpcId&quot; if \r\n\r\n    .Tags[].Value==Product-Production\r\n\r\nbut no matter what I try, I can&#39;t get the right syntax, how can it be achieved?\r\n\r\n",
        "link": "https://stackoverflow.com/questions/51703572/how-can-i-catch-vpcid-if-i-know-a-related-tags-value-ahead",
        "title": "How can I catch VpcId if I know a related tag&#39;s value ahead?"
    },
    {
        "tags": [
            "json",
            "jq",
            "json-query"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1533565725,
                "creation_date": 1533565725,
                "answer_id": 51709946,
                "question_id": 51709799,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use the comma operator.\r\n\r\n    $ jq &#39;.data[&quot;foo&quot;, &quot;bar&quot;][].table&#39; foo.json\r\n\r\nor\r\n\r\n    $ jq &#39;.data | .foo, .bar | .[].table&#39; foo.json\r\n\r\nOr assuming you want to grab any property of the `data` object.\r\n\r\n    $ jq &#39;.data[][].table&#39; foo.json",
                "title": "How to extract some value from diff fields of an object in one command"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1533566378,
                "creation_date": 1533566378,
                "answer_id": 51710146,
                "question_id": 51709799,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you don&#39;t care where the &quot;table&quot; values occur, and if you want to exclude `null` and `false` values:\r\n\r\n    .. | .table? // empty\r\n\r\nIf you want to include `null` and `false` values:\r\n\r\n    .. | objects | has(&quot;table&quot;) | .table",
                "title": "How to extract some value from diff fields of an object in one command"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1533599657,
        "creation_date": 1533565232,
        "last_edit_date": 1533599657,
        "question_id": 51709799,
        "body_markdown": "there is json data like this\r\n\r\n    ➜  ~ cat foo.json | jq\r\n    {\r\n      &quot;data&quot;: {\r\n        &quot;foo&quot;: [\r\n          {\r\n            &quot;table&quot;: &quot;aaa&quot;\r\n          },\r\n          {\r\n            &quot;table&quot;: &quot;bbb&quot;\r\n          }\r\n        ],\r\n        &quot;bar&quot;: [\r\n          {\r\n            &quot;table&quot;: &quot;ccc&quot;\r\n          },\r\n          {\r\n            &quot;table&quot;: &quot;ddd&quot;\r\n          }\r\n        ]\r\n      }\r\n    }\r\nCould get table of foo or bar separately,\r\n\r\n    ➜  ~ cat foo.json | jq &#39;.data.foo[].table&#39;\r\n    &quot;aaa&quot;\r\n    &quot;bbb&quot;\r\n    ➜  ~ cat foo.json | jq &#39;.data.bar[].table&#39;\r\n    &quot;ccc&quot;\r\n    &quot;ddd&quot;\r\n\r\nhow could get all table values in one command?",
        "link": "https://stackoverflow.com/questions/51709799/how-to-extract-some-value-from-diff-fields-of-an-object-in-one-command",
        "title": "How to extract some value from diff fields of an object in one command"
    },
    {
        "tags": [
            "bash",
            "jq",
            "amazon-elb"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 8306545,
                    "reputation": 58596,
                    "user_id": 6243352,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/193965abcb7230d85c6264e55e2f0bda?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "ggorlen",
                    "link": "https://stackoverflow.com/users/6243352/ggorlen"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1627494634,
                "post_id": 51718102,
                "comment_id": 121174133,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 9,
                "is_accepted": true,
                "score": 9,
                "last_activity_date": 1533613443,
                "creation_date": 1533613443,
                "answer_id": 51718532,
                "question_id": 51718102,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You probably should be using `test/2` rather than `match/2`, but in either case, since the problem description calls for\r\ncase-insensitive equality, you would use an anchored regex:\r\n\r\n    .LoadBalancers[]\r\n    | select(.DNSName | test(&quot;^my-lb2-9876556789.us-west-2.elb.amazonaws.com$&quot;;&quot;i&quot;))\r\n\r\nWith the caveat that `ascii_upcase` only translates ASCII characters, it might be more efficient to use it:\r\n \r\n     .LoadBalancers[]\r\n     | select(.DNSName | ascii_upcase == &quot;MY-LB2-9876556789.US-WEST-2.ELB.AMAZONAWS.COM&quot;)",
                "title": "filter json via bash - case insensitive"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 5,
        "last_activity_date": 1533613443,
        "creation_date": 1533609988,
        "last_edit_date": 1533611526,
        "question_id": 51718102,
        "body_markdown": "I have json code and need to filter it by the value of the attribute *DNSName*. The filter must be case insensitive.\r\n\r\nHow can I do that? Is there a possibility to solve it with *jq*?\r\n\r\nThis is how I create the json code:\r\n&lt;!-- language-all: lang-bash --&gt;\r\n\r\n    aws elbv2 describe-load-balancers --region=us-west-2 | jq\r\n\r\n\r\nMy unfiltered source json code looks like this:\r\n&lt;!-- language-all: lang-json --&gt;\r\n\r\n    {\r\n        &quot;LoadBalancers&quot;: [\r\n            {\r\n                &quot;IpAddressType&quot;: &quot;ipv4&quot;, \r\n                &quot;VpcId&quot;: &quot;vpc-abcdabcd&quot;, \r\n                &quot;LoadBalancerArn&quot;: &quot;arn:aws:elasticloadbalancing:us-west-2:000000000000:loadbalancer/app/MY-LB1/a00000000000000a&quot;, \r\n                &quot;State&quot;: {\r\n                    &quot;Code&quot;: &quot;active&quot;\r\n                }, \r\n                &quot;DNSName&quot;: &quot;MY-LB1-123454321.us-west-2.elb.amazonaws.com&quot;, \r\n                &quot;SecurityGroups&quot;: [\r\n                    &quot;sg-00100100&quot;, \r\n                    &quot;sg-01001000&quot;, \r\n                    &quot;sg-10010001&quot;\r\n                ], \r\n                &quot;LoadBalancerName&quot;: &quot;MY-LB1&quot;, \r\n                &quot;CreatedTime&quot;: &quot;2018-01-01T00:00:00.000Z&quot;, \r\n                &quot;Scheme&quot;: &quot;internet-facing&quot;, \r\n                &quot;Type&quot;: &quot;application&quot;, \r\n                &quot;CanonicalHostedZoneId&quot;: &quot;ZZZZZZZZZZZZZ&quot;, \r\n                &quot;AvailabilityZones&quot;: [\r\n                    {\r\n                        &quot;SubnetId&quot;: &quot;subnet-17171717&quot;, \r\n                        &quot;ZoneName&quot;: &quot;us-west-2a&quot;\r\n                    }, \r\n                    {\r\n                        &quot;SubnetId&quot;: &quot;subnet-27272727&quot;, \r\n                        &quot;ZoneName&quot;: &quot;us-west-2c&quot;\r\n                    }, \r\n                    {\r\n                        &quot;SubnetId&quot;: &quot;subnet-37373737&quot;, \r\n                        &quot;ZoneName&quot;: &quot;us-west-2b&quot;\r\n                    }\r\n                ]\r\n            }, \r\n            {\r\n                &quot;IpAddressType&quot;: &quot;ipv4&quot;, \r\n                &quot;VpcId&quot;: &quot;vpc-abcdabcd&quot;, \r\n                &quot;LoadBalancerArn&quot;: &quot;arn:aws:elasticloadbalancing:us-west-2:000000000000:loadbalancer/app/MY-LB2/b00000000000000b&quot;, \r\n                &quot;State&quot;: {\r\n                    &quot;Code&quot;: &quot;active&quot;\r\n                }, \r\n                &quot;DNSName&quot;: &quot;MY-LB2-9876556789.us-west-2.elb.amazonaws.com&quot;, \r\n                &quot;SecurityGroups&quot;: [\r\n                    &quot;sg-88818881&quot;\r\n                ], \r\n                &quot;LoadBalancerName&quot;: &quot;MY-LB2&quot;, \r\n                &quot;CreatedTime&quot;: &quot;2018-01-01T00:00:00.000Z&quot;, \r\n                &quot;Scheme&quot;: &quot;internet-facing&quot;, \r\n                &quot;Type&quot;: &quot;application&quot;, \r\n                &quot;CanonicalHostedZoneId&quot;: &quot;ZZZZZZZZZZZZZ&quot;, \r\n                &quot;AvailabilityZones&quot;: [\r\n                    {\r\n                        &quot;SubnetId&quot;: &quot;subnet-54545454&quot;, \r\n                        &quot;ZoneName&quot;: &quot;us-west-2a&quot;\r\n                    }, \r\n                    {\r\n                        &quot;SubnetId&quot;: &quot;subnet-64646464&quot;, \r\n                        &quot;ZoneName&quot;: &quot;us-west-2c&quot;\r\n                    }, \r\n                    {\r\n                        &quot;SubnetId&quot;: &quot;subnet-74747474&quot;, \r\n                        &quot;ZoneName&quot;: &quot;us-west-2b&quot;\r\n                    }\r\n                ]\r\n            }\r\n        ]\r\n    }\r\n\r\n\r\nI now want some bash code to filter this result for the record with the DNSName property value *MY-LB2-9876556789.us-west-2.elb.amazonaws.com*, and need the entire LoadBalancer object back as a result. This is how I wish my result to look like:\r\n\r\n    {\r\n        &quot;IpAddressType&quot;: &quot;ipv4&quot;, \r\n        &quot;VpcId&quot;: &quot;vpc-abcdabcd&quot;, \r\n        &quot;LoadBalancerArn&quot;: &quot;arn:aws:elasticloadbalancing:us-west-2:000000000000:loadbalancer/app/MY-LB2/b00000000000000b&quot;, \r\n        &quot;State&quot;: {\r\n            &quot;Code&quot;: &quot;active&quot;\r\n        }, \r\n        &quot;DNSName&quot;: &quot;MY-LB2-9876556789.us-west-2.elb.amazonaws.com&quot;, \r\n        &quot;SecurityGroups&quot;: [\r\n            &quot;sg-88818881&quot;\r\n        ], \r\n        &quot;LoadBalancerName&quot;: &quot;MY-LB2&quot;, \r\n        &quot;CreatedTime&quot;: &quot;2018-01-01T00:00:00.000Z&quot;, \r\n        &quot;Scheme&quot;: &quot;internet-facing&quot;, \r\n        &quot;Type&quot;: &quot;application&quot;, \r\n        &quot;CanonicalHostedZoneId&quot;: &quot;ZZZZZZZZZZZZZ&quot;, \r\n        &quot;AvailabilityZones&quot;: [\r\n            {\r\n                &quot;SubnetId&quot;: &quot;subnet-54545454&quot;, \r\n                &quot;ZoneName&quot;: &quot;us-west-2a&quot;\r\n            }, \r\n            {\r\n                &quot;SubnetId&quot;: &quot;subnet-64646464&quot;, \r\n                &quot;ZoneName&quot;: &quot;us-west-2c&quot;\r\n            }, \r\n            {\r\n                &quot;SubnetId&quot;: &quot;subnet-74747474&quot;, \r\n                &quot;ZoneName&quot;: &quot;us-west-2b&quot;\r\n            }\r\n        ]\r\n    }\r\n\r\nDoes anyone know how to do it?\r\n\r\n---\r\n\r\nUpdate:\r\nThis solution works, but is not case insensitive:\r\n\r\n    aws elbv2 describe-load-balancers --region=us-west-2 | jq -c &#39;.LoadBalancers[] | select(.DNSName | contains(&quot;MY-LB2&quot;))&#39;\r\n\r\n---\r\n\r\nUpdate:\r\nThis solution seems to work even better:\r\n\r\n    aws elbv2 describe-load-balancers --region=us-west-2 | jq -c &#39;.LoadBalancers[] | select(.DNSName | match(&quot;my-lb2&quot;;&quot;i&quot;))&#39;\r\n\r\nBut I did not have the chance to test in detail yet.",
        "link": "https://stackoverflow.com/questions/51718102/filter-json-via-bash-case-insensitive",
        "title": "filter json via bash - case insensitive"
    },
    {
        "tags": [
            "json",
            "jq",
            "winston"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 166270,
                    "reputation": 135171,
                    "user_id": 390278,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/84715fec547362389d02f5be0ed12814?s=256&d=identicon&r=PG",
                    "display_name": "Jeff Mercado",
                    "link": "https://stackoverflow.com/users/390278/jeff-mercado"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1533656948,
                "post_id": 51729347,
                "comment_id": 90422351,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1533666730,
                "last_edit_date": 1533666730,
                "creation_date": 1533658801,
                "answer_id": 51731350,
                "question_id": 51729347,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To add line-numbers, the following helper function would be a good way to go:\r\n\r\n    def tocsv(s):\r\n      foreach s as $line (0; .+1; [.] + $line)\r\n      | map(tostring) # for robustness\r\n      | @csv ;\r\n\r\nAnd then:\r\n\r\n    tocsv(inputs\r\n          | [.timestamp, .level, .message]\r\n            + ( .result | [.TransactionID, .TimeStamp, .Status] ))\r\n\r\nThis assumes your jq has `inputs` and that you include `-n` as a command-line option.\r\n",
                "title": "Winston JSON Log output to CSV using JQ but getting &quot;Cannot by Csv-Formatted, only array&quot; error"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1533666730,
        "creation_date": 1533652374,
        "last_edit_date": 1533665555,
        "question_id": 51729347,
        "body_markdown": "I have a vendor supplied application that outputs Node.JS Winston logs in JSON format that I am trying to output into single line CSV format.\r\n\r\nThere are many different types of array types and I&#39;ve used &quot;JQ&quot; utilize to out the elements I want out of each element successfully. \r\n\r\nThe raw being something like the following:\r\n\r\n    {&quot;result&quot;:{&quot;TransactionID&quot;:&quot;ac710dc0-8aa4-11e8-a08c-0d98209bb4f5&quot;,&quot;TimeStamp&quot;:&quot;2018-07-18T12:07:33.082-04:00&quot;,&quot;SourceSystem&quot;:&quot;SOUP&quot;,&quot;Status&quot;:&quot;Accepted&quot;},&quot;level&quot;:&quot;info&quot;,&quot;message&quot;:&quot;SOAP createServiceRequest ack recieved &amp; is successful.&quot;,&quot;timestamp&quot;:&quot;2018-07-18T16:07:33.047Z&quot;}\r\n\r\n\r\nThe output being currently with my existing command string (minus the @csv) like:\r\n\r\n    [\r\n      &quot;2018-07-18T16:07:33.047Z&quot;,\r\n      &quot;info&quot;,\r\n      &quot;SOAP createServiceRequest ack recieved &amp; is successful.&quot;,\r\n      &quot;ac710dc0-8aa4-11e8-a08c-0d98209bb4f5&quot;,\r\n      &quot;2018-07-18T12:07:33.082-04:00&quot;,\r\n      &quot;Accepted&quot;\r\n    ]\r\n\r\nI have read many posts on SE about outputting to CSV and it seems relatively straight forward but I consistently get an error.\r\n\r\n    tail -200 ClientOutbound.log | jq-win64.exe --raw-output &quot;[.timestamp, .level, .message, .result .TransactionID, .result .TimeStamp, .result .Status|tostring|@csv]&quot;\r\n\r\nThough with the above @csv present I get errors like the following no matter how I narrow down the fields included.. it just moves the error.\r\n\r\n    jq: error (at &lt;stdin&gt;:199): string (&quot;2018-07-18...) cannot be csv-formatted, only array\r\n\r\n\r\nand the @csv outside of the array produces a similar error with different detail but also not even parsing the JSON.\r\n\r\n     c:\\Nodejs\\Logs&gt; jq-win64.exe --raw-output @csv ClientOutbound.log &quot;[.level, .message, .result .TransactionID, .result .TimeStamp, .result .Status]&quot;\r\n\r\nFor example from what type of array:\r\n\r\n    jq: error (at NCRClientOutbound.log:2074): object ({&quot;level&quot;:&quot;i...) cannot be csv-formatted, only array\r\njq: error (at NCRClientOutbound.log:2075): object ({&quot;argv&quot;:[&quot;D...) cannot be csv-formatted, only array\r\njq: error (at NCRClientOutbound.log:2076): object ({&quot;CreateSer...) cannot be csv-formatted, only array\r\njq: error (at NCRClientOutbound.log:2077): object ({&quot;lastReque...) cannot be csv-formatted, only array\r\njq: error (at NCRClientOutbound.log:2078): object ({&quot;result&quot;:{...) cannot be csv-formatted, only array\r\n\r\n\r\nThe end result I am looking for is something that looks like this (with or without the new encapsulating [] (preferably without) but each row being on the same line.. and as a bonus would be a unique line identifier.\r\n\r\n    &quot;2018-07-18T16:07:33.047Z&quot;,  &quot;info&quot;,  &quot;SOAP createServiceRequest ack recieved &amp; is successful.&quot;,  &quot;ac710dc0-8aa4-11e8-a08c-0d98209bb4f5&quot;,  &quot;2018-07-18T12:07:33.082-04:00&quot;,  &quot;Accepted&quot;\r\n\r\nWhat do I need to do to get past my error and get the desired output?\r\n\r\n\r\n  [1]: https://stackoverflow.com/questions/187587/a-windows-equivalent-of-the-unix-tail-command\r\n",
        "link": "https://stackoverflow.com/questions/51729347/winston-json-log-output-to-csv-using-jq-but-getting-cannot-by-csv-formatted-on",
        "title": "Winston JSON Log output to CSV using JQ but getting &quot;Cannot by Csv-Formatted, only array&quot; error"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq",
            "influxdb"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2559748,
                    "reputation": 50529,
                    "user_id": 2221001,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/e19e92b3618d46eb6ab80e4bc38cec44?s=256&d=identicon&r=PG",
                    "display_name": "JNevill",
                    "link": "https://stackoverflow.com/users/2221001/jnevill"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1533664518,
                "post_id": 51732540,
                "comment_id": 90426200,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 10461098,
                    "reputation": 73,
                    "user_id": 7711821,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/cc1ac510b3293d1bb94ea948801aeaf7?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "eptesicus",
                    "link": "https://stackoverflow.com/users/7711821/eptesicus"
                },
                "reply_to_user": {
                    "account_id": 2559748,
                    "reputation": 50529,
                    "user_id": 2221001,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/e19e92b3618d46eb6ab80e4bc38cec44?s=256&d=identicon&r=PG",
                    "display_name": "JNevill",
                    "link": "https://stackoverflow.com/users/2221001/jnevill"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1533666851,
                "post_id": 51732540,
                "comment_id": 90427319,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2559748,
                    "reputation": 50529,
                    "user_id": 2221001,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/e19e92b3618d46eb6ab80e4bc38cec44?s=256&d=identicon&r=PG",
                    "display_name": "JNevill",
                    "link": "https://stackoverflow.com/users/2221001/jnevill"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1533667166,
                "post_id": 51732540,
                "comment_id": 90427480,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1537863102,
                "creation_date": 1537863102,
                "answer_id": 52493496,
                "question_id": 51732540,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could extract the wanted field using `jq` and assign values to `bash` variables:\r\n\r\n    &lt;file jq -r &#39;.VoiceCSQDetailsStats | [ .agentId,.agentName,.agentState,.agentStateDuration ] | @tsv&#39; \\\r\n    | while IFS=$&#39;\\t&#39; read jsonAgentId jsonAgentName jsonAgentState jsonAgentStateDuration; do\r\n        echo -e &quot;jsonAgentId=${jsonAgentId}\\njsonAgentName=${jsonAgentName}\\njsonAgentState=${jsonAgentState}\\njsonAgentStateDuration=${jsonAgentStateDuration}\\n&quot;;\r\n    done\r\n\r\nThe `@tsv` operator allows to get all values separated with a tab `\\t`, then it can be easily parsed by the shell by setting the input field separator `IFS` accordingly.\r\n\r\nYou might want to replace the `&lt;file` by `curl ... | ` if you want to directly parse the JSON data.",
                "title": "Bash - Parse JSON for use with InfluxDB"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1573089588,
                "creation_date": 1573089588,
                "answer_id": 58740641,
                "question_id": 51732540,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "My solution is to have `jq` write the `curl` commands for you:\r\n\r\n## Starting Simple: Just get an object with the data you want\r\n\r\n```\r\n$ jq -c &#39;.VoiceCSQDetailsStats | { id: .agentId, name: .agentName, state: .agentState, stateDuration: .agentStateDuration } | select(.id and .name and .state and .stateDuration)&#39; &lt; eptesicus.json\r\n{&quot;id&quot;:&quot;muser&quot;,&quot;name&quot;:&quot;My User&quot;,&quot;state&quot;:&quot;Not Ready&quot;,&quot;stateDuration&quot;:982761}\r\n{&quot;id&quot;:&quot;yuser&quot;,&quot;name&quot;:&quot;Your User&quot;,&quot;state&quot;:&quot;Talking&quot;,&quot;stateDuration&quot;:626160}\r\n{&quot;id&quot;:&quot;euser&quot;,&quot;name&quot;:&quot;Everyones User&quot;,&quot;state&quot;:&quot;Ready&quot;,&quot;stateDuration&quot;:203631}\r\n{&quot;id&quot;:&quot;duser&quot;,&quot;name&quot;:&quot;Dumb User&quot;,&quot;state&quot;:&quot;Not Ready&quot;,&quot;stateDuration&quot;:175342}\r\n{&quot;id&quot;:&quot;fuser&quot;,&quot;name&quot;:&quot;Foolish User&quot;,&quot;state&quot;:&quot;Not Ready&quot;,&quot;stateDuration&quot;:1057520}\r\n{&quot;id&quot;:&quot;druser&quot;,&quot;name&quot;:&quot;Drug User&quot;,&quot;state&quot;:&quot;Talking ( from CSQ: NOCHelpdesk )&quot;,&quot;stateDuration&quot;:167914}\r\n```\r\n\r\n## Expanding on that: Have `jq` write your `curl` statements\r\n\r\n```\r\n$ influxdbIP=1.2.3.4 jq -r &#39;.VoiceCSQDetailsStats | { id: .agentId, name: .agentName, state: .agentState, stateDuration: .agentStateDuration } | select(.id and .name and .state and .stateDuration) | .id as $id | ( .name, .state, .stateDuration) | &quot;curl -i -XPOST \\&quot;\\( $ENV | .influxdbIP):8086/write?db=nocdb\\&quot; --data-binary \\&quot;uccxstats,host=uccx,user=\\($id) value=\\(.)\\&quot;&quot;&#39; &lt; eptesicus.json\r\ncurl -i -XPOST &quot;1.2.3.4:8086/write?db=nocdb&quot; --data-binary &quot;uccxstats,host=uccx,user=muser value=My User&quot;\r\ncurl -i -XPOST &quot;1.2.3.4:8086/write?db=nocdb&quot; --data-binary &quot;uccxstats,host=uccx,user=muser value=Not Ready&quot;\r\ncurl -i -XPOST &quot;1.2.3.4:8086/write?db=nocdb&quot; --data-binary &quot;uccxstats,host=uccx,user=muser value=982761&quot;\r\ncurl -i -XPOST &quot;1.2.3.4:8086/write?db=nocdb&quot; --data-binary &quot;uccxstats,host=uccx,user=yuser value=Your User&quot;\r\ncurl -i -XPOST &quot;1.2.3.4:8086/write?db=nocdb&quot; --data-binary &quot;uccxstats,host=uccx,user=yuser value=Talking&quot;\r\ncurl -i -XPOST &quot;1.2.3.4:8086/write?db=nocdb&quot; --data-binary &quot;uccxstats,host=uccx,user=yuser value=626160&quot;\r\ncurl -i -XPOST &quot;1.2.3.4:8086/write?db=nocdb&quot; --data-binary &quot;uccxstats,host=uccx,user=euser value=Everyones User&quot;\r\ncurl -i -XPOST &quot;1.2.3.4:8086/write?db=nocdb&quot; --data-binary &quot;uccxstats,host=uccx,user=euser value=Ready&quot;\r\ncurl -i -XPOST &quot;1.2.3.4:8086/write?db=nocdb&quot; --data-binary &quot;uccxstats,host=uccx,user=euser value=203631&quot;\r\ncurl -i -XPOST &quot;1.2.3.4:8086/write?db=nocdb&quot; --data-binary &quot;uccxstats,host=uccx,user=duser value=Dumb User&quot;\r\ncurl -i -XPOST &quot;1.2.3.4:8086/write?db=nocdb&quot; --data-binary &quot;uccxstats,host=uccx,user=duser value=Not Ready&quot;\r\ncurl -i -XPOST &quot;1.2.3.4:8086/write?db=nocdb&quot; --data-binary &quot;uccxstats,host=uccx,user=duser value=175342&quot;\r\ncurl -i -XPOST &quot;1.2.3.4:8086/write?db=nocdb&quot; --data-binary &quot;uccxstats,host=uccx,user=fuser value=Foolish User&quot;\r\ncurl -i -XPOST &quot;1.2.3.4:8086/write?db=nocdb&quot; --data-binary &quot;uccxstats,host=uccx,user=fuser value=Not Ready&quot;\r\ncurl -i -XPOST &quot;1.2.3.4:8086/write?db=nocdb&quot; --data-binary &quot;uccxstats,host=uccx,user=fuser value=1057520&quot;\r\ncurl -i -XPOST &quot;1.2.3.4:8086/write?db=nocdb&quot; --data-binary &quot;uccxstats,host=uccx,user=druser value=Drug User&quot;\r\ncurl -i -XPOST &quot;1.2.3.4:8086/write?db=nocdb&quot; --data-binary &quot;uccxstats,host=uccx,user=druser value=Talking ( from CSQ: NOCHelpdesk )&quot;\r\ncurl -i -XPOST &quot;1.2.3.4:8086/write?db=nocdb&quot; --data-binary &quot;uccxstats,host=uccx,user=druser value=167914&quot;\r\n```\r\n\r\n## Finishing up\r\n\r\nThat `select(…)` will generate **no** `curl` requests if any of those fields are missing or null.\r\n\r\nIf you want to, you can expand that like this:\r\n\r\n```\r\n$ influxdbIP=1.2.3.4 jq -r &#39;.VoiceCSQDetailsStats | { id: .agentId, name: .agentName, state: .agentState, stateDuration: .agentStateDuration } | select(.id and .name and .state and .stateDuration and ( .state != &quot;Not Ready&quot; ) ) | .id as $id | ( .name, .state, .stateDuration) | &quot;curl -i -XPOST \\&quot;\\( $ENV | .influxdbIP):8086/write?db=nocdb\\&quot; --data-binary \\&quot;uccxstats,host=uccx,user=\\($id) value=\\(.)\\&quot;&quot;&#39; &lt; eptesicus.json\r\ncurl -i -XPOST &quot;1.2.3.4:8086/write?db=nocdb&quot; --data-binary &quot;uccxstats,host=uccx,user=yuser value=Your User&quot;\r\ncurl -i -XPOST &quot;1.2.3.4:8086/write?db=nocdb&quot; --data-binary &quot;uccxstats,host=uccx,user=yuser value=Talking&quot;\r\ncurl -i -XPOST &quot;1.2.3.4:8086/write?db=nocdb&quot; --data-binary &quot;uccxstats,host=uccx,user=yuser value=626160&quot;\r\ncurl -i -XPOST &quot;1.2.3.4:8086/write?db=nocdb&quot; --data-binary &quot;uccxstats,host=uccx,user=euser value=Everyones User&quot;\r\ncurl -i -XPOST &quot;1.2.3.4:8086/write?db=nocdb&quot; --data-binary &quot;uccxstats,host=uccx,user=euser value=Ready&quot;\r\ncurl -i -XPOST &quot;1.2.3.4:8086/write?db=nocdb&quot; --data-binary &quot;uccxstats,host=uccx,user=euser value=203631&quot;\r\ncurl -i -XPOST &quot;1.2.3.4:8086/write?db=nocdb&quot; --data-binary &quot;uccxstats,host=uccx,user=druser value=Drug User&quot;\r\ncurl -i -XPOST &quot;1.2.3.4:8086/write?db=nocdb&quot; --data-binary &quot;uccxstats,host=uccx,user=druser value=Talking ( from CSQ: NOCHelpdesk )&quot;\r\ncurl -i -XPOST &quot;1.2.3.4:8086/write?db=nocdb&quot; --data-binary &quot;uccxstats,host=uccx,user=druser value=167914&quot;\r\n```\r\n\r\nNote that it generates no `curl` requests for agents in state &quot;Not Ready&quot;.",
                "title": "Bash - Parse JSON for use with InfluxDB"
            }
        ],
        "is_answered": false,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1573089588,
        "creation_date": 1533663667,
        "last_edit_date": 1533668365,
        "question_id": 51732540,
        "body_markdown": "I&#39;ve done some simpler scripts successfully to parse data from json to import into InfluxDB (and to view in Grafana), but this one is much trickier than what I&#39;m used to. Cisco UCCX/Finesse&#39;s VoiceCSQDetailsStats API looks like the below json. What I want to do is to have a loop going to parse the below json, and poll the individual user data (agentId, agentName, agentState, and agentState Duration based on each id) to InfluxDB using the bottom curls. How would I go about accomplishing this with bash?\r\n\r\nSave the data below as the following variables:\r\n\r\n    jsonAgentId=&quot;id&quot;\r\n    jsonAgentName=&quot;agentName&quot;\r\n    jsonAgentState=&quot;agentState&quot;\r\n    jsonAgentStateDuration=&quot;agentStateDuration&quot;\r\n\r\nVoiceCSQDetailsStats json:\r\n\r\n    {\r\n      &quot;id&quot;: &quot;muser&quot;,\r\n      &quot;operation&quot;: &quot;UPDATE&quot;,\r\n      &quot;VoiceCSQDetailsStats&quot;: {\r\n        &quot;agentId&quot;: &quot;muser&quot;,\r\n        &quot;agentName&quot;: &quot;My User&quot;,\r\n        &quot;agentState&quot;: &quot;Not Ready&quot;,\r\n        &quot;skillGroup&quot;: &quot;&quot;,\r\n        &quot;agentStateDuration&quot;: 982761,\r\n        &quot;reason&quot;: &quot;Break&quot;,\r\n        &quot;AgentVoiceCSQNames&quot;: [\r\n          {\r\n            &quot;agentVoiceCSQName&quot;: &quot;Dispatcher&quot;\r\n          },\r\n          {\r\n            &quot;agentVoiceCSQName&quot;: &quot;NOCEscalation&quot;\r\n          },\r\n          {\r\n            &quot;agentVoiceCSQName&quot;: &quot;NOCHelpdesk&quot;\r\n          }\r\n        ]\r\n      }\r\n    }\r\n    {\r\n      &quot;id&quot;: &quot;yuser&quot;,\r\n      &quot;operation&quot;: &quot;UPDATE&quot;,\r\n      &quot;VoiceCSQDetailsStats&quot;: {\r\n        &quot;agentId&quot;: &quot;yuser&quot;,\r\n        &quot;agentName&quot;: &quot;Your User&quot;,\r\n        &quot;agentState&quot;: &quot;Talking&quot;,\r\n        &quot;skillGroup&quot;: &quot;&quot;,\r\n        &quot;agentStateDuration&quot;: 626160,\r\n        &quot;reason&quot;: &quot;&quot;,\r\n        &quot;AgentVoiceCSQNames&quot;: [\r\n          {\r\n            &quot;agentVoiceCSQName&quot;: &quot;Dispatcher&quot;\r\n          },\r\n          {\r\n            &quot;agentVoiceCSQName&quot;: &quot;NOCHelpdesk&quot;\r\n          }\r\n        ]\r\n      }\r\n    }\r\n    {\r\n      &quot;id&quot;: &quot;euser&quot;,\r\n      &quot;operation&quot;: &quot;UPDATE&quot;,\r\n      &quot;VoiceCSQDetailsStats&quot;: {\r\n        &quot;agentId&quot;: &quot;euser&quot;,\r\n        &quot;agentName&quot;: &quot;Everyones User&quot;,\r\n        &quot;agentState&quot;: &quot;Ready&quot;,\r\n        &quot;skillGroup&quot;: &quot;&quot;,\r\n        &quot;agentStateDuration&quot;: 203631,\r\n        &quot;reason&quot;: &quot;&quot;,\r\n        &quot;AgentVoiceCSQNames&quot;: [\r\n          {\r\n            &quot;agentVoiceCSQName&quot;: &quot;NOCHelpdesk&quot;\r\n          },\r\n          {\r\n            &quot;agentVoiceCSQName&quot;: &quot;NOCEscalation&quot;\r\n          }\r\n        ]\r\n      }\r\n    }\r\n    {\r\n      &quot;id&quot;: &quot;duser&quot;,\r\n      &quot;operation&quot;: &quot;UPDATE&quot;,\r\n      &quot;VoiceCSQDetailsStats&quot;: {\r\n        &quot;agentId&quot;: &quot;duser&quot;,\r\n        &quot;agentName&quot;: &quot;Dumb User&quot;,\r\n        &quot;agentState&quot;: &quot;Not Ready&quot;,\r\n        &quot;skillGroup&quot;: &quot;&quot;,\r\n        &quot;agentStateDuration&quot;: 175342,\r\n        &quot;reason&quot;: &quot;Call Not Answered&quot;,\r\n        &quot;AgentVoiceCSQNames&quot;: [\r\n          {\r\n            &quot;agentVoiceCSQName&quot;: &quot;NOCEscalation&quot;\r\n          },\r\n          {\r\n            &quot;agentVoiceCSQName&quot;: &quot;NOCHelpdesk&quot;\r\n          }\r\n        ]\r\n      }\r\n    }\r\n    {\r\n      &quot;id&quot;: &quot;fuser&quot;,\r\n      &quot;operation&quot;: &quot;UPDATE&quot;,\r\n      &quot;VoiceCSQDetailsStats&quot;: {\r\n        &quot;agentId&quot;: &quot;fuser&quot;,\r\n        &quot;agentName&quot;: &quot;Foolish User&quot;,\r\n        &quot;agentState&quot;: &quot;Not Ready&quot;,\r\n        &quot;skillGroup&quot;: &quot;&quot;,\r\n        &quot;agentStateDuration&quot;: 1057520,\r\n        &quot;reason&quot;: &quot;Offhook&quot;,\r\n        &quot;AgentVoiceCSQNames&quot;: [\r\n          {\r\n            &quot;agentVoiceCSQName&quot;: &quot;NOCEscalation&quot;\r\n          },\r\n          {\r\n            &quot;agentVoiceCSQName&quot;: &quot;NOCHelpdesk&quot;\r\n          }\r\n        ]\r\n      }\r\n    }\r\n    {\r\n      &quot;id&quot;: &quot;druser&quot;,\r\n      &quot;operation&quot;: &quot;UPDATE&quot;,\r\n      &quot;VoiceCSQDetailsStats&quot;: {\r\n        &quot;agentId&quot;: &quot;druser&quot;,\r\n        &quot;agentName&quot;: &quot;Drug User&quot;,\r\n        &quot;agentState&quot;: &quot;Talking ( from CSQ: NOCHelpdesk )&quot;,\r\n        &quot;skillGroup&quot;: &quot;NOCHelpdesk&quot;,\r\n        &quot;agentStateDuration&quot;: 167914,\r\n        &quot;reason&quot;: &quot;Offhook&quot;,\r\n        &quot;AgentVoiceCSQNames&quot;: [\r\n          {\r\n            &quot;agentVoiceCSQName&quot;: &quot;NOCEscalation&quot;\r\n          },\r\n          {\r\n            &quot;agentVoiceCSQName&quot;: &quot;NOCHelpdesk&quot;\r\n          }\r\n        ]\r\n      }\r\n    }\r\n\r\nSend to InfluxDB:\r\n\r\n    curl -i -XPOST &quot;$influxdbIP:8086/write?db=nocdb&quot; --data-binary &quot;uccxstats,host=uccx,user=$jsonAgentId value=$jsonAgentName&quot;\r\n    curl -i -XPOST &quot;$influxdbIP:8086/write?db=nocdb&quot; --data-binary &quot;uccxstats,host=uccx,user=$jsonAgentId value=$jsonAgentState&quot;\r\n    curl -i -XPOST &quot;$influxdbIP:8086/write?db=nocdb&quot; --data-binary &quot;uccxstats,host=uccx,user=$jsonAgentId value=$jsonAgentStateDuration&quot;\r\n\r\nUsing jq, I had considered doing the below, but I&#39;ll still need for it to loop through the users and stop once jq -c &#39;.[n]&#39; returns null. \r\n\r\n    curl &#39;http://10.10.66.16:9080/realtime/VoiceCSQDetailsStats&#39; | jq -c &#39;.[6]&#39; | grep -oP &#39;(?&lt;=&quot;id&quot;:&quot;)[^.&quot;]*&#39;\r\n    druser\r\n    \r\n    curl &#39;http://10.10.66.16:9080/realtime/VoiceCSQDetailsStats&#39; | jq -c &#39;.[6]&#39; | grep -oP &#39;(?&lt;=&quot;agentName&quot;:&quot;)[^.&quot;]*&#39;\r\n    Drug User\r\n    \r\n    curl &#39;http://10.10.66.16:9080/realtime/VoiceCSQDetailsStats&#39; | jq -c &#39;.[6]&#39; | grep -oP &#39;(?&lt;=&quot;agentState&quot;:&quot;)[^.&quot;]*&#39;\r\n    Ready\r\n    \r\n    curl &#39;http://10.10.66.16:9080/realtime/VoiceCSQDetailsStats&#39; | jq -c &#39;.[6]&#39; | grep -oP &#39;(?&lt;=&quot;agentStateDuration&quot;:)[^.,]*&#39;\r\n    167914\r\n    \r\n    curl &#39;http://10.10.66.16:9080/realtime/VoiceCSQDetailsStats&#39; | jq -c &#39;.[6]&#39; | grep -oP &#39;(?&lt;=&quot;reason&quot;:&quot;)[^.&quot;]*&#39;\r\n    Offhook\r\n\r\n\r\n\r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/51732540/bash-parse-json-for-use-with-influxdb",
        "title": "Bash - Parse JSON for use with InfluxDB"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1533681908,
                "creation_date": 1533681908,
                "answer_id": 51736407,
                "question_id": 51735996,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use the `transpose` function for this. For example,\r\n\r\n    $ jq -r &#39;[.value[]] | transpose[] | join (&quot; &quot;)&#39; tmp.json\r\n    el11 el21 el31\r\n    el12 el22 el32\r\n    el13 el23 el33\r\n    el14 el24 el34",
                "title": "print elements from multiple lists by index with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1533681908,
        "creation_date": 1533679074,
        "question_id": 51735996,
        "body_markdown": "I have a json with 3 equal lists:\r\n\r\n    {\r\n        &quot;value&quot;: {\r\n            &quot;list1&quot;: [\r\n                &quot;el11&quot;,\r\n                &quot;el12&quot;,\r\n                &quot;el13&quot;,\r\n                &quot;el14&quot;\r\n            ],\r\n            &quot;list2&quot;: [\r\n                &quot;el21&quot;,\r\n                &quot;el22&quot;,\r\n                &quot;el23&quot;,\r\n                &quot;el24&quot;\r\n            ],\r\n            &quot;list3&quot;: [\r\n                &quot;el31&quot;,\r\n                &quot;el32&quot;,\r\n                &quot;el33&quot;,\r\n                &quot;el34&quot;\r\n            ]\r\n        }\r\n    }\r\n\r\nI&#39;m trying to extract from each list the elements with the same index:\r\n\r\n    el11 el21 el31\r\n    ...\r\n    el13 el23 el33\r\n\r\nIdeally those need to be exported as ENV values. But I just want to know if it&#39;s possible to do that with jq. And how.\r\n\r\nThank you",
        "link": "https://stackoverflow.com/questions/51735996/print-elements-from-multiple-lists-by-index-with-jq",
        "title": "print elements from multiple lists by index with jq"
    },
    {
        "tags": [
            "json",
            "linux",
            "bash",
            "csv",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 173557,
                    "reputation": 24077,
                    "user_id": 402322,
                    "user_type": "registered",
                    "accept_rate": 67,
                    "profile_image": "https://i.sstatic.net/GWEWt.gif?s=256",
                    "display_name": "ceving",
                    "link": "https://stackoverflow.com/users/402322/ceving"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1533714292,
                "post_id": 51737608,
                "comment_id": 90442379,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 14102450,
                    "reputation": 19,
                    "user_id": 10194161,
                    "user_type": "registered",
                    "profile_image": "https://lh6.googleusercontent.com/-HGK1Axq8qek/AAAAAAAAAAI/AAAAAAAAA9Q/PA5js_qjGRk/s256-rj/photo.jpg",
                    "display_name": "kdetony",
                    "link": "https://stackoverflow.com/users/10194161/kdetony"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1533734663,
                "post_id": 51737608,
                "comment_id": 90455472,
                "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": 1533746869,
                "post_id": 51737608,
                "comment_id": 90463394,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 14102450,
                    "reputation": 19,
                    "user_id": 10194161,
                    "user_type": "registered",
                    "profile_image": "https://lh6.googleusercontent.com/-HGK1Axq8qek/AAAAAAAAAAI/AAAAAAAAA9Q/PA5js_qjGRk/s256-rj/photo.jpg",
                    "display_name": "kdetony",
                    "link": "https://stackoverflow.com/users/10194161/kdetony"
                },
                "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": 1533754281,
                "post_id": 51737608,
                "comment_id": 90467279,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1533829917,
                "last_edit_date": 1533829917,
                "creation_date": 1533746763,
                "answer_id": 51751770,
                "question_id": 51737608,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With your input, the following filter:\r\n \r\n\r\n    .conversations[]\r\n    | [.conversationId]\r\n      + (.participants[] | [.participantId, .participantName])\r\n\r\n\r\nproduces:\r\n\r\n    [\r\n      &quot;cxx-cccc-4444-9999-b11111111&quot;,\r\n      &quot;2aaaa-1555-4590-99aa-4yyyyyyy&quot;,\r\n      null\r\n    ]\r\n    [\r\n      &quot;cxx-cccc-4444-9999-b11111111&quot;,\r\n      &quot;e9e9e9-d777-4a4a-8989-aeaeaeaeae&quot;,\r\n      &quot;Namek, Sayayin&quot;\r\n    ]\r\n    [\r\n      &quot;09090909-6b60-8888-xxxx-9yyyyyyyy&quot;,\r\n      &quot;xxxc-cccc1-4123-7777-343434343e&quot;,\r\n      null\r\n    ]\r\n\r\n## Variant\r\n\r\nNotice that the above filter does not use any jq variables.  Sometimes it is helpful to introduce them, so the following variant may be of interest:\r\n\r\n    .conversations[]\r\n    | (.participants | range(0;length)) as $j\r\n    | [.conversationId]\r\n      + (.participants[$j] | [.participantId, .participantName])\r\n\r\nWith the help of the jq manual, you should be able to take it from here.\r\n\r\n\r\n## Addendum\r\n&gt; ParticipantId(1),sessionId(1),mediaType(1),sessionId(1),ani(1),dnis(1)\r\n\r\nI&#39;m not quite sure why you would want `sessionsId` twice, but the following corresponds to your second request:\r\n\r\n    .conversations[].participants[]\r\n    | [.participantId] +\r\n       (.sessions[] | [.sessionId, .mediaType, .sessionId, .ani, .dnis])\r\n\r\n",
                "title": "jq query format csv export"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1533930396,
        "creation_date": 1533693513,
        "last_edit_date": 1533930396,
        "question_id": 51737608,
        "body_markdown": "I have a script bash with JQ, but do not know how to perform the query to get the following result: \r\n\r\nconversationId(1),participantId(1),participantName(1),sessionId(1)\r\nconversationId(1),participantId(2),participantName(2),sessionId(2)\r\nconversationId(1),participantId(3),participantName(3),sessionId(3)\r\nconversationId(2),participantId(4),participantName(4),sessionId(4)\r\n.\r\n.\r\n.\r\nconversationId(n),participantId(n),participantName(n),sessionId(n)\r\n\r\nmy file: data.json\r\n\r\n    {\r\n        &quot;conversations&quot;: [\r\n            {\r\n                &quot;conversationId&quot;: &quot;cxx-cccc-4444-9999-b11111111&quot;,\r\n                &quot;conversationStart&quot;: &quot;2016-06-5T00:10:15.412Z&quot;,\r\n                &quot;conversationEnd&quot;: &quot;2016-06-5T00:11:19.447Z&quot;,\r\n                &quot;participants&quot;: [\r\n                    {\r\n                        &quot;participantId&quot;: &quot;2aaaa-1555-4590-99aa-4yyyyyyy&quot;,\r\n                        &quot;userId&quot;: &quot;91111-7rrrr-4000-aqaa-23232323&quot;,\r\n                        &quot;purpose&quot;: &quot;user&quot;,\r\n                        &quot;sessions&quot;: [\r\n                            {\r\n                                &quot;mediaType&quot;: &quot;voice&quot;,\r\n                                &quot;sessionId&quot;: &quot;1111111-aaaa-4009-9000-488888&quot;,\r\n                                &quot;ani&quot;: &quot;sip:user+localhost.com@localhost&quot;,\r\n                                &quot;direction&quot;: &quot;outbound&quot;,\r\n                                &quot;dnis&quot;: &quot;tel:+1111110000&quot;,\r\n                                &quot;edgeId&quot;: &quot;e3e3e3-4&#170;4q-4b4b-9792-95959595&quot;,\r\n                                &quot;segments&quot;: [\r\n                                    {\r\n                                 &quot;segmentStart&quot;: &quot;2016-06-15T00:10:15.412Z&quot;,\r\n                                 &quot;segmentEnd&quot;: &quot;2016-06-15T00:10:10.485Z&quot;,\r\n                                &quot;segmentType&quot;: &quot;contacting&quot;,\r\n                                        &quot;conference&quot;: false\r\n                                    },\r\n                                    {\r\n                                 &quot;segmentStart&quot;: &quot;2016-06-15T00:10:10.485Z&quot;,\r\n                                 &quot;segmentEnd&quot;: &quot;2016-06-15T00:10:10.522Z&quot;,\r\n                                  &quot;segmentType&quot;: &quot;dialing&quot;,\r\n                                   &quot;conference&quot;: false\r\n                                    },\r\n                                    {\r\n                                  &quot;segmentStart&quot;: &quot;2016-06-15T00:20:10.522Z&quot;,\r\n                                  &quot;segmentEnd&quot;: &quot;2016-06-15T00:11:09.436Z&quot;,\r\n                                  &quot;disconnectType&quot;: &quot;client&quot;,\r\n                                   &quot;segmentType&quot;: &quot;interact&quot;,\r\n                                    &quot;conference&quot;: false\r\n                                    }\r\n                                ]\r\n                            }\r\n                        ]\r\n                    },\r\n                    {\r\n                     &quot;participantId&quot;: &quot;e9e9e9-d777-4a4a-8989-aeaeaeaeae&quot;,\r\n                        &quot;participantName&quot;: &quot;Namek, Sayayin&quot;,\r\n                        &quot;purpose&quot;: &quot;ivr&quot;,\r\n                        &quot;sessions&quot;: [\r\n                            {\r\n                                &quot;mediaType&quot;: &quot;voice&quot;,\r\n                               &quot;sessionId&quot;: &quot;262626-6000-4cdd-a511-fafafafa&quot;,\r\n                               &quot;ani&quot;: &quot;sip:goku%localhost.com@localhost&quot;,\r\n                               &quot;direction&quot;: &quot;inbound&quot;,\r\n                              &quot;edgeId&quot;: &quot;e3e3e3e3-4abc-4abc-9700-95959595&quot;,\r\n                                &quot;remoteNameDisplayable&quot;: &quot;Namek, Sayayin&quot;,\r\n                                &quot;segments&quot;: [\r\n                                    {\r\n                                  &quot;segmentStart&quot;: &quot;2016-06-15T00:10:10.510Z&quot;,\r\n                                  &quot;segmentEnd&quot;: &quot;2016-06-15T00:10:10.521Z&quot;,\r\n                                  &quot;segmentType&quot;: &quot;system&quot;,\r\n                                        &quot;conference&quot;: false\r\n                                    },\r\n                                    {\r\n                                 &quot;segmentStart&quot;: &quot;2016-06-15T00:10:20.521Z&quot;,\r\n                                 &quot;segmentEnd&quot;: &quot;2016-06-15T00:11:39.447Z&quot;,\r\n                                  &quot;disconnectType&quot;: &quot;peer&quot;,\r\n                                        &quot;segmentType&quot;: &quot;ivr&quot;,\r\n                                        &quot;conference&quot;: false\r\n                                    }\r\n                                ]\r\n                            }\r\n                        ]\r\n                    }\r\n                ]\r\n            },\r\n            {\r\n                &quot;conversationId&quot;: &quot;09090909-6b60-8888-xxxx-9yyyyyyyy&quot;,\r\n                &quot;conversationStart&quot;: &quot;2016-06-15T00:11:38.867Z&quot;,\r\n                &quot;conversationEnd&quot;: &quot;2016-06-15T01:54:55.744Z&quot;,\r\n                &quot;participants&quot;: [\r\n                    {\r\n                        &quot;participantId&quot;: &quot;xxxc-cccc1-4123-7777-343434343e&quot;,\r\n                        &quot;userId&quot;: &quot;9qwer-7zxc-40df-aghj-2323232323&quot;,\r\n                        &quot;purpose&quot;: &quot;user&quot;,\r\n                        &quot;sessions&quot;: [\r\n                            {\r\n                                &quot;mediaType&quot;: &quot;voice&quot;,\r\n                                &quot;sessionId&quot;: &quot;101010-0faz-4xxx-yyyy-4419441&quot;,\r\n                                &quot;ani&quot;: &quot;sip:goku+localhost.com@localhost&quot;,\r\n                                &quot;direction&quot;: &quot;outbound&quot;,\r\n                                &quot;dnis&quot;: &quot;tel:+11112222333&quot;,\r\n                                &quot;edgeId&quot;: &quot;nenene1-qwer-tyui-9000-9595gggh&quot;,\r\n                                &quot;segments&quot;: [\r\n                                   {\r\n                                  &quot;segmentStart&quot;: &quot;2016-06-15T00:11:18.867Z&quot;,\r\n                                  &quot;segmentEnd&quot;: &quot;2016-06-15T00:11:42.637Z&quot;,\r\n                                  &quot;segmentType&quot;: &quot;contacting&quot;,\r\n                                    &quot;conference&quot;: false\r\n                                    }\r\n                                    ]\r\n                            } ]\r\n                    } ]\r\n            } ]\r\n    }\r\n\r\n\r\nmy query jq:\r\n\r\n&gt; jq . &#39;{conversationId: .conversations[].conversationId, \r\n&gt; participantId:\r\n&gt; .conversations[].participants[].participantId,participantName:\r\n&gt; .conversations[].participants[].participantName} |  join(&quot;,&quot;)&#39;\r\n\r\nbut the fields conversationId and participantName are repeated several times ...",
        "link": "https://stackoverflow.com/questions/51737608/jq-query-format-csv-export",
        "title": "jq query format csv export"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 6,
                "is_accepted": false,
                "score": 6,
                "last_activity_date": 1560446938,
                "last_edit_date": 1560446938,
                "creation_date": 1533779822,
                "answer_id": 51757819,
                "question_id": 51757559,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Unfortunately, jq 1.5 does not include the enhancement regarding &quot;name&quot;.\r\n\r\n(Please note that the jq 1.5 documentation correctly advertises &quot;Name&quot; as an alternative to &quot;key&quot;, but not &quot;name&quot;.)  \r\n\r\nYou will either have to upgrade your jq, or use a workaround, such as:\r\n\r\n    map(with_entries(if .key == &quot;name&quot; then .key = &quot;key&quot; else . end))\r\n    | from_entries\r\n\r\nor more generically:\r\n\r\n    def from_entries(key; value):\r\n      map( {(key): value} ) | add | . // {} ;\r\n   \r\n    from_entries(.name; .value)",
                "title": "jq from_entries function works with &#39;key&#39; but not &#39;name&#39;"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1560446938,
        "creation_date": 1533777056,
        "question_id": 51757559,
        "body_markdown": "According to [the documentation][1] the from_entries function works with objects that look like `{&quot;key&quot;: something, &quot;value&quot;: something}`, or `{&quot;name&quot;: something, &quot;value&quot;: something}`. However, the second form is not working for me. The example from the docs works:\r\n\r\n    $ echo &#39;[{&quot;key&quot;:&quot;a&quot;, &quot;value&quot;:1}, {&quot;key&quot;:&quot;b&quot;, &quot;value&quot;:2}]&#39; | jq from_entries\r\n    {\r\n      &quot;a&quot;: 1,\r\n      &quot;b&quot;: 2\r\n    }\r\n\r\nbut the same example, except using &quot;name&quot; instead of &quot;key&quot; does not:\r\n\r\n    $ echo &#39;[{&quot;name&quot;:&quot;a&quot;, &quot;value&quot;:1}, {&quot;name&quot;:&quot;b&quot;, &quot;value&quot;:2}]&#39; | jq from_entries\r\n    jq: error (at &lt;stdin&gt;:1): Cannot use null (null) as object key\r\n\r\nWhy is this? My jq version is\r\n\r\n    $ jq --version\r\n    jq-1.5-1-a5b5cbe\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/v1.5/#to_entries,from_entries,with_entries\r\n\r\n",
        "link": "https://stackoverflow.com/questions/51757559/jq-from-entries-function-works-with-key-but-not-name",
        "title": "jq from_entries function works with &#39;key&#39; but not &#39;name&#39;"
    },
    {
        "tags": [
            "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": 1533799730,
                "post_id": 51760871,
                "comment_id": 90481195,
                "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": 1533801276,
                "post_id": 51760871,
                "comment_id": 90482080,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 0,
        "last_activity_date": 1533798819,
        "creation_date": 1533798819,
        "question_id": 51760871,
        "body_markdown": "I am trying to following the manual and examples out there and its not especially clear on how to handle colons element name if you want to specifically within a JQ output without outputting the entire structure.\r\n\r\n    Raw:{&quot;UpdateResponseMessage&quot;:{&quot;Header&quot;:{&quot;com:TransactionID&quot;:&quot;5e5b1750-7be7-11e8-886a-838029aca397&quot;,&quot;com:TimeStamp&quot;:&quot;2018-06-29T21:57:08.549Z&quot;,&quot;com:SourceSystem&quot;:&quot;Call&quot;,&quot;com:Status&quot;:&quot;Success&quot;}},&quot;level&quot;:&quot;info&quot;,&quot;message&quot;:&quot;UpdateResponseMessage being sent.&quot;,&quot;timestamp&quot;:&quot;2018-06-29T21:57:08.549Z&quot;}\r\n\r\nThe output of ` jq-win64 [.] test.log` is the following:\r\n\r\n     [  {\r\n    &quot;UpdateResponseMessage&quot;: {\r\n      &quot;Header&quot;: {\r\n        &quot;com:TransactionID&quot;: &quot;5e5b1750-7be7-11e8-886a-838029aca397&quot;,\r\n        &quot;com:TimeStamp&quot;: &quot;2018-06-29T21:57:08.549Z&quot;,\r\n        &quot;com:SourceSystem&quot;: &quot;Call&quot;,\r\n        &quot;com:Status&quot;: &quot;Success&quot;\r\n      }\r\n    },\r\n]\r\n\r\nI am attempting to call just &quot;com:Status&quot; and &quot;com:TransactionID&quot; but it either gives me a syntax error (INVALID_CHARACTER) or turns out no data &quot;null&quot; with everything I have tried.\r\n\r\nThe following outputs &quot;null&quot; for TransactionID and Status.\r\n\r\n\r\nThere were previous reports of people trying to figure out (issue [741][1], [745][2] with the suggestion to use `jq &lt;x.json &#39;.[&quot;key::name&quot;]&#39;`and similar [questions][3] the above code for [JSON.net][4] as well as some variations have tried to follow the guidance but the [JQ manual][5] has no examples specifically addressing this situation either. \r\n\r\nThe following at least doesn&#39;t error, but it doesn&#39;t output the values, just &quot;NULL&quot; for the two elements containing the &quot;:&quot; in their name.. if I add the ``` mark like I have in the commented out field I get &quot;Invalid_Character&quot; again.\r\n\r\n    \t\t     elif .UpdateResponseMessage then \r\n                # ( .UpdateResponseMessage .Header | [`.[&quot;com::TransactionID&quot;]`] ) \r\n\t\t\t\t ( .UpdateResponseMessage .Header | [&quot;Response&quot;, `.[&quot;com::TransactionID&quot;], .[&quot;com::Status&quot;]] ) \r\n\r\nOutput:\r\n\r\n   &quot;Response&quot;,&quot;null&quot;,&quot;null&quot;\r\n\r\nBut what I need is: \r\n\r\n   &quot;Response&quot;,&quot;5e5b1750-7be7-11e8-886a-838029aca397&quot;,&quot;Success&quot;\r\n\r\n  [1]: https://github.com/stedolan/jq/issues/741\r\n  [2]: https://github.com/stedolan/jq/pull/745\r\n  [3]: https://stackoverflow.com/questions/49427529/accessing-field-with-jq-that-contains-a-special-character-and-can-be-an-object-o\r\n  [4]: https://stackoverflow.com/questions/22089319/parsing-field-name-with-a-colon-in-json\r\n  [5]: https://stedolan.github.io/jq/manual/#ConditionalsandComparisons",
        "link": "https://stackoverflow.com/questions/51760871/directly-accessing-a-json-element-with-a-colon-special-character-in-element-na",
        "title": "Directly accessing a JSON element with a colon / special character in element Name with JQ"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1533895368,
                "creation_date": 1533895368,
                "answer_id": 51784010,
                "question_id": 51783807,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You shouldn&#39;t use `contains/1` as it will not work the way you might expect it, particularly if you&#39;re dealing with strings. It will recursively check if all parts are contained. So not only will it check if the string is contained in the array, but if the string is also a substring.\r\n\r\nYou&#39;ll want to write out your conditions checking any and all tags against your criteria.\r\n\r\n    [.servers[] | select(any(.tagNames[]; . == &quot;auto-test&quot;) and all(.tagNames[]; . != &quot;auto-test2&quot;))]",
                "title": "select array by any element exactly matched to specified value"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1533910883,
                "creation_date": 1533910883,
                "answer_id": 51788549,
                "question_id": 51783807,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "One way would be to use `index/1`, e.g.\r\n\r\n    .servers[]\r\n    | select( .tagNames | index(&quot;auto-test&quot;))\r\n\r\nThis produces:\r\n\r\n    {&quot;id&quot;:1,&quot;tagNames&quot;:[&quot;auto-test&quot;,&quot;xxx&quot;]}\r\n\r\nIf you want that wrapped in an array, you could (for example) wrap the filter above in square brackets.  ",
                "title": "select array by any element exactly matched to specified value"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1534144043,
                "creation_date": 1534144043,
                "answer_id": 51816847,
                "question_id": 51783807,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Another solution is to use the idiom: first(select(_)):\r\n\r\n    jq &#39;.servers[] | first(select(.tagNames[]==&quot;auto-test&quot;))&#39; file\r\n\r\nIf the `first` is omitted, then the same item in the `servers` array might be emitted more than once.",
                "title": "select array by any element exactly matched to specified value"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1534144043,
        "creation_date": 1533894796,
        "last_edit_date": 1533895432,
        "question_id": 51783807,
        "body_markdown": "Anyone know to how to implement this?\r\n\r\nI have an array which has a nested array, say tagNames, I want to select all item which tagNames contains &quot;auto-test&quot; exactly, not &quot;auto-test2&quot;. \r\n\r\n    {\r\n      &quot;servers&quot;:[\r\n          {&quot;id&quot;:1, &quot;tagNames&quot;: [&quot;auto-test&quot;,  &quot;xxx&quot;]},\r\n          {&quot;id&quot;:2, &quot;tagNames&quot;: [&quot;auto-test2&quot;, &quot;xxxx&quot;]}\r\n      ]\r\n    }\r\n\r\nSo far, I am using\r\n\r\n    echo &#39;{&quot;servers&quot;:[{&quot;id&quot;:1,&quot;tagNames&quot;:[&quot;auto-test&quot;,&quot;xxx&quot;]},{&quot;id&quot;:2,&quot;tagNames&quot;:[&quot;auto-test2&quot;,&quot;xxxx&quot;]}]}&#39; |\\\r\n    jq  &#39;[ .servers[] | select(.tagNames | contains([&quot;auto-test&quot;])) ]&#39;\r\n\r\nI got two records, but I just want the first one.\r\n\r\n    [\r\n      {\r\n        &quot;id&quot;: 1,\r\n        &quot;tagNames&quot;: [\r\n          &quot;auto-test&quot;,\r\n          &quot;xxx&quot;\r\n        ]\r\n      },\r\n      {\r\n        &quot;id&quot;: 2,\r\n        &quot;tagNames&quot;: [\r\n          &quot;auto-test2&quot;,\r\n          &quot;xxxx&quot;\r\n        ]\r\n      }\r\n    ]\r\n\r\nSo I want this:\r\n\r\n    [\r\n      {\r\n        &quot;id&quot;: 1,\r\n        &quot;tagNames&quot;: [\r\n          &quot;auto-test&quot;,\r\n          &quot;xxx&quot;\r\n        ]\r\n      }\r\n    ]\r\n\r\nAny idea?\r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/51783807/select-array-by-any-element-exactly-matched-to-specified-value",
        "title": "select array by any element exactly matched to specified value"
    },
    {
        "tags": [
            "json",
            "functional-programming",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1533912578,
                "last_edit_date": 1533912578,
                "creation_date": 1533911614,
                "answer_id": 51788768,
                "question_id": 51787648,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Thanks to the magic of jq, you could just write:\r\n\r\n    (.fieldOne, .fieldTwo) |= .*3\r\n\r\nMore generically, here are two other approaches.\r\n\r\n## multiop/2\r\n    # If the input is an object, $fields should be an array of key names\r\n    # If the input is an array, $fields should be an array of integers\r\n    def multiop($fields; f):\r\n      if $fields|length == 0 then .\r\n      else .[$fields[0]] |= f\r\n      | multiop($fields[1:]; f)\r\n      end;\r\n\r\n    multiop([&quot;fieldOne&quot;, &quot;fieldTwo&quot;]; . * 3)\r\n\r\nOr, if you want the operation applied to all fields:\r\n\r\n    multiop( keys_unsorted; .*3)\r\n\r\n## triple/1\r\n\r\n    def triple(f): f |= . * 3;\r\n    \r\n    triple(.fieldOne, .fieldTwo)\r\n",
                "title": "Perform the same operation on multiple JSON fields using JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1533912578,
        "creation_date": 1533907675,
        "last_edit_date": 1533911729,
        "question_id": 51787648,
        "body_markdown": "I&#39;m trying to change the values of multiple fields in a JSON object using JQ. However, I want to perform the same operation on each of these fields. I accomplished this, but the way I did seems redundant.\r\n\r\n`jq &#39;.fieldOne |= . * 3 | .fieldTwo |= . * 3 | ...&#39;`\r\n\r\nIs there a way of doing something along the lines of this: (not exactly this because JQ won&#39;t work like that)\r\n\r\n`jq &#39;(.fieldOne | .fieldTwo | ...) |= . * 3&#39;`",
        "link": "https://stackoverflow.com/questions/51787648/perform-the-same-operation-on-multiple-json-fields-using-jq",
        "title": "Perform the same operation on multiple JSON fields using JQ"
    },
    {
        "tags": [
            "json",
            "bash",
            "csv",
            "parsing",
            "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": 1534186926,
                "post_id": 51793855,
                "comment_id": 90612341,
                "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": 1534201344,
                "post_id": 51793855,
                "comment_id": 90617414,
                "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": 1534201395,
                "post_id": 51793855,
                "comment_id": 90617423,
                "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": 1534201553,
                "post_id": 51793855,
                "comment_id": 90617464,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1533935333,
                "last_edit_date": 1533935333,
                "creation_date": 1533934759,
                "answer_id": 51793982,
                "question_id": 51793855,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "    string=&quot;key1=value1,key2=value2&quot;\r\n\r\n    jq -Rc &#39;\r\n    split(&quot;,&quot;)\r\n    | [.[] | match( &quot;([^=]*)=(.*)&quot; )]\r\n    | reduce .[].captures as $item ({}; .[$item[0].string]=$item[1].string)\r\n    &#39; &lt;&lt;&lt;&quot;$string&quot;",
                "title": "Create JSON from string with format &quot;key1=value1,key2=value2&quot; using jq"
            },
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1534194976,
                "last_edit_date": 1534194976,
                "creation_date": 1533935868,
                "answer_id": 51794145,
                "question_id": 51793855,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a reduce-free solution that assumes `string` is the shell variable (not part of the string to be parsed), and that parsing of the string can be accomplished by first splitting on &quot;,&quot;:\r\n\r\n    jq -R &#39;split(&quot;,&quot;)\r\n           | map( index(&quot;=&quot;) as $i | {(.[0:$i]) : .[$i+1:]})\r\n           | add&#39; &lt;&lt;&lt; &quot;$string&quot;\r\n\r\nNotice that this allows &quot;=&quot; to appear within the values.\r\n\r\nThe only trickiness here is that when a key name is specified programmatically, it must be enclosed within parentheses.\r\n\r\n## Supplemental question\r\n\r\n&gt;    string=&quot;key1=value1|key2=value2,value3|key3=value4&quot;\r\n\r\nIn this case, you would first split on &quot;|&quot;, and then find the first occurrence of &quot;=&quot;:\r\n\r\n    split(&quot;|&quot;)\r\n    | map( index(&quot;=&quot;) as $i | {(.[0:$i]) : .[$i+1:]})\r\n    | add\r\n    | map_values(if index(&quot;,&quot;) then split(&quot;,&quot;) else . end)\r\n\r\n\r\n Output:\r\n\r\n    {\r\n      &quot;key1&quot;: &quot;value1&quot;,\r\n      &quot;key2&quot;: [\r\n        &quot;value2&quot;,\r\n        &quot;value3&quot;\r\n      ],\r\n      &quot;key3&quot;: &quot;value4&quot;\r\n    }",
                "title": "Create JSON from string with format &quot;key1=value1,key2=value2&quot; using jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1549889021,
                "creation_date": 1549889021,
                "answer_id": 54630886,
                "question_id": 51793855,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```\r\necho -n &quot;key1=value1,key2=value2&quot; | \\\r\njq -csR &#39;[split(&quot;,&quot;)[]|split(&quot;=&quot;) | {(.[0]): .[1]}]|add&#39;\r\n```\r\nthis gives\r\n```\r\n{&quot;key1&quot;:&quot;value1&quot;,&quot;key2&quot;:&quot;value2&quot;}\r\n```",
                "title": "Create JSON from string with format &quot;key1=value1,key2=value2&quot; using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1549889021,
        "creation_date": 1533933963,
        "last_edit_date": 1534202600,
        "question_id": 51793855,
        "body_markdown": "I&#39;m trying to create a json file from a string with the following format:\r\n\r\n    string=&quot;key1=value1,key2=value2&quot;\r\n\r\nIs there a way to create a json using jq by specifying the `=` and `,` symbols as separators for the keys and values?\r\n\r\nThe output I&#39;m looking for would be:\r\n\r\n    {&quot;key1&quot;: &quot;value1&quot;, &quot;key2” :”value2&quot;}\r\n\r\nI&#39;ve tried to use this post as a reference:\r\nhttps://stackoverflow.com/questions/38860529/create-json-using-jq-from-pipe-separated-keys-and-values-in-bash -- however, it expects input that contains a line with only keys, before later lines with only values; here, the keys and values are all interspersed.",
        "link": "https://stackoverflow.com/questions/51793855/create-json-from-string-with-format-key1-value1-key2-value2-using-jq",
        "title": "Create JSON from string with format &quot;key1=value1,key2=value2&quot; using jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": -3,
                "last_activity_date": 1533963793,
                "creation_date": 1533963793,
                "answer_id": 51796624,
                "question_id": 51796573,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You want to get the Key Value.\r\n\r\nSo use the keys command, to return &#39;RQBTYFE86MFC3oL&#39; as that is the key, the rest is the value of that key.\r\n\r\n    jq &#39;keys&#39;\r\n\r\nHere is a snippet: https://jqplay.org/s/YvpCb2PH42\r\n\r\nReference: https://stedolan.github.io/jq/manual/ ",
                "title": "Get parent value from json using jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1533965008,
                "creation_date": 1533965008,
                "answer_id": 51796731,
                "question_id": 51796573,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "A simple way to determine the key name(s) corresponding to values satisfying a certain condition is to use `to_entries`, as explained in the jq manual.  \r\n\r\nUsing this approach, the appropriate jq filter would be:\r\n\r\n    to_entries[] | select(.value.name == &quot;Nightmode&quot;) | .key \r\n\r\nwith the result:\r\n\r\n    &quot;RQBTYFE86MFC3oL&quot;\r\n\r\nIf you want to get the key-value pair, you&#39;d use `with_entries` as follows:\r\n\r\n    with_entries( select(.value.name == &quot;Nightmode&quot;) )\r\n",
                "title": "Get parent value from json using jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1534229063,
                "creation_date": 1534229063,
                "answer_id": 51835214,
                "question_id": 51796573,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If the input JSON is too large to fit comfortably in memory, then it would make sense to use jq&#39;s streaming parser (invoked with the --stream command-line option):\r\n\r\n    jq --stream &#39;\r\n      select(.[1] == &quot;Nightmode&quot; and (first|length) == 2 and first[1] == &quot;name&quot;)\r\n      | first | first&#39; \r\n\r\nThis would produce the key name. \r\n\r\nThe key idea is that the streaming parser produces arrays including pairs of the form: [ARRAYPATH, VALUE] where VALUE is the value at ARRAYPATH.\r\n\r\n",
                "title": "Get parent value from json using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1534229063,
        "creation_date": 1533963145,
        "question_id": 51796573,
        "body_markdown": "My json file looks like this;\r\n\r\n    {\r\n     &quot;RQBTYFE86MFC3oL&quot;: {\r\n        &quot;name&quot;: &quot;Nightmode&quot;,\r\n        &quot;lights&quot;: [\r\n          &quot;1&quot;,\r\n          &quot;2&quot;,\r\n          &quot;3&quot;,\r\n          &quot;4&quot;,\r\n          &quot;5&quot;,\r\n          &quot;7&quot;,\r\n          &quot;8&quot;,\r\n          &quot;9&quot;,\r\n          &quot;10&quot;,\r\n          &quot;11&quot;\r\n        ],\r\n        &quot;owner&quot;: &quot;kvovodUUfn2vlby9h9okdDhv8SrTzkBFjk6kPz2v&quot;,\r\n        &quot;recycle&quot;: false,\r\n        &quot;locked&quot;: false,\r\n        &quot;appdata&quot;: {\r\n          &quot;version&quot;: 1,\r\n          &quot;data&quot;: &quot;QSXCj_r01_d99&quot;\r\n        },\r\n        &quot;picture&quot;: &quot;&quot;,\r\n        &quot;lastupdated&quot;: &quot;2018-08-08T03:21:39&quot;,\r\n        &quot;version&quot;: 2\r\n      }\r\n    }\r\n\r\n\r\nI want to get the &#39;RQBTYFE86MFC3oL&#39; value by doing a query for &#39;Nightmode&#39;. So far I came up with this;\r\n\r\n    jq &#39;.[] | select(.name == &quot;Nightmode&quot;)&#39;\r\n\r\nThis will return me the correct part of the Json but the &#39;RQBTYFE86MFC3oL&#39; part is stripped. How do I get this part as well? \r\n",
        "link": "https://stackoverflow.com/questions/51796573/get-parent-value-from-json-using-jq",
        "title": "Get parent value from json using jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 27,
                "is_accepted": true,
                "score": 27,
                "last_activity_date": 1534237745,
                "creation_date": 1534237745,
                "answer_id": 51837735,
                "question_id": 51837624,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Good news! Your proposed solution is just missing a pair of parentheses.  Also, there is no need for `$version`.  That is, this will do it:\r\n\r\n    .basePath = (.version | split(&quot;.&quot;)\r\n                 | if .[0] == &quot;0&quot; then &quot;beta&quot;+ .[1] else .[0] end)",
                "title": "jq split string and assign"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 19,
        "last_activity_date": 1534237745,
        "creation_date": 1534237398,
        "question_id": 51837624,
        "body_markdown": "I have the following json\r\n\r\n    {\r\n        &quot;version&quot; : &quot;0.1.2&quot;,\r\n        &quot;basePath&quot; : &quot;/&quot;\r\n    }\r\n\r\nand the desired output is \r\n\r\n    {\r\n        &quot;version&quot; : &quot;0.1.2&quot;,\r\n        &quot;basePath&quot; : &quot;beta1&quot;\r\n    }\r\n\r\nI have the following jq which is producing the error below:\r\n\r\n    .basePath = .version | split(&quot;.&quot;) as $version | if  $version[0] == &quot;0&quot; then &quot;beta&quot;+ $version[1] else $version[0] end\r\n\r\njq: error (at &lt;stdin&gt;:3): split input and separator must be strings\r\nexit status 5\r\n\r\nUsing `.basePath = .version` assigns the value successfully and `.version | split(&quot;.&quot;) as $version | if  $version[0] == &quot;0&quot; then &quot;beta&quot;+ $version[1] else $version[0] end` on its own returns `&quot;beta1&quot;`.  Is there a way to assign the string to the `basePath` key?",
        "link": "https://stackoverflow.com/questions/51837624/jq-split-string-and-assign",
        "title": "jq split string and assign"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1534247176,
                "creation_date": 1534247176,
                "answer_id": 51840664,
                "question_id": 51840448,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Not quite the elegant of filters, but does what you need. All you need is a nested `to_entries[]` transformation and build the JSON on top of it.\r\n\r\n    jq &#39;[ to_entries[] | \r\n          { &quot;name&quot;: .key, \r\n            &quot;count&quot;: [ .value | to_entries[] | { &quot;type&quot;: .key, &quot;number&quot;: .value } ]\r\n          }\r\n        ]&#39; json\r\n\r\n[jq-play](https://jqplay.org/s/xClPHmIsTZ) snippet for the same.",
                "title": "jq: how to add the key of each element in a list into its value"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1534261847,
        "creation_date": 1534246422,
        "last_edit_date": 1534261847,
        "question_id": 51840448,
        "body_markdown": "I have some JSON input looks like:\r\n\r\n    {\r\n        &quot;name1&quot;:{\r\n            &quot;type1&quot;:1,\r\n            &quot;type2&quot;:2\r\n        },\r\n        &quot;name2&quot;:{\r\n            &quot;type2&quot;:3,\r\n            &quot;type3&quot;:4\r\n        }\r\n    }\r\n\r\nI&#39;d like to use jq to convert it into something like:\r\n\r\n    [\r\n        {\r\n            &quot;name&quot;:&quot;name1&quot;,\r\n            &quot;count&quot;:[\r\n                {\r\n                    &quot;type&quot;:&quot;type1&quot;\r\n                    &quot;number&quot;:1\r\n                },\r\n                {\r\n                    &quot;type&quot;:&quot;type2&quot;\r\n                    &quot;number&quot;:2\r\n                }\r\n            ]\r\n        },\r\n        {\r\n            &quot;name&quot;:&quot;name2&quot;,\r\n            &quot;count&quot;:[\r\n                {\r\n                    &quot;type&quot;:&quot;type2&quot;\r\n                    &quot;number&quot;:3\r\n                },\r\n                {\r\n                    &quot;type&quot;:&quot;type3&quot;\r\n                    &quot;number&quot;:4\r\n                }\r\n            ]\r\n        }\r\n    ]\r\n\r\nnot sure if this is possible to do?\r\n\r\nhttps://jqplay.org/s/b7ByAsQ571",
        "link": "https://stackoverflow.com/questions/51840448/jq-how-to-add-the-key-of-each-element-in-a-list-into-its-value",
        "title": "jq: how to add the key of each element in a list into its value"
    },
    {
        "tags": [
            "json",
            "bash",
            "macos",
            "jq",
            "io-redirection"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1534314791,
                "creation_date": 1534314791,
                "answer_id": 51853981,
                "question_id": 51853509,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; Am I missing something? \r\n\r\nYes - you cannot reliably use shell redirection to read and write the same file in the way you are expecting.  That&#39;s just the way things are :-(\r\n\r\n&gt; Is there a way to do this? \r\n\r\nYes.  One way is to use `sponge`.  (On a Mac, you could install it using `brew install moreutils`.)  Another is to use https://github.com/nicowilliams/inplace\r\n\r\nFor further details and options, see https://github.com/stedolan/jq/wiki/FAQ (search for `sponge`).\r\n",
                "title": "jq : Moving nested content from one file to another - pretty printing disappears"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1534398191,
        "creation_date": 1534311777,
        "last_edit_date": 1534397859,
        "question_id": 51853509,
        "body_markdown": "I want to move a JS object from one file to another.  I am currently trying to use jq to do this, but I&#39;m having issues getting it to output the result to a file using pretty printing.  In case you were wondering, I am trying to move duplicate swagger definitions into a common file.\r\n\r\nThis is my script:\r\n\r\n    content=`jq &#39;.definitions.foo&#39; ./src.swagger.json`\r\n    src_without_content=`jq &#39;del(.definitions.foo)&#39; ./src.swagger.json`\r\n    echo $src_without_content &gt; ./src.swagger.json\r\n    dest_with_content=`jq --argjson content &quot;$content&quot; &#39;.definitions |= .+ { &quot;foo&quot;: $content }&#39; ./dest.swagger.json`\r\n    echo $dest_with_content &gt; ./dest.swagger.json\r\n\r\nBasically, I am trying to capture the object that I want, then remove it from the source file, then add it to the destination.  I modify both files by creating the data that I want in the files, then overwriting them.\r\n\r\nWhen I tried using the output to directly write to a file (instead of first storing it in environment variables), the file was overwritten with a blank file:\r\n\r\n    jq &#39;del(.definitions.foo)&#39; ./src.swagger.json &gt; ./src.swagger.json\r\n\r\nWith my current script, the content is valid and as expected, but it isn&#39;t formatted nicely.  Instead, it is being printed as one solid line.  I read into this, and by default jq is supposed to use pretty printing.  Perhaps it is getting lost when I store the result in an environment variable?  I&#39;ve seen a few posts, but none of them seem to discuss how to write the output to a file.\r\n\r\nAm I missing something?  Is there a way to do this?  Any help is appreciated.  Thanks!\r\n\r\nIn case it matters, I am running this script on a mac.",
        "link": "https://stackoverflow.com/questions/51853509/jq-moving-nested-content-from-one-file-to-another-pretty-printing-disappears",
        "title": "jq : Moving nested content from one file to another - pretty printing disappears"
    },
    {
        "tags": [
            "python",
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 13674898,
                    "reputation": 1114,
                    "user_id": 9866643,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/ruolT.jpg?s=256",
                    "display_name": "M.Rau",
                    "link": "https://stackoverflow.com/users/9866643/m-rau"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1534312326,
                "post_id": 51853545,
                "comment_id": 90659574,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4194169,
                    "reputation": 969,
                    "user_id": 3435964,
                    "user_type": "registered",
                    "accept_rate": 50,
                    "profile_image": "https://www.gravatar.com/avatar/1ded010d65e135855530ebfc3d235893?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "user3435964",
                    "link": "https://stackoverflow.com/users/3435964/user3435964"
                },
                "reply_to_user": {
                    "account_id": 13674898,
                    "reputation": 1114,
                    "user_id": 9866643,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/ruolT.jpg?s=256",
                    "display_name": "M.Rau",
                    "link": "https://stackoverflow.com/users/9866643/m-rau"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1534312409,
                "post_id": 51853545,
                "comment_id": 90659594,
                "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": 1534315429,
                "post_id": 51853545,
                "comment_id": 90660497,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1534312782,
                "creation_date": 1534312782,
                "answer_id": 51853641,
                "question_id": 51853545,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "if your input json is stable and you do not need to control any edge cases (arbitrary depth, a top-level type mismatch, e.g. `&quot;key1&quot;: &quot;not a dict&quot;`) then this solves your problem:\r\n\r\n    ret = []\r\n    for k, v in js.items():\r\n        if v.get(&quot;filterkey&quot;) == &quot;filtervalue&quot;:\r\n            ret.append(k)\r\n",
                "title": "jq query json key based on key value filter"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1534312797,
                "creation_date": 1534312797,
                "answer_id": 51853643,
                "question_id": 51853545,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "\r\nRun snippet to see output:\r\n\r\n&lt;!-- begin snippet: js hide: false console: true babel: false --&gt;\r\n\r\n&lt;!-- language: lang-js --&gt;\r\n\r\n        var jsonObject = {\r\n                            &quot;key1&quot;: {\r\n                                &quot;filterkey&quot;: &quot;filtervalue&quot;,\r\n                                &quot;key1&quot;: &quot;value1&quot;\r\n                            },\r\n                            &quot;key2&quot;: {\r\n                                &quot;key1&quot;: &quot;value1&quot;,\r\n                                &quot;key2&quot;: &quot;value2&quot;\r\n                            }\r\n                        };\r\n        function filterKey(jsonObject, keySearch, valueSearch) {\r\n            var result = null;\r\n            for (const key in jsonObject) {\r\n                if (jsonObject.hasOwnProperty(key) &amp;&amp; \r\n                    jsonObject[key][keySearch] !== undefined &amp;&amp; \r\n                    jsonObject[key][keySearch] === valueSearch) {\r\n                    result = key;\r\n                    break;\r\n                }\r\n            }\r\n            return result;\r\n        }\r\n\r\n        alert(filterKey(jsonObject, &#39;filterkey&#39;, &#39;filtervalue&#39;));\r\n\r\n&lt;!-- end snippet --&gt;\r\n",
                "title": "jq query json key based on key value filter"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1534313329,
                "creation_date": 1534313329,
                "answer_id": 51853724,
                "question_id": 51853545,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "    jq &#39;.[] | select( .filterkey == &quot;filtervalue&quot;) | to_entries[1]| .key&#39;   sample.json\r\n\r\nSelect by filterkey, turn the objects into key value entires, then take the second entry&#39;s key. Output is: \r\n\r\n    &quot;key1&quot;",
                "title": "jq query json key based on key value filter"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1534315135,
                "creation_date": 1534315135,
                "answer_id": 51854034,
                "question_id": 51853545,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "In the example, &quot;key1&quot; appears several times, but it looks like you want the outermost key name.  If that&#39;s the case, then using `to_entries` is a good way to go, e.g.:\r\n\r\n    to_entries[]\r\n    | if .value.filterkey == &quot;filtervalue&quot; then .key else empty end\r\n\r\nOr equivalently:\r\n\r\n    to_entries[]\r\n    | select(.value.filterkey == &quot;filtervalue&quot; )\r\n    | .key\r\n\r\n",
                "title": "jq query json key based on key value filter"
            }
        ],
        "is_answered": false,
        "answer_count": 4,
        "score": 0,
        "last_activity_date": 1534315135,
        "creation_date": 1534312045,
        "question_id": 51853545,
        "body_markdown": "I have a json file with key and the value is a json with key value pair. I would like to filter and extract the key based on the inner key value pair. Any help is greatly appreciated\r\n\r\nExample json data:\r\n\r\n    {\r\n        &quot;key1&quot;: {\r\n          &quot;filterkey&quot;: &quot;filtervalue&quot;,\r\n          &quot;key1&quot;: &quot;value1&quot;\r\n        },\r\n        &quot;key2&quot;: {\r\n          &quot;key1&quot;: &quot;value1&quot;,\r\n          &quot;key2&quot;: &quot;value2&quot;\r\n        }\r\n    }\r\n\r\n* Filter: &quot;filterkey&quot;: &quot;filtervalue&quot;\r\n* expected output: &quot;key1&quot;",
        "link": "https://stackoverflow.com/questions/51853545/jq-query-json-key-based-on-key-value-filter",
        "title": "jq query json key based on key value filter"
    },
    {
        "tags": [
            "json",
            "key",
            "distinct",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1534407920,
                "last_edit_date": 1534407920,
                "creation_date": 1534319623,
                "answer_id": 51854892,
                "question_id": 51854685,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you put your JSON data into a file, you can do something like this:\r\n\r\n    cat data.json \\\r\n    | jq &#39;.gcp_price_list | del(.sustained_use_base,.sustained_use_tiers) | .[] | keys[]&#39; \\\r\n    | uniq\r\n\r\n ",
                "title": "jq: find unique keys from multiple object"
            },
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1534364643,
                "last_edit_date": 1534364643,
                "creation_date": 1534321972,
                "answer_id": 51855400,
                "question_id": 51854685,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "An only-jq solution:\r\n\r\n    .gcp_price_list\r\n    | del(.sustained_use_base,.sustained_use_tiers)\r\n    | [.[] | keys_unsorted[]]\r\n    | unique[]\r\n\r\n(Using `keys_unsorted` here saves unnecessary sorts.)\r\n\r\n## Better\r\nThe above solution has two main problems:\r\n\r\na) it uses `unique`, which involves an unnecessary (and perhaps undesirable) sorting operation;\r\nb) it includes keys whose values are not numbers and are presumably therefore to be excluded.\r\n\r\nThe following variation addresses both problems.  For convenience, we define these generic functions:\r\n\r\n    def set(s): reduce s as $x ({}; .[$x | (type[0:1] + tostring)] = $x);\r\n\r\n    def distinct(s): set(s)[];\r\n\r\n    .gcp_price_list\r\n    | del(.sustained_use_base,.sustained_use_tiers)\r\n    | distinct(.[]\r\n               | keys_unsorted[] as $k\r\n               | select( getpath([$k]) | type == &quot;number&quot;)\r\n               | $k)\r\n\r\nThis will still include some irrelevant keys, which of course can easily be removed (e.g. using array subtraction).\r\n\r\n\r\n",
                "title": "jq: find unique keys from multiple object"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1534407920,
        "creation_date": 1534318661,
        "last_edit_date": 1534407782,
        "question_id": 51854685,
        "body_markdown": "I manage to get the list of keys, but can&#39;t make it a list to pass into `unique`.\r\n\r\nhttps://jqplay.org/s/-YDVDeXTHb\r\n\r\nI&#39;d like to get a list of zone names, i.e.\r\n\r\n    &quot;asia&quot;\r\n    &quot;asia-east&quot;\r\n    &quot;asia-northeast&quot;\r\n    &quot;asia-south1&quot;\r\n    &quot;asia-southeast&quot;\r\n    &quot;australia&quot;\r\n    &quot;australia-southeast1&quot;\r\n\r\nI can manually remove &quot;cores&quot;, &quot;memory&quot; etc.",
        "link": "https://stackoverflow.com/questions/51854685/jq-find-unique-keys-from-multiple-object",
        "title": "jq: find unique keys from multiple object"
    },
    {
        "tags": [
            "json",
            "select",
            "key",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1534400459,
                "post_id": 51869431,
                "comment_id": 90692793,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 325508,
                    "reputation": 1864,
                    "user_id": 646732,
                    "user_type": "registered",
                    "accept_rate": 83,
                    "profile_image": "https://www.gravatar.com/avatar/459585723f7ba8b03ec3d32f5394b0e4?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Mzq",
                    "link": "https://stackoverflow.com/users/646732/mzq"
                },
                "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": 1534400757,
                "post_id": 51869431,
                "comment_id": 90692946,
                "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": 2,
                "creation_date": 1534403769,
                "post_id": 51869431,
                "comment_id": 90694387,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 488110,
                    "reputation": 1545,
                    "user_id": 1858241,
                    "user_type": "registered",
                    "accept_rate": 25,
                    "profile_image": "https://i.sstatic.net/vBxSV.png?s=256",
                    "display_name": "MikeB",
                    "link": "https://stackoverflow.com/users/1858241/mikeb"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1661480499,
                "post_id": 51869431,
                "comment_id": 129787998,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 29,
                "is_accepted": true,
                "score": 29,
                "last_activity_date": 1534401273,
                "creation_date": 1534401273,
                "answer_id": 51870918,
                "question_id": 51869431,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It looks like you want to take a &quot;slice&quot; of the object by selecting just those keys containing a certain string.  Using your query as a model, this can most easily be accomplished using a query of the form `with_entries( select(...) )`, e.g.:\r\n\r\n    .gcp_price_list\r\n    | with_entries( select(.key|contains(&quot;VMIMAGE&quot;)))\r\n\r\n\r\n\r\n",
                "title": "Using jq select elements with keys containing some string, key preserved in results"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 15,
        "last_activity_date": 1534403618,
        "creation_date": 1534392094,
        "last_edit_date": 1534403618,
        "question_id": 51869431,
        "body_markdown": "I have a JSON content as embedded in this link [jq-play](https://jqplay.org/s/npoAQkfK9V). The JSON content is large and couldn&#39;t be accommodated here. \r\n\r\nCurrently, I manage to get the values by\r\n\r\n    [.[keys[] | select(contains(&quot;VMIMAGE&quot;))]]\r\n\r\nbut the key names, i.e. `CP-COMPUTEENGINE-VMIMAGE-F1-MICRO` aren&#39;t present in the result. How do I get it?",
        "link": "https://stackoverflow.com/questions/51869431/using-jq-select-elements-with-keys-containing-some-string-key-preserved-in-resu",
        "title": "Using jq select elements with keys containing some string, key preserved in results"
    },
    {
        "tags": [
            "json",
            "linux",
            "xcode",
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 8727884,
                    "reputation": 623,
                    "user_id": 6528988,
                    "user_type": "registered",
                    "accept_rate": 25,
                    "profile_image": "https://lh5.googleusercontent.com/-WMr8-I3LjCA/AAAAAAAAAAI/AAAAAAAABqA/0FpThfnLDB0/s256-rj/photo.jpg",
                    "display_name": "Malinda Peiris",
                    "link": "https://stackoverflow.com/users/6528988/malinda-peiris"
                },
                "reply_to_user": {
                    "account_id": 262968,
                    "reputation": 789094,
                    "user_id": 548225,
                    "user_type": "registered",
                    "accept_rate": 90,
                    "profile_image": "https://www.gravatar.com/avatar/dab08478b226280d4a30894c9a7ed719?s=256&d=identicon&r=PG",
                    "display_name": "anubhava",
                    "link": "https://stackoverflow.com/users/548225/anubhava"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1534412472,
                "post_id": 51873886,
                "comment_id": 90699451,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8727884,
                    "reputation": 623,
                    "user_id": 6528988,
                    "user_type": "registered",
                    "accept_rate": 25,
                    "profile_image": "https://lh5.googleusercontent.com/-WMr8-I3LjCA/AAAAAAAAAAI/AAAAAAAABqA/0FpThfnLDB0/s256-rj/photo.jpg",
                    "display_name": "Malinda Peiris",
                    "link": "https://stackoverflow.com/users/6528988/malinda-peiris"
                },
                "reply_to_user": {
                    "account_id": 262968,
                    "reputation": 789094,
                    "user_id": 548225,
                    "user_type": "registered",
                    "accept_rate": 90,
                    "profile_image": "https://www.gravatar.com/avatar/dab08478b226280d4a30894c9a7ed719?s=256&d=identicon&r=PG",
                    "display_name": "anubhava",
                    "link": "https://stackoverflow.com/users/548225/anubhava"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1534412570,
                "post_id": 51873886,
                "comment_id": 90699512,
                "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": 1534559406,
                "post_id": 51873886,
                "comment_id": 90760253,
                "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": 1534657659,
                "post_id": 51873886,
                "comment_id": 90779631,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1534426527,
                "last_edit_date": 1534426527,
                "creation_date": 1534412746,
                "answer_id": 51874105,
                "question_id": 51873886,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using jq:\r\n\r\n    echo &#39;[{ &quot;customer.name&quot;:&quot;malinda&quot;, &quot;customer.details&quot;:&quot;test123&quot; }]&#39; | \r\n      jq &#39;.[].&quot;customer.name&quot;&#39;\r\n\r\nor without double quotes:\r\n\r\n    echo &#39;[{ &quot;customer.name&quot;:&quot;malinda&quot;, &quot;customer.details&quot;:&quot;test123&quot; }]&#39; |\r\n      jq -r &#39;.[].&quot;customer.name&quot;&#39;\r\n\r\nSince the dot `.` is neither alphanumeric nor an underscore, you need to quote the key name.",
                "title": "Using jq, get value of a specific key which is inside a shell-defined JSON object within an array"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1534657516,
        "creation_date": 1534412031,
        "last_edit_date": 1534657516,
        "question_id": 51873886,
        "body_markdown": "Given:\r\n \r\n       [{\r\n        &quot;customer.name&quot;:&quot;malinda&quot;,\r\n        &quot;customer.details&quot;:&quot;test123&quot;\r\n        }]\r\n\r\n \r\nUsing jq, get the value of &quot;customer.name&quot;.\r\n\r\nMy attempt:\r\n   \r\n    echo $response | jq -r .[] | &quot;customer.name&quot;",
        "link": "https://stackoverflow.com/questions/51873886/using-jq-get-value-of-a-specific-key-which-is-inside-a-shell-defined-json-objec",
        "title": "Using jq, get value of a specific key which is inside a shell-defined JSON object within an array"
    },
    {
        "tags": [
            "bash",
            "azure",
            "azure-functions",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 496401,
                    "reputation": 26534,
                    "user_id": 4148708,
                    "user_type": "registered",
                    "accept_rate": 70,
                    "profile_image": "https://i.sstatic.net/3T3nq.jpg?s=256",
                    "display_name": "evilSnobu",
                    "link": "https://stackoverflow.com/users/4148708/evilsnobu"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1534496610,
                "post_id": 51887566,
                "comment_id": 90734675,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1534482912,
                "creation_date": 1534482912,
                "answer_id": 51888770,
                "question_id": 51887566,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "technically you can use python venv to install jq, but generally speaking you can easily parse json with python\\powershell\\whatever. it doesnt take a lot of digging to do that.\r\n\r\nPowershell parse json:\r\n\r\n    $json = az bla bla-bla bla-bla-bla\r\n    $jsonParsed = $json | ConvertFrom-Json\r\n    $jsonParsed.Property1[index].value\r\n\r\nPython without jq:\r\n\r\n    import json\r\n    j = json.loads(&#39;{&quot;one&quot; : &quot;1&quot;, &quot;two&quot; : &quot;2&quot;, &quot;three&quot; : &quot;3&quot;}&#39;)\r\n    print j[&#39;two&#39;]\r\n\r\nPython way to install modules:\r\n\r\nhttps://github.com/yokawasa/azure-functions-python-samples/blob/master/docs/install-python-modules.md\r\n\r\nand after that you just add venv modules to path:\r\n\r\n    sys.path.append(os.path.abspath(os.path.join(os.path.dirname( __file__ ), &#39;../../../az/Lib/site-packages&#39;)))\r\n\r\nassuming `../../../az/Lib/site-packages` is a relative path from you function root to the venv `site-packages` directory",
                "title": "Use JQ in Bash Azure Function"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1534482912,
        "creation_date": 1534472141,
        "last_edit_date": 1534472654,
        "question_id": 51887566,
        "body_markdown": "Goal:\r\n\r\nI have a Bash script that needs to run every 5 minutes. I am currently doing this with Windows Task Scheduler on an Azure VM. I would like to use an alternative to the VM to save cost. Azure Functions seems like a way.\r\n\r\nProblem:\r\n\r\nMy Bash script uses JQ. I&#39;d like to run the script in a Bash Azure Function (QueueTriggerBash). The script runs but doesn&#39;t execute the JQ commands. I assume this is because JQ is not recognized by the Azure Function.\r\n\r\nI tried installing JQ with the JQ Linux instructions (`sudo apt-get install jq` - it does not recognize `sudo`), installing a JQ package with npm (it does not recognize `npm`), installing JQ with Chocolatey (it does not recognize `choco`) but these attempts were unsuccessful. My method for trying these was to include the command at the beginning of my script and running the Azure Function.\r\n\r\nThe reason the script is in Bash is that I don&#39;t know PS, C#, or JS. The reason for Azure Functions is that I have an Azure subscription. The script is not public.\r\n\r\nThank you for any help or ideas. If an Azure Function is not the best way to meet my goal I would be grateful to know.",
        "link": "https://stackoverflow.com/questions/51887566/use-jq-in-bash-azure-function",
        "title": "Use JQ in Bash Azure Function"
    },
    {
        "tags": [
            "json",
            "bash",
            "sorting",
            "key",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 24,
                "is_accepted": true,
                "score": 24,
                "last_activity_date": 1534652233,
                "last_edit_date": 1534652233,
                "creation_date": 1534651872,
                "answer_id": 51914402,
                "question_id": 51914316,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; the values sorted in descending order of length:\r\n\r\n    [.[]] | sort_by(length) | reverse[]\r\n\r\n&gt; swap properties for values\r\n\r\n    with_entries(.key as $k | .key=.value | .value=$k )\r\n\r\n## Combining the two requirements\r\n\r\nA solution to the combined problem can be crafted by combining the above two solutions, because `with_entries` is a combination of `to_entries` and `from_entries`:\r\n\r\n    to_entries\r\n    | map(.key as $k | .key=.value | .value=$k )\r\n    | sort_by(.key|length)\r\n    | reverse\r\n    | from_entries\r\n\r\n",
                "title": "Use jq in Bash to sort object properties by descending length of their value"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 8,
        "last_activity_date": 1534652318,
        "creation_date": 1534650877,
        "last_edit_date": 1534652318,
        "question_id": 51914316,
        "body_markdown": "I have the following JSON snippet:\r\n\r\n    {\r\n        &quot;root_path&quot;: &quot;/www&quot;,\r\n        &quot;core_path&quot;: &quot;/www/wp&quot;,\r\n        &quot;content_path&quot;: &quot;/www/content&quot;,\r\n        &quot;vendor_path&quot;: &quot;/www/vendor&quot;\r\n    }\r\n\r\nI would like to use `jq` first to get the values sorted in descending order of length:\r\n\r\n    /www/content\r\n    /www/vendor\r\n    /www/wp\r\n    /www\r\n\r\nI need these so I can match against a list of files to find which of the named paths the files exist in.\r\n\r\nThen I would like to use `jq` again to swap properties for values _(it can drop duplicate properties, that&#39;s okay):_\r\n\r\n    {\r\n        &quot;/www&quot;: &quot;root_path&quot;.\r\n        &quot;/www/wp&quot;: &quot;core_path&quot;,\r\n        &quot;/www/content&quot;: &quot;content_path&quot;,\r\n        &quot;/www/vendor&quot;: &quot;vendor_path&quot;\r\n    }\r\n\r\nMy use case for this 2nd query is to be able to lookup a matched path value and find its path name, which I will then use in a second JSON snippet with an identical schema to get the named path&#39;s value. \r\n\r\nMy use-case is for website deployment and I have a config file that contains files names as they will exist on the deployment server that should be copied from the source server to the deploy server but the servers may have different directory layouts.\r\n\r\nI need to use Bash for this, but if there is a better way to do what I am looking to do I am open. That said, I really do want to learn how to use `jq` better so I would prefer to learn how to use `jq` to do these transforms.\r\n\r\n\r\nI am using `jq` version `1.5`",
        "link": "https://stackoverflow.com/questions/51914316/use-jq-in-bash-to-sort-object-properties-by-descending-length-of-their-value",
        "title": "Use jq in Bash to sort object properties by descending length of their value"
    },
    {
        "tags": [
            "json",
            "jq",
            "flatten",
            "keypaths"
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1534773687,
                "last_edit_date": 1534773687,
                "creation_date": 1534746489,
                "answer_id": 51925136,
                "question_id": 51924988,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "One approach would be to use `tostream`:\r\n\r\n    tostream\r\n    | select(length==2)\r\n    | (.[0] | join(&quot;.&quot;)) as $k\r\n    | .[1] as $v\r\n    | &quot;\\&quot;\\($k)\\&quot; = \\&quot;\\($v)\\&quot;;&quot;\r\n\r\nWhen used with the -r command-line option, this will produce the desired results, assuming the input is valid JSON.  \r\n\r\n## Checking the key assumption [*]\r\n\r\nIt might be worth making explicit that the output format may not be very useful if any key name contains a period, so it might be worth checking that this is indeed the case, e.g. as follows:\r\n\r\n    [.. | objects | keys_unsorted[]]\r\n    | map(select(index(&quot;.&quot;)))\r\n    | unique[]\r\n\r\n## If your jq does not have `tostream`\r\n\r\n    paths as $path\r\n    | getpath($path) \r\n    | strings\r\n    | &quot;\\&quot;\\($path|join(&quot;.&quot;))\\&quot; = \\&quot;\\(.)\\&quot;;&quot;\r\n\r\n&lt;sub&gt;[*] pun intended&lt;/sub&gt;\r\n",
                "title": "Flatten nested Json objects with JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1534773687,
        "creation_date": 1534745623,
        "last_edit_date": 1534747968,
        "question_id": 51924988,
        "body_markdown": "I am creating a script to transform JSON objects to &quot;string&quot; files (for translation purposes). the idea is to transform:\r\n\r\n\r\n    {\r\n       &quot;TRANSLATION1&quot;: &quot;text1&quot;,\r\n       &quot;TRANSLATION2&quot;: &quot;text2&quot;\r\n    }\r\n\r\n\r\ninto \r\n\r\n    &quot;TRANSLATION1&quot; = &quot;text1&quot;;\r\n    &quot;TRANSLATION2&quot; = &quot;text2&quot;;\r\n\r\n\r\n\r\nThat was done with :\r\n`jq  -r &#39;to_entries|map(&quot;\\&quot;\\(.key)\\&quot;=\\(.value|tojson);&quot;)|.[]&#39;`\r\n\r\nNice!\r\n\r\nNow, my problem is with nested objects:\r\n\r\n\r\n    {\r\n       &quot;TRANSLATION1&quot;: &quot;text1&quot;,\r\n       &quot;TRANSLATION2&quot;: &quot;text2&quot;,\r\n       &quot;TRANSLATION3&quot;: {\r\n         &quot;SUBTRANS1&quot;: &quot;subtranslation1&quot;,\r\n         &quot;SUBTRANS2&quot;: &quot;subtranslation2&quot;,\r\n       }\r\n    }\r\n\r\n\r\nI would like to have as result: \r\n\r\n    &quot;TRANSLATION1&quot; = &quot;text1&quot;;\r\n    &quot;TRANSLATION2&quot; = &quot;text2&quot;;\r\n    &quot;TRANSLATION3.SUBTRANS1&quot; = &quot;subtranslation1&quot;;\r\n    &quot;TRANSLATION3.SUBTRANS2&quot; = &quot;subtranslation2&quot;;\r\n\r\nCan anyone help?! I have been scratching my head for hours now...\r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/51924988/flatten-nested-json-objects-with-jq",
        "title": "Flatten nested Json objects with JQ"
    },
    {
        "tags": [
            "arrays",
            "json",
            "bash",
            "csv",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 7,
                "is_accepted": false,
                "score": 7,
                "last_activity_date": 1534764711,
                "creation_date": 1534764711,
                "answer_id": 51929863,
                "question_id": 51929141,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Like this:\r\n\r\n    jq -rRs &#39;split(&quot;\\n&quot;)[1:-1] |\r\n             map([split(&quot;\\t&quot;)[]|split(&quot;,&quot;)] | {\r\n                     &quot;name&quot;:.[0],\r\n                     &quot;age&quot;:.[1],\r\n                     &quot;pet&quot;:.[2]\r\n                 }\r\n        )&#39; input.tsv",
                "title": "Converting tsv with arrays to JSON with jq"
            },
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1534831807,
                "last_edit_date": 1534831807,
                "creation_date": 1534772215,
                "answer_id": 51931963,
                "question_id": 51929141,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "In case the name includes any commas, I&#39;d go with the following, which also avoids having to &quot;slurp&quot; the input:\r\n\r\n    inputs\r\n    | split(&quot;\\t&quot;)\r\n    | {name: .[0], age: .[1], pet: .[2]}\r\n    | .pet |= split(&quot;,&quot;) \r\n\r\nTo skip the header, simply invoke jq with the -R option, e.g. like this:\r\n\r\n    jq -R -f program.jq input.tsv\r\n\r\nIf you want the result as an array, simply enclose the entire filter above in square brackets.\r\n\r\n",
                "title": "Converting tsv with arrays to JSON with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 7,
        "last_activity_date": 1534831807,
        "creation_date": 1534762242,
        "last_edit_date": 1534817691,
        "question_id": 51929141,
        "body_markdown": "i found [jq][1] very helpful in converting tsv to JSON file, however, i want to figure out how to do it with jq when i have array in my tsv:\r\n\r\n    name    age    pets\r\n    Tim    15    cats,dogs\r\n    Joe    11    rabbits,birds\r\n    ...\r\n\r\nideal JSON:\r\n\r\n    [\r\n     {\r\n      name: &quot;Tim&quot;,\r\n      age: &quot;15&quot;,\r\n      pet:[&quot;cats&quot;,&quot;dogs&quot;]\r\n     },\r\n      name: &quot;Joe&quot;,\r\n      age: &quot;11&quot;,\r\n      pet:[&quot;rabbits&quot;,&quot;birds&quot;]\r\n     }, ...\r\n    ]\r\n\r\nThis is the command i tried:\r\n\r\n    cat file.tsv | jq -s  --slurp --raw-input --raw-output &#39;split(&quot;\\n&quot;) | .[1:-1] | map(split(&quot;\\t&quot;)) |\r\n            map({&quot;name&quot;: .[0],\r\n                 &quot;age&quot;: .[1],\r\n                 &quot;pet&quot;: .[2]})&#39;\r\n\r\nand the output the the above command is:\r\n\r\n    [\r\n     {\r\n      name: &quot;Tim&quot;,\r\n      age: &quot;15&quot;,\r\n      pet:&quot;cats,dogs&quot;\r\n     },\r\n      name: &quot;Joe&quot;,\r\n      age: &quot;11&quot;,\r\n      pet:&quot;rabbits,birds&quot;-\r\n     }, ...\r\n    ]\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/tutorial/",
        "link": "https://stackoverflow.com/questions/51929141/converting-tsv-with-arrays-to-json-with-jq",
        "title": "Converting tsv with arrays to JSON with jq"
    },
    {
        "tags": [
            "jq",
            "aws-cli"
        ],
        "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": 1534808496,
                "post_id": 51935775,
                "comment_id": 90829528,
                "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": 1534814736,
                "post_id": 51935775,
                "comment_id": 90830664,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1534828448,
                "creation_date": 1534828448,
                "answer_id": 51941960,
                "question_id": 51935775,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "All the values in the nested `BlockDeviceMappings` are in an array. So you would need to flatten it down to the individual values. There&#39;s a couple of ways you could achieve this using JMESPath, you could just index to the first block device.\r\n\r\n    Reservations[].Instances[].{\r\n        InstanceId: InstanceId,\r\n        type: InstanceType,\r\n        Devicename: BlockDeviceMappings[0].DeviceName,\r\n        Persistence_on: BlockDeviceMappings[0].Ebs.DeleteOnTermination,\r\n        Status: BlockDeviceMappings[0].Ebs.Status,\r\n        Volume_id: BlockDeviceMappings[0].Ebs.VolumeId\r\n    }\r\n\r\nBut I think for readability sake, I would opt for this approach (assuming aws-cli supports `merge()`):\r\n\r\n    Reservations[].Instances[].merge(\r\n        {InstanceId: InstanceId, type: InstanceType},\r\n        BlockDeviceMappings[0].{\r\n            Devicename: DeviceName,\r\n            Persistence_on: Ebs.DeleteOnTermination,\r\n            Status: Ebs.Status,\r\n            Volume_id: Ebs.VolumeId\r\n        }\r\n    )\r\n\r\n&lt;hr&gt;\r\n\r\nOn the other hand, I find `jq` a lot easier to work with. This should yield the same results as json.\r\n\r\n    $ aws-cli ... | jq &#39;[.Reservations[].Instances[] |\r\n        { InstanceId, type: .InstanceType } +\r\n        (.BlockDeviceMappings[] | {\r\n            Devicename: .DeviceName,\r\n            Persistence_on: .Ebs.DeleteOnTermination,\r\n            Status: .Ebs.Status,\r\n            Volume_id: .Ebs.VolumeId\r\n        })\r\n    ]&#39;",
                "title": "query nested path with AWS CLI and output as Table"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1534828448,
        "creation_date": 1534786026,
        "question_id": 51935775,
        "body_markdown": "I&#39;m trying to ouput a table using the --query command in AWSCLI, but for some reason I cant get the values in the same row. What is the error?\r\n\r\nthe .json file is\r\n\r\n    {\r\n    &quot;Reservations&quot;: [\r\n        {\r\n            &quot;Groups&quot;: [],\r\n            &quot;Instances&quot;: [\r\n                {\r\n                    &quot;AmiLaunchIndex&quot;: 0,\r\n                    &quot;ImageId&quot;: &quot;ami-2a7d75c0&quot;,\r\n                    &quot;InstanceId&quot;: &quot;i-099569e17a368446b&quot;,\r\n                    &quot;InstanceType&quot;: &quot;t2.micro&quot;,\r\n                    &quot;KeyName&quot;: &quot;ar_ecs_key&quot;,\r\n                    &quot;LaunchTime&quot;: &quot;2018-08-18T17:59:49.000Z&quot;,\r\n                    &quot;Monitoring&quot;: {\r\n                        &quot;State&quot;: &quot;disabled&quot;\r\n                    },\r\n                    &quot;Placement&quot;: {\r\n                        &quot;AvailabilityZone&quot;: &quot;eu-west-1c&quot;,\r\n                        &quot;GroupName&quot;: &quot;&quot;,\r\n                        &quot;Tenancy&quot;: &quot;default&quot;\r\n                    },\r\n                    &quot;PrivateDnsName&quot;: &quot;ip-172-31-46-99.eu-west-1.compute.internal&quot;,\r\n                    &quot;PrivateIpAddress&quot;: &quot;172.31.46.99&quot;,\r\n                    &quot;ProductCodes&quot;: [],\r\n                    &quot;PublicDnsName&quot;: &quot;ec2-34-245-58-217.eu-west-1.compute.amazonaws.com&quot;,\r\n                    &quot;PublicIpAddress&quot;: &quot;34.245.58.217&quot;,\r\n                    &quot;State&quot;: {\r\n                        &quot;Code&quot;: 16,\r\n                        &quot;Name&quot;: &quot;running&quot;\r\n                    },\r\n                    &quot;StateTransitionReason&quot;: &quot;&quot;,\r\n                    &quot;SubnetId&quot;: &quot;subnet-3407646f&quot;,\r\n                    &quot;VpcId&quot;: &quot;vpc-24ddec43&quot;,\r\n                    &quot;Architecture&quot;: &quot;x86_64&quot;,\r\n                    &quot;BlockDeviceMappings&quot;: [\r\n                        {\r\n                            &quot;DeviceName&quot;: &quot;/dev/sda1&quot;,\r\n                            &quot;Ebs&quot;: {\r\n                                &quot;AttachTime&quot;: &quot;2018-08-18T17:59:49.000Z&quot;,\r\n                                &quot;DeleteOnTermination&quot;: true,\r\n                                &quot;Status&quot;: &quot;attached&quot;,\r\n                                &quot;VolumeId&quot;: &quot;vol-0d9f4ab048e7999b7&quot;\r\n                            }\r\n                        }\r\n                    ],\r\n                    &quot;ClientToken&quot;: &quot;&quot;,\r\n                    &quot;EbsOptimized&quot;: false,\r\n                    &quot;EnaSupport&quot;: true,\r\n                    &quot;Hypervisor&quot;: &quot;xen&quot;,\r\n                    &quot;NetworkInterfaces&quot;: [\r\n                        {\r\n                            &quot;Association&quot;: {\r\n                                &quot;IpOwnerId&quot;: &quot;amazon&quot;,\r\n                                &quot;PublicDnsName&quot;: &quot;ec2-34-245-58-217.eu-west-1.compute.amazonaws.com&quot;,\r\n                                &quot;PublicIp&quot;: &quot;34.245.58.217&quot;\r\n                            },\r\n                            &quot;Attachment&quot;: {\r\n                                &quot;AttachTime&quot;: &quot;2018-08-18T17:59:49.000Z&quot;,\r\n                                &quot;AttachmentId&quot;: &quot;eni-attach-0bbfc61bf0a6729ad&quot;,\r\n                                &quot;DeleteOnTermination&quot;: true,\r\n                                &quot;DeviceIndex&quot;: 0,\r\n                                &quot;Status&quot;: &quot;attached&quot;\r\n                            },\r\n                            &quot;Description&quot;: &quot;&quot;,\r\n                            &quot;Groups&quot;: [\r\n                                {\r\n                                    &quot;GroupName&quot;: &quot;default&quot;,\r\n                                    &quot;GroupId&quot;: &quot;sg-98ce7ee3&quot;\r\n                                }\r\n                            ],\r\n                            &quot;Ipv6Addresses&quot;: [],\r\n                            &quot;MacAddress&quot;: &quot;0a:df:58:fe:e5:d2&quot;,\r\n                            &quot;NetworkInterfaceId&quot;: &quot;eni-02dcc4cbc45726b77&quot;,\r\n                            &quot;OwnerId&quot;: &quot;300746241447&quot;,\r\n                            &quot;PrivateDnsName&quot;: &quot;ip-172-31-46-99.eu-west-1.compute.internal&quot;,\r\n                            &quot;PrivateIpAddress&quot;: &quot;172.31.46.99&quot;,\r\n                            &quot;PrivateIpAddresses&quot;: [\r\n                                {\r\n                                    &quot;Association&quot;: {\r\n                                        &quot;IpOwnerId&quot;: &quot;amazon&quot;,\r\n                                        &quot;PublicDnsName&quot;: &quot;ec2-34-245-58-217.eu-west-1.compute.amazonaws.com&quot;,\r\n                                        &quot;PublicIp&quot;: &quot;34.245.58.217&quot;\r\n                                    },\r\n                                    &quot;Primary&quot;: true,\r\n                                    &quot;PrivateDnsName&quot;: &quot;ip-172-31-46-99.eu-west-1.compute.internal&quot;,\r\n                                    &quot;PrivateIpAddress&quot;: &quot;172.31.46.99&quot;\r\n                                }\r\n                            ],\r\n                            &quot;SourceDestCheck&quot;: true,\r\n                            &quot;Status&quot;: &quot;in-use&quot;,\r\n                            &quot;SubnetId&quot;: &quot;subnet-3407646f&quot;,\r\n                            &quot;VpcId&quot;: &quot;vpc-24ddec43&quot;\r\n                        }\r\n                    ],\r\n                    &quot;RootDeviceName&quot;: &quot;/dev/sda1&quot;,\r\n                    &quot;RootDeviceType&quot;: &quot;ebs&quot;,\r\n                    &quot;SecurityGroups&quot;: [\r\n                        {\r\n                            &quot;GroupName&quot;: &quot;default&quot;,\r\n                            &quot;GroupId&quot;: &quot;sg-98ce7ee3&quot;\r\n                        }\r\n                    ],\r\n                    &quot;SourceDestCheck&quot;: true,\r\n                    &quot;Tags&quot;: [\r\n                        {\r\n                            &quot;Key&quot;: &quot;webserver&quot;,\r\n                            &quot;Value&quot;: &quot;production&quot;\r\n                        }\r\n                    ],\r\n                    &quot;VirtualizationType&quot;: &quot;hvm&quot;\r\n                }\r\n            ],\r\n            &quot;OwnerId&quot;: &quot;300746241447&quot;,\r\n            &quot;ReservationId&quot;: &quot;r-047aab5e090b741af&quot;\r\n        }\r\n    ]\r\n}\r\n\r\nmy query is:\r\n\r\n    $ aws ec2 describe-instances --instance-ids i-099569e17a368446b --query &#39;Reservations[*].Instances[].{InstanceId:InstanceId,type:InstanceType,Devicename:BlockDeviceMappings.DeviceName,Persistence_on:BlockDeviceMappings[].Ebs.DeleteOnTermination,Status:BlockDeviceMappings[*].Ebs.Status,Volume_id:BlockDeviceMappings.Ebs.VolumeId}&#39; --output table\r\n\r\nand the result is:\r\n\r\n[![enter image description here][1]][1]\r\n\r\n  [1]: https://i.sstatic.net/HFNT5.png\r\n\r\n\r\nI&#39;m sure it has something to do with the flattening operator [], but I dont know what. Tried all versions already...\r\n\r\nmerci in advance\r\n\r\nA",
        "link": "https://stackoverflow.com/questions/51935775/query-nested-path-with-aws-cli-and-output-as-table",
        "title": "query nested path with AWS CLI and output as Table"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2387472,
                    "reputation": 74949,
                    "user_id": 2088135,
                    "user_type": "registered",
                    "accept_rate": 93,
                    "profile_image": "https://i.sstatic.net/YB10Q.jpg?s=256",
                    "display_name": "Tom Fenech",
                    "link": "https://stackoverflow.com/users/2088135/tom-fenech"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1534835019,
                "post_id": 51943101,
                "comment_id": 90836062,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6346989,
                    "reputation": 1579,
                    "user_id": 4927212,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/f3mhM.jpg?s=256",
                    "display_name": "KaiserKatze",
                    "link": "https://stackoverflow.com/users/4927212/kaiserkatze"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1534835155,
                "post_id": 51943101,
                "comment_id": 90836128,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1534926927,
                "last_edit_date": 1534926927,
                "creation_date": 1534835440,
                "answer_id": 51943402,
                "question_id": 51943101,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This returns the second element in each array in the `google_groups` property of the `commercial` property:\r\n\r\n    jq --arg key commercial &#39;.[$key].google_groups | .[] | .[1]&#39; file\r\nUse `jq -r` to output in &quot;raw&quot; format (lose the double quotes).\r\n\r\n    $ key=commercial\r\n    $ jq -r --arg key &quot;$key&quot; &#39;.[$key].google_groups | .[] | .[1]&#39; file\r\n    commercial-team@domain.com\r\n    commercial-updates@domain.com\r\nI used `--arg` in these examples to show how it is used, optionally with a shell variable. If, on the other hand, `commercial` was just a fixed string, then you could simplify:\r\n\r\n    jq -r &#39;.commercial.google_groups | .[] | .[1]&#39; file\r\nTo process each line of the output, you can just use a shell `while read` loop:\r\n\r\n    key=commercial\r\n    while read -r email; do\r\n      echo &quot;$email&quot;\r\n      # process each email individually here\r\n    done &lt; &lt;(jq -r --arg key &quot;$key&quot; &#39;.[$key].google_groups | .[] | .[1]&#39; file)\r\nHere I am using a process substitution `&lt;()`, which acts like a file that can be processed by the shell. One advantage of doing this, over using a pipe, is that no subshell is created. Among other things, this means that the variables used within the loop remain in scope after the `while` block, so you can use them later.\r\n\r\nIf you prefer to use a pipe, just remove the part after `done` and move the command up to the first line:\r\n\r\n    jq ... | while read -r email; do # etc.",
                "title": "Reading and Looping Through A JSON File in BASH"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1534865007,
                "creation_date": 1534865007,
                "answer_id": 51951982,
                "question_id": 51943101,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "As @TomFenech noted, the requirements are somewhat unclear, but if it&#39;s the email addresses you want, the following variant of his answer may be of interest:\r\n\r\n    key=commercial\r\n    $ jq -r --arg key &quot;$key&quot; &#39;.[$key].google_groups[][] | select(test(&quot;@&quot;))&#39; department_groups.json\r\n    commercial-team@domain.com\r\n    commercial-updates@domain.com",
                "title": "Reading and Looping Through A JSON File in BASH"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1534926927,
        "creation_date": 1534834167,
        "last_edit_date": 1534844652,
        "question_id": 51943101,
        "body_markdown": "I&#39;ve got a JSON file (see below) called department_groups.json. \r\n\r\nEssentially if I gave an argument of `commercial` I&#39;d like it to return:\r\n\r\n    commercial-team@domain.com\r\n\r\n    commercial-updates@domain.com\r\n\r\nCan anyone guide/help me with doing this? \r\n\r\n    {\r\n        &quot;legal&quot;: {\r\n            &quot;google_groups&quot;:[\r\n                [&quot;Legal&quot;, &quot;legal@domain.com&quot;],\r\n                [&quot;Legal Team&quot;, &quot;legal-team@domain.com&quot;],\r\n                [&quot;Compliance Checks&quot;, &quot;compliance@domain.com&quot;]\r\n            ],\r\n            &quot;samba_groups&quot;: &quot;&quot;\r\n         },\r\n        &quot;commercial&quot;:{\r\n            &quot;google_groups&quot;:[\r\n                [&quot;Commercial Team&quot;, &quot;commercial-team@domain.com&quot;],\r\n                [&quot;Commercial Updates&quot;, &quot;commercial-updates@domain.com&quot;]\r\n            ],\r\n            &quot;samba_groups&quot;: &quot;&quot;  \r\n        },\r\n        &quot;technology&quot;:{\r\n            &quot;google_groups&quot;:[\r\n                [&quot;Technology&quot;, &quot;technology@domain.com&quot;],\r\n                [&quot;Incidents&quot;, &quot;incidents@domain.com&quot;]\r\n            ],\r\n            &quot;samba_groups&quot;: &quot;&quot;\r\n        }\r\n    }",
        "link": "https://stackoverflow.com/questions/51943101/reading-and-looping-through-a-json-file-in-bash",
        "title": "Reading and Looping Through A JSON File in BASH"
    },
    {
        "tags": [
            "arrays",
            "json",
            "formatting",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1534860911,
                "last_edit_date": 1534860911,
                "creation_date": 1534852197,
                "answer_id": 51948043,
                "question_id": 51944541,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can try this:\r\n\r\n    jq &#39;.result[] | [ flatten[] | try(.action) // . ] | @csv&#39; file\r\n    &quot;\\&quot;ebsvolume\\&quot;,\\&quot;gtest\\&quot;,\\&quot;vol-999999999999\\&quot;,\\&quot;g-test-acct\\&quot;,\\&quot;12345678912\\&quot;,\\&quot;ap-southeast-2c\\&quot;,\\&quot;ap-southeast-2\\&quot;,998.56,167.7,0,\\&quot;2018-08-16T22:00:00Z\\&quot;,\\&quot;io1\\&quot;,\\&quot;in-use\\&quot;,180,2000,500,\\&quot;2018-08-08T22:00:00Z\\&quot;,\\&quot;i-086f957ee\\&quot;,\\&quot;Rightsize\\&quot;,\\&quot;Rightsize\\&quot;,\\&quot;Rightsize\\&quot;&quot;\r\n\r\n`flatten` does what it says.  \r\n\r\n`try` tests if `.action` is neither `null` nor `false`. If so, it emits its value, otherwise `jq` emits the other value (operator `//`).  \r\n\r\nThe filtered values are put into an array in order to get them converted with the `@csv` operator.",
                "title": "Formatting into CSV JSON file using jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1535074485,
                "creation_date": 1535074485,
                "answer_id": 51996333,
                "question_id": 51944541,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "That didn&#39;t overly work for me actually it omitted all the data in the previous array - but thanks! \r\n\r\nI ended up with the following, granted it doesn&#39;t put the Rightsize details on a seperate line but it will have to do:\r\n\r\njq -r &#39;.result[] | [.service,.name,.resourceIdentifier,.accountName,.vendorAccountId,.availabilityZone,.region,.effectiveHourly,.totalSpend,.idle,.lastSeen,.volumeType,.state,.volumeSize,.iops,.throughput,.lastAttachedTime,.lastAttachedId,.recommendations[][]] |@csv&#39; ./myfile.json",
                "title": "Formatting into CSV JSON file using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1535074485,
        "creation_date": 1534839809,
        "last_edit_date": 1534860174,
        "question_id": 51944541,
        "body_markdown": "I&#39;ve some data in a file called myfile.json. I need to format using jq - in JSON it looks like this ;\r\n\r\n\r\n`{\r\n  &quot;result&quot;: [\r\n    {\r\n      &quot;service&quot;: &quot;ebsvolume&quot;,\r\n      &quot;name&quot;: &quot;gtest&quot;,\r\n      &quot;resourceIdentifier&quot;: &quot;vol-999999999999&quot;,\r\n      &quot;accountName&quot;: &quot;g-test-acct&quot;,\r\n      &quot;vendorAccountId&quot;: &quot;12345678912&quot;,\r\n      &quot;availabilityZone&quot;: &quot;ap-southeast-2c&quot;,\r\n      &quot;region&quot;: &quot;ap-southeast-2&quot;,\r\n      &quot;effectiveHourly&quot;: 998.56,\r\n      &quot;totalSpend&quot;: 167.7,\r\n      &quot;idle&quot;: 0,\r\n      &quot;lastSeen&quot;: &quot;2018-08-16T22:00:00Z&quot;,\r\n      &quot;volumeType&quot;: &quot;io1&quot;,\r\n      &quot;state&quot;: &quot;in-use&quot;,\r\n      &quot;volumeSize&quot;: 180,\r\n      &quot;iops&quot;: 2000,\r\n      &quot;throughput&quot;: 500,\r\n      &quot;lastAttachedTime&quot;: &quot;2018-08-08T22:00:00Z&quot;,\r\n      &quot;lastAttachedId&quot;: &quot;i-086f957ee&quot;,\r\n      &quot;recommendations&quot;: [\r\n        {\r\n          &quot;action&quot;: &quot;Rightsize&quot;,\r\n          &quot;preferenceOrder&quot;: 2,\r\n          &quot;risk&quot;: 0,\r\n          &quot;savingsPct&quot;: 91,\r\n          &quot;savings&quot;: 189.05,\r\n          &quot;volumeType&quot;: &quot;gp2&quot;,\r\n          &quot;volumeSize&quot;: 120,\r\n        },\r\n        {\r\n          &quot;action&quot;: &quot;Rightsize&quot;,\r\n          &quot;preferenceOrder&quot;: 4,\r\n          &quot;risk&quot;: 0,\r\n          &quot;savingsPct&quot;: 97,\r\n          &quot;savings&quot;: 166.23,\r\n          &quot;volumeType&quot;: &quot;gp2&quot;,\r\n          &quot;volumeSize&quot;: 167,\r\n        },\r\n        {\r\n          &quot;action&quot;: &quot;Rightsize&quot;,\r\n          &quot;preferenceOrder&quot;: 6,\r\n          &quot;risk&quot;: 0,\r\n          &quot;savingsPct&quot;: 91,\r\n          &quot;savings&quot;: 111.77,\r\n          &quot;volumeType&quot;: &quot;gp2&quot;,\r\n          &quot;volumeSize&quot;: 169,\r\n        }\r\n      ]\r\n    }\r\n}`\r\n\r\nI have it formatted better with the following \r\n\r\n`jq &#39;.result[] | [.service,.name,.resourceIdentifier,.accountName,.vendorAccountId,.availabilityZone,.region,.effectiveHourly,.totalSpend,.idle,.lastSeen,.volumeType,.state,.volumeSize,.iops,.throughput,.lastAttachedTime,.lastAttachedId] |@csv&#39; ./myfile.json`\r\n\r\nThis nets the following output ;\r\n\r\n\r\n`&quot;\\&quot;ebsvolume\\&quot;,\\&quot;gtest\\&quot;,\\&quot;vol-999999999999\\&quot;,\\&quot;g-test-acct\\&quot;,\\&quot;12345678912\\&quot;,\\&quot;ap-southeast-2c\\&quot;,\\&quot;ap-southeast-2\\&quot;,998.56,167.7,0,\\&quot;2018-08-16T22:00:00Z\\&quot;,\\&quot;io1\\&quot;,\\&quot;in-use\\&quot;,180,2000,500,\\&quot;2018-08-08T22:00:00Z\\&quot;,\\&quot;i-086f957ee\\&quot;&quot;`\r\n\r\nI figured out this but its not exactly what I am trying to achieve. I want to have each recommendation listed underneath on a seperate line, and not at the end of the same line. \r\n\r\n\r\n`jq &#39;.result[] | [.service,.name,.resourceIdentifier,.accountName,.vendorAccountId,.availabilityZone,.region,.effectiveHourly,.totalSpend,.idle,.lastSeen,.volumeType,.state,.volumeSize,.iops,.throughput,.lastAttachedTime,.lastAttachedId,.recommendations[].action] |@csv&#39; ./myfile.json`\r\n\r\nThis nets :\r\n\r\n\r\n`&quot;\\&quot;ebsvolume\\&quot;,\\&quot;gtest\\&quot;,\\&quot;vol-999999999999\\&quot;,\\&quot;g-test-acct\\&quot;,\\&quot;12345678912\\&quot;,\\&quot;ap-southeast-2c\\&quot;,\\&quot;ap-southeast-2\\&quot;,998.56,167.7,0,\\&quot;2018-08-16T22:00:00Z\\&quot;,\\&quot;io1\\&quot;,\\&quot;in-use\\&quot;,180,2000,500,\\&quot;2018-08-08T22:00:00Z\\&quot;,\\&quot;i-086f957ee\\&quot;,\\&quot;Rightsize\\&quot;,\\&quot;Rightsize\\&quot;,\\&quot;Rightsize\\&quot;&quot;`\r\n\r\nWhat I want is \r\n\r\n`&quot;\\&quot;ebsvolume\\&quot;,\\&quot;gtest\\&quot;,\\&quot;vol-999999999999\\&quot;,\\&quot;g-test-acct\\&quot;,\\&quot;12345678912\\&quot;,\\&quot;ap-southeast-2c\\&quot;,\\&quot;ap-southeast-2\\&quot;,998.56,167.7,0,\\&quot;2018-08-16T22:00:00Z\\&quot;,\\&quot;io1\\&quot;,\\&quot;in-use\\&quot;,180,2000,500,\\&quot;2018-08-08T22:00:00Z\\&quot;,\\&quot;i-086f957ee\\&quot;,\r\n\\&quot;Rightsize\\&quot;,\r\n\\&quot;Rightsize\\&quot;,\r\n\\&quot;Rightsize\\&quot;&quot;`\r\n\r\nSo not entirely sure how to deal with the array inside the &quot;recommendations&quot; section in jq, I think it might be called unflattening?\r\n",
        "link": "https://stackoverflow.com/questions/51944541/formatting-into-csv-json-file-using-jq",
        "title": "Formatting into CSV JSON file using jq"
    },
    {
        "tags": [
            "json",
            "geojson",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1534868324,
                "last_edit_date": 1534868324,
                "creation_date": 1534866656,
                "answer_id": 51952464,
                "question_id": 51951847,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The key to a simple solution is to recognize that the combined &quot;coordinates&quot; array can be computed by the filter:\r\n\r\n    [.features[] | .geometry | .coordinates[]] \r\n\r\nwhich can be abbreviated as:\r\n\r\n    [.features[].geometry.coordinates[]] \r\n\r\nLet&#39;s call this array `$combined`.  A solution can then be obtained by updating `.features`, like so:\r\n\r\n    .features = [.features[0] | (.geometry.coordinates = $combined)]\r\n\r\nA complete solution is thus:\r\n\r\n    [.features[].geometry.coordinates[]] as $combined\r\n    | .features = [.features[0] | (.geometry.coordinates = $combined)]\r\n\r\n\r\nThis can be further simplified using the `|=` operator:\r\n\r\n    [.features[].geometry.coordinates[]] as $combined\r\n    | .features |= [.[0] | (.geometry.coordinates = $combined)]\r\n\r\n\r\n",
                "title": "How to consolidate arrays under one single MultiLineString GeoJSON array using jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1534868324,
        "creation_date": 1534864599,
        "last_edit_date": 1534865363,
        "question_id": 51951847,
        "body_markdown": "There are coordinates within an array that are divided up between multiple GeoJSON `MultiLineString` structures. I would like to consolidate all the coordinates, maintaining them in their own array, under one single MultiLineString structure. How do i do this with `jq` ?\r\n\r\nThis is the original file (modified for example purposes)\r\n\r\n    {\r\n      &quot;type&quot;: &quot;FeatureCollection&quot;,\r\n      &quot;crs&quot;: {\r\n        &quot;type&quot;: &quot;name&quot;,\r\n        &quot;properties&quot;: {\r\n          &quot;name&quot;: &quot;urn:ogc:def:crs:OGC:1.3:CRS84&quot;\r\n        }\r\n      },\r\n    \r\n      &quot;features&quot;: [{\r\n          &quot;type&quot;: &quot;Feature&quot;,\r\n          &quot;geometry&quot;: {\r\n            &quot;type&quot;: &quot;MultiLineString&quot;,\r\n            &quot;coordinates&quot;: [\r\n              [\r\n                [-82.619152670413143, 29.568340757283536, 0.0],\r\n                [-82.619147188198966, 29.568355832670516, 0.0],\r\n                [-82.607558975018591, 29.580299204829011, 0.0]\r\n              ]\r\n            ]\r\n          }\r\n        },\r\n        {\r\n          &quot;type&quot;: &quot;Feature&quot;,\r\n          &quot;geometry&quot;: {\r\n            &quot;type&quot;: &quot;MultiLineString&quot;,\r\n            &quot;coordinates&quot;: [\r\n              [\r\n                [-82.619152670413513, 29.568340757283536, 0.0],\r\n                [-82.619490683489488, 29.568318912277654, 0.0],\r\n                [-82.629348688631055, 29.569000553128618, 0.0]\r\n              ]\r\n            ]\r\n          }\r\n        },\r\n        {\r\n          &quot;type&quot;: &quot;Feature&quot;,\r\n          &quot;geometry&quot;: {\r\n            &quot;type&quot;: &quot;MultiLineString&quot;,\r\n            &quot;coordinates&quot;: [\r\n              [\r\n                [-82.629348688631055, 29.569000553128618, 0.0],\r\n                [-82.62943243076478, 29.568922074598046, 0.0],\r\n                [-82.623065167913538, 29.56611193045412, 0.0]\r\n              ]\r\n            ]\r\n          }\r\n        },\r\n        {\r\n          &quot;type&quot;: &quot;Feature&quot;,\r\n          &quot;geometry&quot;: {\r\n            &quot;type&quot;: &quot;MultiLineString&quot;,\r\n            &quot;coordinates&quot;: [\r\n              [\r\n                [-82.618039923193663, 29.563657436904819, 0.0],\r\n                [-82.618306111861301, 29.565336028000189, 0.0],\r\n                [-82.619152670413669, 29.568340757283639, 0.0]\r\n              ]\r\n            ]\r\n          }\r\n        },\r\n        {\r\n          &quot;type&quot;: &quot;Feature&quot;,\r\n          &quot;geometry&quot;: {\r\n            &quot;type&quot;: &quot;MultiLineString&quot;,\r\n            &quot;coordinates&quot;: [\r\n              [\r\n                [-82.62306516791385, 29.566111930454156, 0.0],\r\n                [-82.618758856449034, 29.563742939021793, 0.0],\r\n                [-82.618212862210015, 29.563577318475456, 0.0]\r\n              ]\r\n            ]\r\n          }\r\n        }\r\n      ]\r\n    }\r\n\r\nWhat I am trying to achieve: \r\n\r\n    {\r\n      &quot;type&quot;: &quot;FeatureCollection&quot;,\r\n      &quot;crs&quot;: {\r\n        &quot;type&quot;: &quot;name&quot;,\r\n        &quot;properties&quot;: {\r\n          &quot;name&quot;: &quot;urn:ogc:def:crs:OGC:1.3:CRS84&quot;\r\n        }\r\n      },\r\n    \r\n      &quot;features&quot;: [{\r\n          &quot;type&quot;: &quot;Feature&quot;,\r\n          &quot;geometry&quot;: {\r\n            &quot;type&quot;: &quot;MultiLineString&quot;,\r\n            &quot;coordinates&quot;: [\r\n              [\r\n                [-82.619152670413143, 29.568340757283536, 0.0],\r\n                [-82.619147188198966, 29.568355832670516, 0.0],\r\n                [-82.607558975018591, 29.580299204829011, 0.0]\r\n              ],\r\n              [\r\n                [-82.619152670413513, 29.568340757283536, 0.0],\r\n                [-82.619490683489488, 29.568318912277654, 0.0],\r\n                [-82.629348688631055, 29.569000553128618, 0.0]\r\n              ],\r\n              [\r\n                [-82.629348688631055, 29.569000553128618, 0.0],\r\n                [-82.62943243076478, 29.568922074598046, 0.0],\r\n                [-82.623065167913538, 29.56611193045412, 0.0]\r\n              ],\r\n              [\r\n                [-82.618039923193663, 29.563657436904819, 0.0],\r\n                [-82.618306111861301, 29.565336028000189, 0.0],\r\n                [-82.619152670413669, 29.568340757283639, 0.0]\r\n              ],\r\n              [\r\n                [-82.62306516791385, 29.566111930454156, 0.0],\r\n                [-82.618758856449034, 29.563742939021793, 0.0],\r\n                [-82.618212862210015, 29.563577318475456, 0.0]\r\n              ]\r\n            ]\r\n          }\r\n        }\r\n      ]\r\n    }",
        "link": "https://stackoverflow.com/questions/51951847/how-to-consolidate-arrays-under-one-single-multilinestring-geojson-array-using-j",
        "title": "How to consolidate arrays under one single MultiLineString GeoJSON array using jq?"
    },
    {
        "tags": [
            "json",
            "bash",
            "curl",
            "jq",
            "jive"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1542297509,
                "last_edit_date": 1542297509,
                "creation_date": 1534869737,
                "answer_id": 51953248,
                "question_id": 51953147,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If your HTML file is short enough it can fit into a command line:\r\n\r\n    jq --arg text &quot;$(&lt;file.html)&quot; &#39;.content.text=$text&#39; file.json &gt;newfile.json\r\n\r\nAlternately, running an extra copy of `jq`, but working with files of any size:\r\n\r\n    jq --slurpfile texts &lt;(jq -Rs file.html) &#39;.content.text=$texts[0]&#39; file.json &gt;newfile.json",
                "title": "Insert an HTML file into a JSON file value using JQ"
            },
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1534886906,
                "creation_date": 1534886906,
                "answer_id": 51956934,
                "question_id": 51953147,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Regarding the &quot;Bonus Question&quot; about encoding the HTML file, you could simply use the filter `@html`, e.g.\r\n\r\n    .content.text=($text | @html)\r\n\r\nFrom the online manual:\r\n\r\n\r\n&gt; @html:\r\n&gt; \r\n&gt; Applies HTML/XML escaping, by mapping the characters &lt;&gt;&amp;&#39;&quot; to their\r\n&gt; entity equivalents &amp;lt;, &amp;gt;, &amp;amp;, &amp;apos;, &amp;quot;.",
                "title": "Insert an HTML file into a JSON file value using JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1542297509,
        "creation_date": 1534869315,
        "question_id": 51953147,
        "body_markdown": "## Goal\r\nMy goal is to push HTML content to the Jive content-management platform using the Jive API and a cURL command.\r\n\r\n## Current status\r\nI can do this successfully but my process is manual. I want to further automate by scripting the insertion of the HTML into the JSON file Jive requires to post HTML content through the API.\r\n\r\n## JSON file example\r\n\r\n    {\r\n        &quot;entityType&quot;: &quot;document&quot;,\r\n        &quot;content&quot;: {\r\n            &quot;type&quot;: &quot;text/html&quot;,\r\n            &quot;text&quot;: &quot;ENCODED HTML FILE CONTENT AS A STRING&quot;\r\n        },\r\n        &quot;type&quot;: &quot;document&quot;,\r\n        &quot;subject&quot;: &quot;Document Title&quot;,\r\n        &quot;visibility&quot;: &quot;place&quot;,\r\n        &quot;parent&quot;: &quot;https://&lt;URL&gt;/api/core/v3/places/1579&quot;\r\n    }\r\n\r\n## HTML file example\r\n\r\n    &lt;html lang=&quot;en&quot;&gt;\r\n    &lt;body&gt;\r\n    &lt;h1 id=&quot;example&quot;&gt;Sample file&lt;/h1&gt;\r\n        &lt;p&gt;Sample text&lt;/p&gt;\r\n    &lt;table&gt;\r\n        &lt;thead&gt;\r\n            &lt;tr class=&quot;header&quot;&gt;\r\n\r\n    etc.\r\n\r\n## cURL example\r\n\r\n    curl -X PUT -u username:password -H &quot;Content-Type: application/json&quot; -H &quot;Accept: application/json&quot; -H &quot;Cache-Control: no-cache&quot; -d @file.json &quot;https://&lt;URL&gt;/api/core/v3/contents/12204&quot;\r\n\r\nThe Jive API [does not turn a standalone .html file sent over the API into HTML content](https://community.jivesoftware.com/community/developer/blog/2015/06/24/upload-a-local-file-using-the-jive-api) but rather treats it as any uploaded binary file, which must be downloaded by the user.\r\n\r\n## Attempts to solve\r\nA [similar question in Stack Overflow](https://stackoverflow.com/questions/36273218/jq-read-txt-file-and-write-the-values-to-json-file) asks about inserting a .txt file in the same manner. The accepted answer suggests that I try:\r\n\r\n    jq --slurpfile text file.html &#39;.text=$text&#39; file.json &gt;newfile.json\r\n\r\nI have tried surrounding the file with quotes (after it is encoded and stringified), which also failed.\r\n\r\n## Why cURL and JQ\r\nThe reason I am looking for a JQ + cURL solution is that both JQ and cURL can be run with a Bash script, which is the only programming I know.\r\n\r\n## Bonus question\r\nTo make the HTML file an encoded string, I run `sed &#39;s/&amp;/\\&amp;amp;/g; s/&quot;/\\\\\\&quot;/g; s/&#39;&quot;&#39;&quot;&#39;/\\\\\\&#39;&quot;&#39;&quot;&#39;/g&#39;` and remove all the hard returns. I believe JQ&#39;s raw input and slurp options can solve this with something like `jq -Rs &#39;{ text: . }&#39; file.html` (according to this [Stack overflow question](https://stackoverflow.com/questions/33359437/read-files-into-json), and JQ offers an [@json](https://stedolan.github.io/jq/manual) method that escapes HTML, but after many web searches and attempts I have failed at both. It would be nice to run one JQ command that both encoded/stringified the HTML _and_ inserted the HTML into the .json file.\r\n\r\n## If this is the wrong approach entirely...\r\nThe solutions described in this question are my attempt to solve my problem and I invite a broader perspective as to whether my basic assumptions and approach are inferior to other potential approaches.\r\n\r\nThank you.",
        "link": "https://stackoverflow.com/questions/51953147/insert-an-html-file-into-a-json-file-value-using-jq",
        "title": "Insert an HTML file into a JSON file value using JQ"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 7869117,
                    "reputation": 62566,
                    "user_id": 5947043,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/jUK37.png?s=256",
                    "display_name": "ADyson",
                    "link": "https://stackoverflow.com/users/5947043/adyson"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1534886216,
                "post_id": 51956550,
                "comment_id": 90864258,
                "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": 1534886404,
                "post_id": 51956550,
                "comment_id": 90864306,
                "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": 1534886515,
                "post_id": 51956550,
                "comment_id": 90864330,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 468289,
                    "reputation": 190915,
                    "user_id": 874188,
                    "user_type": "registered",
                    "accept_rate": 62,
                    "profile_image": "https://www.gravatar.com/avatar/091f411d57db5be8298e057a32e5ad72?s=256&d=identicon&r=PG",
                    "display_name": "tripleee",
                    "link": "https://stackoverflow.com/users/874188/tripleee"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1683527327,
                "post_id": 51956550,
                "comment_id": 134374587,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": false,
                "score": 5,
                "last_activity_date": 1534901278,
                "creation_date": 1534901278,
                "answer_id": 51958709,
                "question_id": 51956550,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Well you could use jq in conjunction with `split` to write those files.\r\n\r\n    $ jq -nc --stream &#39;fromstream(1|truncate_stream(inputs))&#39; large_file.json |\r\n        split -dl 100000 -additional-suffix=.json - part",
                "title": "Splitting a larger json file into smaller files"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1534901278,
        "creation_date": 1534884753,
        "question_id": 51956550,
        "body_markdown": "I have a json file that is 2.37 gb with about 2.1 million records. I wanted to use jq to go through the file and create a new file every 100000 records.\r\n\r\nI.e \r\n\r\npart1.json\r\npart2.json\r\npart3.json\r\npart4.json\r\npart5.json\r\netc\r\n\r\nHas anyone done this with jq? \r\n\r\n",
        "link": "https://stackoverflow.com/questions/51956550/splitting-a-larger-json-file-into-smaller-files",
        "title": "Splitting a larger json file into smaller files"
    },
    {
        "tags": [
            "json",
            "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": 1534936679,
                "post_id": 51965607,
                "comment_id": 90881070,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 13026626,
                    "reputation": 509,
                    "user_id": 9414424,
                    "user_type": "registered",
                    "accept_rate": 75,
                    "profile_image": "https://lh3.googleusercontent.com/-XdUIqdMkCWA/AAAAAAAAAAI/AAAAAAAAAAA/4252rscbv5M/s256-rj/photo.jpg",
                    "display_name": "user9414424",
                    "link": "https://stackoverflow.com/users/9414424/user9414424"
                },
                "reply_to_user": {
                    "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": 1534937168,
                "post_id": 51965607,
                "comment_id": 90881349,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 7,
                "is_accepted": true,
                "score": 7,
                "last_activity_date": 1534947723,
                "last_edit_date": 1592644375,
                "creation_date": 1534940287,
                "answer_id": 51966736,
                "question_id": 51965607,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "# A `jq` solution\n\nYou can use the `jq`&#39;s [`walk()`](https://stedolan.github.io/jq/manual/#walk(f)) builtin to recursively walk the JSON values, check their [`type`](https://stedolan.github.io/jq/manual/#type)s and convert the numbers [`tostring()`](https://stedolan.github.io/jq/manual/#tostring).\n\nAssuming your JSON is stored in the file `input.json`, the command is like:\n\n\n    jq &#39;walk(if type == &quot;number&quot; then tostring else . end)&#39; input.json\n\nIt dumps the modified JSON to the screen and its output can be redirector to another file (`&gt; output.json`).\n\n### If it fails \n\nMost probably, the command above fails with the error message:\n\n    jq: error: walk/1 is not defined at &lt;top-level&gt;, line 1:\n\nIt means the `walk()` builtin is not (!) built into the `jq` version you use. The issue has been reported two years ago (issue [#1106](https://github.com/stedolan/jq/issues/1106)) but it apparently is not a bug but an optional feature. The definition of builtins can be [downloaded](https://github.com/stedolan/jq/wiki/FAQ#definition-of-builtins) from Github&#39;s project page. Once downloaded and saved in a local file, the builtins module can be loaded using [`include()`](https://stedolan.github.io/jq/manual/#includeRelativePathString[%3Cmetadata%3E];) and used.\n\nYour workflow would look like this:\n\n    # Download the builtins module (only once) and save it in &#39;./builtin.jq&#39;\n    curl -O https://raw.githubusercontent.com/stedolan/jq/master/src/builtin.jq\n\n    # Process the data\n    jq &#39;include &quot;./builtin&quot;; walk(if type == &quot;number&quot; then tostring else . end)&#39; input.json &gt; output.json\n\nThat&#39;s all!",
                "title": "How to convert all integers in a json file to strings via jq command?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1534947723,
        "creation_date": 1534936386,
        "question_id": 51965607,
        "body_markdown": "Suppose that we have a `a.json` file. The file contains many attributes.\r\nFor example in the file, I just show two attributes &quot;name&quot; and &quot;age&quot;.\r\nIn fact there are more attributes having numerical values though.\r\n\r\n    {\r\n      &quot;name&quot;:[\r\n        &quot;James&quot;, \r\n        &quot;Alek&quot;, \r\n        &quot;Bob&quot;\r\n      ],\r\n      &quot;age&quot;:[\r\n        35,\r\n        25,\r\n        23\r\n      ]\r\n      ...//other attributes with numerical values\r\n    } \r\n\r\nHow can we convert the file like the following?\r\n\r\n    {\r\n      &quot;name&quot;:[\r\n        &quot;James&quot;, \r\n        &quot;Alek&quot;, \r\n        &quot;Bob&quot;\r\n      ],\r\n      &quot;age&quot;:[\r\n        &quot;35&quot;,\r\n        &quot;25&quot;,\r\n        &quot;23&quot;\r\n      ]\r\n      ...//other attributes with numerical values\r\n    } \r\n",
        "link": "https://stackoverflow.com/questions/51965607/how-to-convert-all-integers-in-a-json-file-to-strings-via-jq-command",
        "title": "How to convert all integers in a json file to strings via jq command?"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 9,
                "is_accepted": false,
                "score": 9,
                "last_activity_date": 1535026855,
                "last_edit_date": 1535026855,
                "creation_date": 1534945252,
                "answer_id": 51968247,
                "question_id": 51968246,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I came up with the following expression:\r\n\r\n`jq &quot;to_entries[] | select(.value.restricted|not) | .key&quot;`\r\n\r\n`to_entries` converts the top-level object to an array of objects with a `&quot;key&quot;` and a `&quot;value&quot;` attribute each:\r\n\r\n    [\r\n      {\r\n        &quot;key&quot;: &quot;foo135&quot;,\r\n        &quot;value&quot;: {\r\n          &quot;restricted&quot;: true\r\n        }\r\n      },\r\n      {\r\n        &quot;key&quot;: &quot;foo246&quot;,\r\n        &quot;value&quot;: {\r\n          &quot;restricted&quot;: false\r\n        }\r\n      },\r\n      {\r\n        &quot;key&quot;: &quot;foo345&quot;,\r\n        &quot;value&quot;: {}\r\n      }\r\n    ]\r\n\r\n`[]` explodes this array. This is done in order to filter individual objects in the next step:\r\n\r\n    {\r\n      &quot;key&quot;: &quot;foo135&quot;,\r\n      &quot;value&quot;: {\r\n        &quot;restricted&quot;: true\r\n      }\r\n    }\r\n    {\r\n      &quot;key&quot;: &quot;foo246&quot;,\r\n      &quot;value&quot;: {\r\n        &quot;restricted&quot;: false\r\n      }\r\n    }\r\n    {\r\n      &quot;key&quot;: &quot;foo345&quot;,\r\n      &quot;value&quot;: {}\r\n    }\r\n\r\nThen a filter is applied for each object: `select(.value.restricted|not)`. To filter out attributes with the subattribute `restricted` being truthy, `.value.restricted` can be inverted with `|not` to select objects with `restricted == false` as well as objects without this attribute using a single condition:\r\n\r\n    {\r\n      &quot;key&quot;: &quot;foo246&quot;,\r\n      &quot;value&quot;: {\r\n        &quot;restricted&quot;: false\r\n      }\r\n    }\r\n    {\r\n      &quot;key&quot;: &quot;foo345&quot;,\r\n      &quot;value&quot;: {}\r\n    }\r\n\r\nFinally, the `&quot;key&quot;` attribute is selected: `.key`. This returns the names of the matching objects (originally the top-level attribute keys):\r\n\r\n    &quot;foo246&quot;\r\n    &quot;foo345&quot;\r\n\r\nNote that the pipe character `|` in `select(...) | .key` isn&#39;t strictly needed. The result is the same without.\r\n\r\nIf a string array is desired as result...\r\n\r\n    [\r\n      &quot;foo246&quot;,\r\n      &quot;foo345&quot;\r\n    ]\r\n\r\n... then the following expression can be used:\r\n\r\n    jq &quot;to_entries | map(select(.value.restricted|not).key)&quot;\r\n\r\nAs you can see, `select()` can be used inside of `map()` to filter out individual elements, and it can even be combined with the attribute filter `.key`.\r\n\r\nIf you append `[]` at the end like `map(...)[]`, then the array gets exploded and the result is a list of strings again, like in the initial example, but using a slightly different approach.",
                "title": "jq - Return all top-level attribute keys which have a subattribute that matches a condition"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 5,
        "last_activity_date": 1535026855,
        "creation_date": 1534945252,
        "last_edit_date": 1535020544,
        "question_id": 51968246,
        "body_markdown": "My JSON looks like:\r\n\r\n    {\r\n      &quot;foo&quot;: {\r\n        &quot;restricted&quot;: true\r\n      },\r\n      &quot;bar&quot;: {\r\n        &quot;restricted&quot;: false\r\n      },\r\n      &quot;baz&quot;: { }\r\n    }\r\n\r\nAs single line:\r\n\r\n    {&quot;foo&quot;:{&quot;restricted&quot;:true},&quot;bar&quot;:{&quot;restricted&quot;:false},&quot;baz&quot;:{}}\r\n\r\nI want to get all top-level attribute keys returned which are either `restricted == false` or don&#39;t have the `restricted` subattribute. With above example JSON, the expected output is:\r\n\r\n    &quot;bar&quot;\r\n    &quot;baz&quot;\r\n",
        "link": "https://stackoverflow.com/questions/51968246/jq-return-all-top-level-attribute-keys-which-have-a-subattribute-that-matches",
        "title": "jq - Return all top-level attribute keys which have a subattribute that matches a condition"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1534976146,
                "last_edit_date": 1534976146,
                "creation_date": 1534975786,
                "answer_id": 51975841,
                "question_id": 51970546,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You just need to wrap the result in `[...]`:\r\n\r\n    [.[] | select(.Key == &quot;app&quot;), select(.Key == &quot;app_env&quot;), select(.Key == &quot;sbu&quot;)]\r\n\r\nYou can also shorten this filter slightly:\r\n\r\n    [.[] | select(.Key == &quot;app&quot; or .Key == &quot;app_env&quot; or .Key == &quot;sbu&quot;)]\r\n\r\nOr use the `map` function:\r\n\r\n    map(select(.Key == &quot;app&quot; or .Key == &quot;app_env&quot; or .Key == &quot;sbu&quot;))",
                "title": "Using jq, select multiple keys and return them in an array"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1682942654,
                "creation_date": 1682942654,
                "answer_id": 76146785,
                "question_id": 51970546,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Small improvement on @chepner&#39;s answer that&#39;s a bit more concise:\r\n\r\n```jq\r\nmap(select(.Key == (&quot;app&quot;, &quot;app_env&quot;, &quot;sbu&quot;)))\r\n```\r\n",
                "title": "Using jq, select multiple keys and return them in an array"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1682942654,
        "creation_date": 1534952671,
        "question_id": 51970546,
        "body_markdown": "Given this array:\r\n\r\n    [{&quot;Key&quot;:&quot;base_ami&quot;,&quot;Value&quot;:&quot;ami-46d003ac&quot;},\r\n    {&quot;Key&quot;:&quot;app&quot;,&quot;Value&quot;:&quot;amibuild&quot;},\r\n    {&quot;Key&quot;:&quot;sbu&quot;,&quot;Value&quot;:&quot;IT&quot;},\r\n    {&quot;Key&quot;:&quot;base_ami_image_location&quot;,&quot;Value&quot;:&quot;123456789012/amazon-linux&quot;},\r\n    {&quot;Key&quot;:&quot;app_env&quot;,&quot;Value&quot;:&quot;dev&quot;},\r\n    {&quot;Key&quot;:&quot;Name&quot;,&quot;Value&quot;:&quot;amazon-linux&quot;},\r\n    {&quot;Key&quot;:&quot;jenkins_build_id&quot;,&quot;Value&quot;:&quot;24&quot;},\r\n    {&quot;Key&quot;:&quot;os_type&quot;,&quot;Value&quot;:&quot;linux&quot;},\r\n    {&quot;Key&quot;:&quot;version&quot;,&quot;Value&quot;:&quot;1.0.24&quot;}]\r\n\r\nI want this output:\r\n\r\n    [{&quot;Key&quot;:&quot;app&quot;,&quot;Value&quot;:&quot;amibuild&quot;},{&quot;Key&quot;:&quot;sbu&quot;,&quot;Value&quot;:&quot;IT&quot;},{&quot;Key&quot;:&quot;app_env&quot;,&quot;Value&quot;:&quot;dev&quot;}]\r\n\r\nI&#39;ve got it down as far as this:\r\n\r\n    .[] | select(.Key == &quot;app&quot;), select(.Key == &quot;app_env&quot;), select(.Key == &quot;sbu&quot;)\r\n\r\nbut that results in:\r\n\r\n    {&quot;Key&quot;:&quot;app&quot;,&quot;Value&quot;:&quot;amibuild&quot;}\r\n    {&quot;Key&quot;:&quot;sbu&quot;,&quot;Value&quot;:&quot;IT&quot;}\r\n    {&quot;Key&quot;:&quot;app_env&quot;,&quot;Value&quot;:&quot;dev&quot;}\r\n\r\nI need those individual objects returned as elements of an array.",
        "link": "https://stackoverflow.com/questions/51970546/using-jq-select-multiple-keys-and-return-them-in-an-array",
        "title": "Using jq, select multiple keys and return them in an array"
    },
    {
        "tags": [
            "arrays",
            "json",
            "node.js",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 10597965,
                    "reputation": 3836,
                    "user_id": 7805917,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/44a9e844e013e7c5ae10d7645e6e333c?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Inder",
                    "link": "https://stackoverflow.com/users/7805917/inder"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1534954514,
                "post_id": 51970861,
                "comment_id": 90892599,
                "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": 1534967745,
                "post_id": 51970861,
                "comment_id": 90898858,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1534963570,
                "creation_date": 1534963570,
                "answer_id": 51973311,
                "question_id": 51970861,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I&#39;d recommend printing the id on one line, and the corresponding object on the next. For example:\r\n\r\n    jq -c &#39;.mappings[] | .id, .&#39; mappings.json |\r\n        while read -r id ; do\r\n    \techo &quot;id=$id&quot;\r\n    \tread -r json\r\n    \t  jq . &lt;&lt;&lt; &quot;$json&quot;  &gt; &quot;tmp/${id}.json&quot;\r\n    done\r\n\r\n",
                "title": "bash split array into separate files with dynamic name"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1534968122,
                "creation_date": 1534968122,
                "answer_id": 51974288,
                "question_id": 51970861,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I would write a simple Python script instead (or the equivalent in your favorite, general-purpose programming language).\r\n\r\n    import sys, json\r\n\r\n    d = json.load(sys.stdin):\r\n    for o in d[&#39;mappings&#39;]:\r\n        with open(os.path.join(&#39;tmp&#39;, o[&#39;id&#39;] + &#39;.json&#39;), &#39;w&#39;) as f:\r\n            json.dump(o, f)\r\n\r\nThis would be more efficient and less error-prone, at least until `jq` gets some sort of `output` built-in:\r\n\r\n    # hypothetical\r\n    jq &#39;.mappings[] | output(&quot;tmp/\\(.id).json&quot;)&#39; mappings.json",
                "title": "bash split array into separate files with dynamic name"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1534968122,
        "creation_date": 1534953708,
        "last_edit_date": 1534954357,
        "question_id": 51970861,
        "body_markdown": "I have the following returned to me as a response of a mocking tool I&#39;m using.\r\n\r\n    {\r\n      &quot;mappings&quot; : [ \r\n\t{\r\n    &quot;id&quot; : &quot;bcf3559f-7ff7-406b-a4f1-6d3e9ac00e63&quot;,\r\n    &quot;name&quot; : &quot;Hellow world 2&quot;,\r\n    &quot;request&quot; : {\r\n      &quot;url&quot; : &quot;/hello-world-2&quot;,\r\n      &quot;method&quot; : &quot;POST&quot;\r\n    },\r\n    &quot;response&quot; : {\r\n      &quot;status&quot; : 200,\r\n      &quot;body&quot; : &quot;\\nBody content for stub 3\\n\\n&quot;,\r\n      &quot;headers&quot; : { }\r\n    },\r\n    &quot;uuid&quot; : &quot;bcf3559f-7ff7-406b-a4f1-6d3e9ac00e63&quot;,\r\n    &quot;persistent&quot; : true,\r\n    &quot;priority&quot; : 5\r\n      }, \r\n    {\r\n    &quot;id&quot; : &quot;9086b24f-4f5e-465a-bbe5-73bbfb82cd5c&quot;,\r\n    &quot;name&quot;: &quot;Hello world&quot;,\r\n    &quot;request&quot; : {\r\n      &quot;url&quot; : &quot;/hello-world&quot;,\r\n      &quot;method&quot; : &quot;ANY&quot;\r\n    },\r\n    &quot;response&quot; : {\r\n      &quot;status&quot; : 200,\r\n      &quot;body&quot; : &quot;Hi!&quot;\r\n    },\r\n    &quot;uuid&quot; : &quot;9086b24f-4f5e-465a-bbe5-73bbfb82cd5c&quot;\r\n    } ]\r\n    }\r\n\r\nI&#39;d like to know how I can split each object into it&#39;s own file with the file named after the id of the object.\r\n\r\nE.g: \r\n\r\nbcf3559f-7ff7-406b-a4f1-6d3e9ac00e63.json\r\n\r\nbcf3559f-7ff7-406b-a4f1-6d3e9ac00e63.json \r\n\r\nI have got as far as this so far but can&#39;t get it over the line:\r\n\r\n    jq -c &#39;.mappings = (.mappings[] | [.])&#39; mappings.json |\r\n      while read -r json ; do\r\n      N=$((N+1))\r\n      jq . &lt;&lt;&lt; &quot;$json&quot;  &gt; &quot;tmp/file${N}.json&quot;\r\n    done\r\n\r\n",
        "link": "https://stackoverflow.com/questions/51970861/bash-split-array-into-separate-files-with-dynamic-name",
        "title": "bash split array into separate files with dynamic name"
    },
    {
        "tags": [
            "json",
            "command-line",
            "terminal",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1535059397,
                "creation_date": 1535059397,
                "answer_id": 51994452,
                "question_id": 51987063,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This gets the desired result. I think the [manual][1] entry under .[] explains why it works.\r\n\r\n    jq &#39;.groups[] | {&quot;id&quot;: .group, &quot;value&quot;: [.items[].item]}&#39;\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/v1.5/",
                "title": "Getting unique values from nested Array using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1535059397,
        "creation_date": 1535031243,
        "question_id": 51987063,
        "body_markdown": "Trying to get unique values stored in items array for each group. somehow it&#39;s always mixed...\r\n\r\nMy JSON looks like this:\r\n\r\n    {\r\n      &quot;start&quot;: 1534425916,\r\n      &quot;stop&quot;: 1535030716,\r\n      &quot;groups&quot;: [\r\n        {\r\n          &quot;group&quot;: &quot;transmission&quot;,\r\n          &quot;data&quot;: {\r\n            &quot;events&quot;: 665762,\r\n          },\r\n          &quot;items&quot;: [\r\n            {\r\n              &quot;item&quot;: &quot;manualni&quot;,\r\n              &quot;data&quot;: {\r\n                &quot;events&quot;: 389158,\r\n              }\r\n            },\r\n            {\r\n              &quot;item&quot;: &quot;automaticka&quot;,\r\n              &quot;data&quot;: {\r\n                &quot;events&quot;: 276604,\r\n              }\r\n            }\r\n          ]\r\n        },\r\n        {\r\n          &quot;group&quot;: &quot;vat&quot;,\r\n          &quot;data&quot;: {\r\n            &quot;events&quot;: 671924,\r\n          },\r\n          &quot;items&quot;: [\r\n            {\r\n              &quot;item&quot;: &quot;ne&quot;,\r\n              &quot;data&quot;: {\r\n                &quot;events&quot;: 346221,\r\n              }\r\n            },\r\n            {\r\n              &quot;item&quot;: &quot;ano&quot;,\r\n              &quot;data&quot;: {\r\n                &quot;events&quot;: 325703,\r\n              }\r\n            }\r\n          ]\r\n        }\r\n      ]\r\n    }\r\n\r\nDesired result is the following:\r\n\r\n    {\r\n      &quot;id&quot;: &quot;transmission&quot;,\r\n      &quot;value&quot;: [\r\n        &quot;manualni&quot;,\r\n        &quot;automaticka&quot;,\r\n      ]\r\n    }\r\n    {\r\n      &quot;id&quot;: &quot;vat&quot;,\r\n      &quot;value&quot;: [\r\n        &quot;ne&quot;,\r\n        &quot;ano&quot;\r\n      ]\r\n    }\r\n\r\nTried with this filter on command line:\r\n\r\n    | jq &#39;{id: .groups[].group, value: [.groups[].items[].item]}&#39;\r\n\r\nWhich results in the above mentioned mixed up result:\r\n\r\n    {\r\n      &quot;id&quot;: &quot;transmission&quot;,\r\n      &quot;value&quot;: [\r\n        &quot;manualni&quot;,\r\n        &quot;automaticka&quot;,\r\n        &quot;ne&quot;,\r\n        &quot;ano&quot;\r\n      ]\r\n    }\r\n    {\r\n      &quot;id&quot;: &quot;vat&quot;,\r\n      &quot;value&quot;: [\r\n        &quot;manualni&quot;,\r\n        &quot;automaticka&quot;,\r\n        &quot;ne&quot;,\r\n        &quot;ano&quot;\r\n      ]\r\n    }\r\n\r\nAny idea how to receive the uniquified values here? Thanks in advance!",
        "link": "https://stackoverflow.com/questions/51987063/getting-unique-values-from-nested-array-using-jq",
        "title": "Getting unique values from nested Array using jq"
    },
    {
        "tags": [
            "json",
            "object",
            "select",
            "key",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 4203335,
                    "reputation": 96,
                    "user_id": 3442916,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/2713d911f1faf0d25989d5c025f06b83?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "split",
                    "link": "https://stackoverflow.com/users/3442916/split"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1535047672,
                "post_id": 51991463,
                "comment_id": 90933284,
                "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": 1535078253,
                "post_id": 51991463,
                "comment_id": 90942722,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1535078752,
                "creation_date": 1535078752,
                "answer_id": 51996770,
                "question_id": 51991463,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If your jq has `walk`, and if your computer has enough memory:\r\n\r\n    walk(if type == &quot;object&quot; \r\n         then if has(&quot;time&quot;) then . else empty end\r\n         else . end )\r\n\r\nTo get a copy of the def of `walk`, see e.g. https://github.com/stedolan/jq/blob/master/src/builtin.jq",
                "title": "jq gets objects that contain certain key"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1726435978,
        "creation_date": 1535046083,
        "last_edit_date": 1726435978,
        "question_id": 51991463,
        "body_markdown": "I&#39;m strugling to find a solution to this, every other question I&#39;ve found its quite close but still not the answer.\r\n\r\nI&#39;ve got a huge json, and it has many objects and arrays inside. \r\nWhat I&#39;d like do to is extract the whole object from that json that contain a key named &quot;time&quot; or &quot;*time*&quot;. I&#39;ve found solutions related, however they just brings the key and not the whole object.\r\n\r\nEx 1:\r\n\r\n&lt;!-- language-all: json --&gt;\r\n        {\r\n          &quot;time&quot;: -762,\r\n          &quot;type&quot;: &quot;chatwheel&quot;,\r\n          &quot;key&quot;: &quot;156&quot;,\r\n          &quot;slot&quot;: 1,\r\n          &quot;player_slot&quot;: 1\r\n        }\r\n\r\nEx 2:\r\n\r\n    {\r\n      &quot;time&quot;: 888,\r\n      &quot;type&quot;: &quot;building_kill&quot;,\r\n      &quot;unit&quot;: &quot;npc_knight&quot;,\r\n      &quot;key&quot;: &quot;npc_goodguys_tower1&quot;,\r\n      &quot;slot&quot;: 7,\r\n      &quot;player_slot&quot;: 130\r\n    },\r\n\r\nEx 3:\r\n\r\n    {\r\n      &quot;time&quot;: 681,\r\n      &quot;type&quot;: &quot;obs_left_log&quot;,\r\n      &quot;key&quot;: &quot;[132, 124]&quot;,\r\n      &quot;slot&quot;: 0,\r\n      &quot;x&quot;: 132,\r\n      &quot;y&quot;: 124,\r\n      &quot;z&quot;: 130,\r\n      &quot;entityleft&quot;: true,\r\n      &quot;ehandle&quot;: 5014545,\r\n      &quot;player_slot&quot;: 0\r\n    },\r\n\r\n\r\nEx 4:\r\n\r\n      &quot;purchase_log&quot;: [\r\n        {\r\n          &quot;time&quot;: -89,\r\n          &quot;key&quot;: &quot;orb_of_venom&quot;\r\n        },\r\n        {\r\n          &quot;time&quot;: -89,\r\n          &quot;key&quot;: &quot;tango&quot;\r\n        },\r\n\r\nSo, basically, I need to get not only the time key, i need to get the whole object that the key &quot;time&quot; belongs. (like the examples)\r\nIs there a way to do it?\r\n\r\nThank you",
        "link": "https://stackoverflow.com/questions/51991463/jq-gets-objects-that-contain-certain-key",
        "title": "jq gets objects that contain certain key"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": -1,
                "last_activity_date": 1535408205,
                "last_edit_date": 1535408205,
                "creation_date": 1535134749,
                "answer_id": 52009851,
                "question_id": 51992570,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I found a solution by saving the original input as a variable so that I can continue to reference it while operating on its values.\r\n\r\n    . as $arr\r\n    | length as $len\r\n    | [\r\n        .[]\r\n        | . as $i\r\n        | {\r\n            $(i): (\r\n              if ($arr | index($i)) &lt; ($x % $len) then\r\n                ($x / $len) + 1\r\n              else\r\n                $x / $len\r\n              end\r\n              | floor\r\n            )\r\n          }\r\n      ]\r\n    | add\r\n\r\nThe following worked for me with passing `--argjson count $X` and feeding the array as my input.",
                "title": "Spread number equally across elements of array (and add remainder to beginning of ring)"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1535147080,
                "last_edit_date": 1535147080,
                "creation_date": 1535146100,
                "answer_id": 52011953,
                "question_id": 51992570,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use the `transpose` function to help build this. It&#39;s simpler with a `ceil` function, which we have to define ourselves. The mapping you are looking for from index to allocation is `ceil($count - $i)/$n)`, where `$count` is the amount you are distributing, `$i` is the index in the original list, and `$n` is the length of the list.\r\n\r\nComments show how each piece works on your sample input of `[&quot;foo&quot;, &quot;bar&quot;, &quot;baz&quot;]`.\r\n\r\n    def ceil(v): -(-v | floor);\r\n    def objectify(n): {key: .[0], value: ceil(($count - .[1])/n)}; \r\n      # [&quot;foo&quot;, 0] | objectify(3) -&gt; {&quot;key&quot;: &quot;foo&quot;, &quot;value&quot;, 2}\r\n    length as $n |   # n == 3\r\n    [., keys]    |   # [[&quot;foo&quot;, &quot;bar&quot;, &quot;baz&quot;], [0,1,2]]\r\n    [transpose[] |   # [[&quot;foo&quot;, 0], [&quot;bar&quot;, 1], [&quot;baz&quot;, 2]]\r\n        objectify($n)\r\n    ] |\r\n    from_entries # {&quot;foo&quot;: 2, &quot;bar&quot;: 2, &quot;baz&quot;: 1}\r\n\r\nWithout the comments...\r\n\r\n    def ceil(v): -(-v | floor);\r\n    def objectify(n): {key: .[0], value: ceil(($count - .[1])/n)};\r\n    length as $n | [., keys] | [transpose[] | objectify($n)] | from_entries\r\n\r\nAn example of its use, assuming you saved it to file named `distribute.jq`:\r\n\r\n    jq --argjson count 5 -f distribute.jq tmp.json",
                "title": "Spread number equally across elements of array (and add remainder to beginning of ring)"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1535408205,
        "creation_date": 1535050553,
        "last_edit_date": 1535075971,
        "question_id": 51992570,
        "body_markdown": "Let&#39;s say I have some JSON array, we&#39;ll call it `A`:\r\n\r\n`[&quot;foo&quot;, &quot;bar&quot;, &quot;baz&quot;]`\r\n\r\nAnd I have some number `X`, let&#39;s say 5 in this case.\r\n\r\nI want to produce the following object in jq:\r\n\r\n    {\r\n      &quot;foo&quot;: 2,\r\n      &quot;bar&quot;: 2,\r\n      &quot;baz&quot;: 1,\r\n    }\r\n\r\nThis is the number 5 divided up equally across the elements of the array, with the remainder being distributed to the elements at the beginning of the ring. You could maybe think of it this way, the value for element `N` should be `ceil(X / length(A))` if `index(N) &lt; (X % length(A))`, otherwise it should be `floor(X / length(A))`.\r\n\r\nAssuming `A` is my file input to jq, and I have `X` defined as a variable, how can I express this in jq?\r\n\r\nI have tried `&#39;length as $len | .[] | if index(.) &lt; (5 % $len) then (5 / $len) + 1 else 5 / $len end&#39; | 5` as a starting point but I get 2 for each element.\r\n\r\n",
        "link": "https://stackoverflow.com/questions/51992570/spread-number-equally-across-elements-of-array-and-add-remainder-to-beginning-o",
        "title": "Spread number equally across elements of array (and add remainder to beginning of ring)"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 57200,
                    "reputation": 158728,
                    "user_id": 171318,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/ePRKy.jpg?s=256",
                    "display_name": "hek2mgl",
                    "link": "https://stackoverflow.com/users/171318/hek2mgl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1535152703,
                "post_id": 52012535,
                "comment_id": 90976360,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1535153939,
                "creation_date": 1535153939,
                "answer_id": 52012877,
                "question_id": 52012535,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It seems to me that you don&#39;t need two bash scripts. You can call file-a.sh with an argument:\r\n  \r\n    ./file-a.sh &quot;This is my subject&quot; \r\n\r\nand within file-a.sh you can access the argument as:\r\n\r\n    echo &quot;Subject: $1&quot;\r\n\r\n... where $1 , $2  etc are the variables \r\n\r\n\r\n\r\n\r\n",
                "title": "Pipe variable from a Bash file into a JQ command in another Bash file"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1535153939,
        "creation_date": 1535150609,
        "last_edit_date": 1535151476,
        "question_id": 52012535,
        "body_markdown": "## Goal\r\nPipe variable from a Bash file into a JQ command in another Bash file\r\n\r\n## Context\r\nI have a JSON file with two empty values I want to populate with:\r\n\r\n- An HTML file\r\n- A variable in a Bash file (file-b.sh)\r\n\r\nThe HTML portion works. I cannot figure out the variable portion. I show the HTML portion to demonstrate the logic I&#39;m attempting to follow.\r\n\r\n### file-a.sh\r\n\r\n    #!/bin/bash\r\n    \r\n    #This line (for the HTML portion) works:\r\n    jq --arg text &quot;$(&lt;file.html)&quot; &#39;.content.text=($text | @html)&#39; my-json.json &gt; file.json\r\n    \r\n    # This line (for the Bash variable) doesn&#39;t...see end of question for result:\r\n    jq --arg variable &quot;$subject&quot; &#39;.subject=$variable&#39; file.json &gt; file-1.json\r\n\r\n### file-b.sh\r\n\r\n    #!/bin/bash\r\n    \r\n    subject=&quot;abc&quot;\r\n    export subject\r\n    ./file-a.sh\r\n\r\n### file-1.json: The result\r\nThe result is that `content.text` is populated, while `subject` is printed literally as the variable I attempted to code.\r\n\r\n    {\r\n      &quot;content&quot;: {\r\n        &quot;text&quot;: &quot;Is populated; works great&quot;\r\n      },\r\n      &quot;subject&quot;: &quot;$subject&quot;,\r\n    }\r\n\r\nBased on what I have read, I have tried many iterations of single quotes, double quotes, parentheses, curly brackets (e.g., `{&quot;$subject&quot;}` or `&quot;.subject=$variable&quot;`), `echo` in a pipe, but continue to fail. Thank you for any ideas.",
        "link": "https://stackoverflow.com/questions/52012535/pipe-variable-from-a-bash-file-into-a-jq-command-in-another-bash-file",
        "title": "Pipe variable from a Bash file into a JQ command in another Bash file"
    },
    {
        "tags": [
            "python",
            "json",
            "csv",
            "parsing",
            "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": 0,
                "creation_date": 1535154515,
                "post_id": 52012899,
                "comment_id": 90976658,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1535155942,
                "creation_date": 1535155942,
                "answer_id": 52013038,
                "question_id": 52012899,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use the `@csv` format to produce CSV output from an array of the values.\r\n\r\n    cat test.json | jq -r &#39;.[] | [.host, .ip] | @csv&#39;\r\n\r\nThe `-r` option is needed to get raw output rather than JSON, which would wrap an extra set of quotes around the result and escape the quotes that surround each field.",
                "title": "how to refine jq output"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1535156848,
                "creation_date": 1535156848,
                "answer_id": 52013107,
                "question_id": 52012899,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To remove quotes:\r\n\r\n    $ cat test.json | jq -r &#39;.[] | [ .host, .ip ] | @csv&#39; | sed &#39;s/&quot;//g&#39;\r\n    a.com,1.2.2.3\r\n    b.com,2.5.0.4\r\n    c.com,9.17.6.7\r\n\r\nIf using OS X, use Homebrew to install GNU `sed`.",
                "title": "how to refine jq output"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1535159600,
        "creation_date": 1535154158,
        "last_edit_date": 1535159600,
        "question_id": 52012899,
        "body_markdown": "I have a json file. A simple example looks like:\r\n\r\n    [\r\n    {\r\n      &quot;host&quot;: &quot;a.com&quot;,\r\n      &quot;ip&quot;: &quot;1.2.2.3&quot;,\r\n      &quot;port&quot;: 8,\r\n      &quot;name&quot;:&quot;xyz&quot;\r\n    },\r\n    {\r\n      &quot;host&quot;: &quot;b.com&quot;,\r\n      &quot;ip&quot;: &quot;2.5.0.4&quot;,\r\n      &quot;port&quot;: 3,\r\n      &quot;name&quot;:&quot;xyz&quot;\r\n    \r\n    },\r\n    {\r\n      &quot;host&quot;: &quot;c.com&quot;,\r\n      &quot;ip&quot;: &quot;9.17.6.7&quot;,\r\n      &quot;port&quot;: 4,\r\n      &quot;name&quot;:&quot;xyz&quot;\r\n    }\r\n    ]\r\n\r\nI want to extract the &quot;host&quot; and &quot;ip&quot; value and add them in a comma separated values file. Each record in a line as follows: \r\n\r\n    a.com,1.2.2.3\r\n    b.com,2.5.0.4\r\n    c.com,9.17.6.7\r\n\r\n I installed jq library to parse the json file. I executed this command:\r\n\r\n    cat test.json | jq &#39;.[] | {host: .host, ip: .ip}&#39;\r\n\r\nThe output I get is as the following:\r\n\r\n    {\r\n      &quot;host&quot;: &quot;a.com&quot;,\r\n      &quot;ip&quot;: &quot;1.2.2.3&quot;\r\n    }\r\n    {\r\n      &quot;host&quot;: &quot;b.com&quot;,\r\n      &quot;ip&quot;: &quot;2.5.0.4&quot;\r\n    }\r\n    {\r\n      &quot;host&quot;: &quot;c.com&quot;,\r\n      &quot;ip&quot;: &quot;9.17.6.7&quot;\r\n    }\r\n\r\nIs there any way I can extract the output as I want? This output that jq produced require additional script to parse it and save the values as I want in csv format, one item in a line.\r\n\r\n",
        "link": "https://stackoverflow.com/questions/52012899/how-to-refine-jq-output",
        "title": "how to refine jq output"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1536766173,
                "last_edit_date": 1536766173,
                "creation_date": 1535191391,
                "answer_id": 52016144,
                "question_id": 52015757,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I think `info` value is seperated by four-spaces, not by tabs because raw tab character is not allowed in JSON and jq raises an error when there is an invalid character in input. If I&#39;m not wrong, this command should do what you want\r\n\r\n&lt;!-- language: lang-bash --&gt;\r\n\r\n    jq -r &#39;.[] | (.info | split(&quot;    &quot;)[0:2] | join(&quot;,&quot;)) as $info | &quot;\\(.host),\\(.ip),\\($info)&quot;&#39; input.json &gt; result.txt",
                "title": "jq dividing a single string value into two"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1624679798,
        "creation_date": 1535188605,
        "last_edit_date": 1624679798,
        "question_id": 52015757,
        "body_markdown": "    [\r\n    {\r\n      &quot;host&quot;: &quot;a.com&quot;,\r\n      &quot;ip&quot;: &quot;1.2.2.3&quot;,\r\n      &quot;port&quot;: 8,\r\n      &quot;name&quot;:&quot;xyz&quot;, \r\n      &quot;info&quot;:&quot;part1    part2    part3    part4&quot;\r\n    },\r\n    {\r\n      &quot;host&quot;: &quot;b.com&quot;,\r\n      &quot;ip&quot;: &quot;2.5.0.4&quot;,\r\n      &quot;port&quot;: 3,\r\n      &quot;name&quot;:&quot;xyz&quot;,\r\n      &quot;info&quot;:&quot;part1    part2    part3    part4&quot;\r\n    },\r\n    {\r\n      &quot;host&quot;: &quot;c.com&quot;,\r\n      &quot;ip&quot;: &quot;9.17.6.7&quot;,\r\n      &quot;port&quot;: 4,\r\n      &quot;name&quot;:&quot;xyz&quot;,\r\n       &quot;info&quot;:&quot;part1    part2    part3    part4&quot;\r\n    }\r\n    ]\r\n\r\nI want to produce output in the following format:\r\n\r\n    a.com,1.2.2.3,part1,part\r\n    b.com,2.5.0.4,part1,par2\r\n    c.com,9.17.6.7,part1,part2\r\n\r\nThe problem is the key `&quot;info`&quot; is a single key, but I want to divide two pieces of information separated by tab separately. How to do this?\r\n\r\nThis is my jq command to parse the file:\r\n\r\n    cat input.json | jq -r &#39;.[] | &quot;\\(.host),\\(.ip),\\(.info)&quot;&#39; &gt; result.txt",
        "link": "https://stackoverflow.com/questions/52015757/jq-dividing-a-single-string-value-into-two",
        "title": "jq dividing a single string value into two"
    },
    {
        "tags": [
            "json",
            "csv",
            "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": 1535217983,
                "post_id": 52016697,
                "comment_id": 90989603,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 10264881,
                    "reputation": 5,
                    "user_id": 7575152,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d59aa3cb16660c2f8d16892bbea90a8a?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "user7575152",
                    "link": "https://stackoverflow.com/users/7575152/user7575152"
                },
                "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": 1535231851,
                "post_id": 52016697,
                "comment_id": 90992984,
                "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": 1535260348,
                "post_id": 52016697,
                "comment_id": 90997064,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1535268056,
                "last_edit_date": 1535268056,
                "creation_date": 1535264364,
                "answer_id": 52023703,
                "question_id": 52016697,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Perhaps this can get you started.\r\n\r\nUse a programming language like Python to convert the CSV data into a dictionary data structure by splitting on the commas, and use the JSON library to dump your dictionary out as JSON.\r\n\r\nI have assumed that actually you expect to have more than one room per floor and thus I took the liberty to adjust your input data a little.\r\n\r\n    import json\r\n      \r\n    csv = &quot;&quot;&quot;floor1,room1,note1,note2,note3\r\n    floor1,room2,2people\r\n    floor1,room3,3people\r\n    floor2,room4,6people,projector\r\n    floor2,room5,3people,projector\r\n    floor3,room6,1person\r\n    &quot;&quot;&quot;\r\n    \r\n    response = {}\r\n    \r\n    for line in csv.splitlines():\r\n        fields = line.split(&quot;,&quot;)\r\n        floor, room, data = fields[0], fields[1], fields[2:]\r\n        if floor not in response:\r\n            response[floor] = {}\r\n        response[floor][room] = data\r\n    \r\n    print json.dumps(response)\r\n\r\nIf you then run that script and pipe it into `jq` (where JQ is just used for pretty-printing the output on your screen ; it is not really required) you will see:\r\n\r\n&lt;!-- language: json --&gt;\r\n    \r\n    $ python test.py | jq . \r\n    {\r\n      &quot;floor1&quot;: {\r\n        &quot;room2&quot;: [\r\n          &quot;2people&quot;\r\n        ],\r\n        &quot;room3&quot;: [\r\n          &quot;3people&quot;\r\n        ],\r\n        &quot;room1&quot;: [\r\n          &quot;note1&quot;,\r\n          &quot;note2&quot;,\r\n          &quot;note3&quot;\r\n        ]\r\n      },\r\n      &quot;floor2&quot;: {\r\n        &quot;room4&quot;: [\r\n          &quot;6people&quot;,\r\n          &quot;projector&quot;\r\n        ],\r\n        &quot;room5&quot;: [\r\n          &quot;3people&quot;,\r\n          &quot;projector&quot;\r\n        ]\r\n      },\r\n      &quot;floor3&quot;: {\r\n        &quot;room6&quot;: [\r\n          &quot;1person&quot;\r\n        ]\r\n      }\r\n    }\r\n\r\n\r\n",
                "title": "Convert data from CSV to JSON with grouping"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1535268056,
        "creation_date": 1535195297,
        "question_id": 52016697,
        "body_markdown": "Example csv data (top row is column header followed by three data lines);\r\n\r\n    floor,room,note1,note2,note3\r\n    floor1,room1,2people\r\n    floor2,room4,6people,projector\r\n    floor6,room5,20people,projector,phone\r\n\r\n\r\nI need the output in json, but grouped by floor, like this;\r\n\r\n    floor\r\n\t    room\r\n\t    note1\r\n\t    note2\r\n\t    note3\r\n\t\r\n\t    room\r\n\t    note1\r\n\t    note2\r\n\t    note3\r\n\t\r\n    floor\r\n\t    room\r\n\t    note1\r\n\t    note2\r\n\t    note3\r\n\t\r\n\t    room\r\n        note1\r\n\t    note2\r\n\t    note3\r\n\r\nSo all floor1 rooms are in their own json grouping, then floor2 rooms etc.\r\n\r\nPlease could someone point me in the right direction in terms of which tools to look at and any specific functions e.g. jq + categories.  I&#39;ve done some searching already and got muddled up between lots of different posts relating to csvtojson, jq and some python scripts.  Ideally I would like to include the solution in a shell script rather than a separate program/language (I have sys admin experience but not a programmer).\r\n\r\nMany thanks",
        "link": "https://stackoverflow.com/questions/52016697/convert-data-from-csv-to-json-with-grouping",
        "title": "Convert data from CSV to JSON with grouping"
    },
    {
        "tags": [
            "json",
            "bash",
            "chef-infra",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1535261764,
                "creation_date": 1535261764,
                "answer_id": 52023484,
                "question_id": 52020292,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The `props` key is nested under `normal` so you would need `.normal.props` or similar.",
                "title": "I am trying to update the output of sudo knife node edit fqdn -c /etc/chef/client.rb using bash script"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1535261764,
        "creation_date": 1535222984,
        "last_edit_date": 1535259912,
        "question_id": 52020292,
        "body_markdown": "Here is the command that I run:\r\n`sudo knife node edit  fqdn -c /etc/chef/client.rb .` --&gt; hit enter button then shows below output :\r\n\r\n\r\n    {\r\n    &quot;name&quot;: &quot;test&quot;,\r\n    &quot;chef_environment&quot;: &quot;standard_chef_environment&quot;,\r\n    &quot;normal&quot;: {\r\n      &quot;httpd&quot;: {\r\n      &quot;fips_mode_enable&quot;: &quot;false&quot;\r\n       },\r\n    &quot;enable_fips_mode&quot;: false,\r\n      &quot;props&quot;: {\r\n       \r\n\r\nSo i wanted to add few line under *props* using following command but its getting failed :\r\n\r\n\r\n`sudo knife node edit  fqdn -c /etc/chef/client.rb |jq ‘.props |= . + { &quot;ParameterKey&quot;: &quot;Foo4&quot;, &quot;ParameterValue&quot;: &quot;Bar4&quot; }&#39; `\r\n",
        "link": "https://stackoverflow.com/questions/52020292/i-am-trying-to-update-the-output-of-sudo-knife-node-edit-fqdn-c-etc-chef-clien",
        "title": "I am trying to update the output of sudo knife node edit fqdn -c /etc/chef/client.rb using bash script"
    },
    {
        "tags": [
            "string",
            "type-conversion",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1535306653,
                "creation_date": 1535306653,
                "answer_id": 52028968,
                "question_id": 52024621,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "    $ cat q6.jq \r\n    { &quot;b&quot;: \r\n       [(\r\n         { &quot;a&quot;: (split(&quot;&quot;)) }\r\n         | .a[] \r\n         | gsub (&quot;a&quot;; &quot;10&quot;; &quot;i&quot;) | gsub (&quot;b&quot;; &quot;11&quot;; &quot;i&quot;) | gsub (&quot;c&quot;; &quot;12&quot;; &quot;i&quot;) | gsub (&quot;d&quot;; &quot;13&quot;; &quot;i&quot;) | gsub (&quot;e&quot;; &quot;14&quot;; &quot;i&quot;) | gsub (&quot;f&quot;; &quot;15&quot;; &quot;i&quot;)\r\n        )\r\n       ]\r\n    } \r\n    | { &quot;a&quot;: [ .b as $m | range(0; $m | length; 2) | { &quot;q&quot; : [ ($m[.]|tonumber),  ($m[(. + 1)]|tonumber) ] } ] } |\r\n    [ (.a[].q) as $b | (($b[0]) * 16) as $d | ($b[1]) as $e | ($d+$e) ] | implode\r\n\r\n    $ echo &#39;&quot;4162634b6c6d&quot;&#39; | jq -f q6.jq\r\n    &quot;AbcKlm&quot;\r\n    $\r\n\r\nYes, I know, it&#39;s ugly, twice the size of the bash function and it works. If you can improve: please show us.\r\n",
                "title": "JQ hex string conversion to ASCII"
            },
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1535454094,
                "last_edit_date": 1535454094,
                "creation_date": 1535346866,
                "answer_id": 52032894,
                "question_id": 52024621,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could use a function like this:\r\n\r\n    def decode_hex:\r\n        (&quot;0123456789abcdef&quot;|split(&quot;&quot;)|with_entries({key:.value, value:.key})) as $hex_map |\r\n        def decode_nybble: $hex_map[ascii_downcase];\r\n        def decode_byte: (.[0:1]|decode_nybble * 16) + (.[1:2]|decode_nybble);\r\n        def pairs: range(0;length;2) as $i | .[$i:$i+2];\r\n        [pairs|decode_byte] | implode;\r\n\r\nThen to use it, strip out any non-hex characters and pass the string in.\r\n\r\n    .[2:] | decode_hex\r\n\r\nInteresting side notes, strings are handled very differently compared to arrays to my surprise. You cannot index into them directly or perform other similar array-like operations on them. You can see how awkward it can be by looking at how `$hex_map` and `decode_byte` was defined above.",
                "title": "JQ hex string conversion to ASCII"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1536765456,
                "last_edit_date": 1536765456,
                "creation_date": 1536765110,
                "answer_id": 52298427,
                "question_id": 52024621,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If an efficient solution is needed, then piggy-backing off @JeffMercado&#39;s answer:\r\n\r\n    def decode_hex:\r\n      def decode: if . &lt; 58 then .-48 elif . &lt; 91 then .-55 else .-87 end;\r\n      def decode_byte: map(decode) | (.[0] * 16) + .[1];\r\n      def pairs: explode | range(0;length;2) as $i | [.[$i], .[$i+1]];\r\n      [pairs|decode_byte] | implode;\r\n\r\n\r\n",
                "title": "JQ hex string conversion to ASCII"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1665043787,
                "creation_date": 1665043787,
                "answer_id": 73970522,
                "question_id": 52024621,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Further extending @peak&#39;s answer and adding @stackprotector suggestion to filter out non-printable characters:\r\n\r\n    def decode_hex:\r\n      def decode: if . &lt; 58 then .-48 elif . &lt; 91 then .-55 else .-87 end;\r\n      def decode_byte: map(decode) | (.[0] * 16) + .[1];\r\n      def pairs: explode | range(0;length;2) as $i | [.[$i], .[$i+1]];\r\n      def filter: if (. &lt; 32 or (. &gt;= 128 and . &lt;= 159)) then 46 else . end;\r\n      [pairs|decode_byte|filter] | implode;",
                "title": "JQ hex string conversion to ASCII"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1702904463,
                "creation_date": 1702904463,
                "answer_id": 77679262,
                "question_id": 52024621,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use this filter to convert input hex string to number:\r\n\r\n    reduce explode[] as $n (0; . * 16 + ($n - 48) % 39)\r\n\r\n---\r\n\r\n    $ echo ff | jq -R &#39;reduce explode[] as $n (0; . * 16 + ($n - 48) % 39)&#39;\r\n    255\r\n",
                "title": "JQ hex string conversion to ASCII"
            }
        ],
        "is_answered": true,
        "answer_count": 5,
        "score": 2,
        "last_activity_date": 1702904463,
        "creation_date": 1535272932,
        "last_edit_date": 1535276865,
        "question_id": 52024621,
        "body_markdown": "I end up in jq with a hex string that I want to convert to ASCII, within jq. Doing it outside would involve passing multiple conditions too, which over complicates matters and would really slow down the solution.\r\n\r\nTo be clear: it concerns a string translation like:\r\n\r\n    &quot;0x4162634b6c6d&quot; -&gt; &quot;AbcKlm&quot;\r\n\r\nstripping of the &quot;0x&quot; is easy ( .[2:] ) and I got the equivalent in a bash function:\r\n\r\n    function h2a () \r\n    { \r\n        while read s; do\r\n            n=0;\r\n            while [[ &quot;$n&quot; -lt ${#s} ]]; do\r\n                h=&quot;${s:$n:2}&quot;;\r\n                printf &quot;\\x$h&quot;;\r\n                n=&quot;$(($n+2))&quot;;\r\n            done;\r\n        done\r\n    }\r\n\r\nbut I would really want to do this in native jq. I found [Rosetta JQ][1], but am unable to convert.\r\n\r\nThanks for the help!\r\n\r\nEdit: making progress, found [how to access substrings][2]\r\nNow, how do I convert and iterate? \r\n\r\n\r\n  [1]: https://rosettacode.org/wiki/Category:Jq\r\n  [2]: https://github.com/stedolan/jq/issues/1520",
        "link": "https://stackoverflow.com/questions/52024621/jq-hex-string-conversion-to-ascii",
        "title": "JQ hex string conversion to ASCII"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 5940172,
                    "reputation": 3884,
                    "user_id": 4671717,
                    "user_type": "registered",
                    "accept_rate": 25,
                    "profile_image": "https://i.sstatic.net/oyNTO.jpg?s=256",
                    "display_name": "Chris Maggiulli",
                    "link": "https://stackoverflow.com/users/4671717/chris-maggiulli"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1535297458,
                "post_id": 52027546,
                "comment_id": 91005589,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3545296,
                    "reputation": 319,
                    "user_id": 2961418,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/421962ee2ebace418252201c54b85825?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Maurice1408",
                    "link": "https://stackoverflow.com/users/2961418/maurice1408"
                },
                "reply_to_user": {
                    "account_id": 5940172,
                    "reputation": 3884,
                    "user_id": 4671717,
                    "user_type": "registered",
                    "accept_rate": 25,
                    "profile_image": "https://i.sstatic.net/oyNTO.jpg?s=256",
                    "display_name": "Chris Maggiulli",
                    "link": "https://stackoverflow.com/users/4671717/chris-maggiulli"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1535300179,
                "post_id": 52027546,
                "comment_id": 91006414,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1535314536,
                "creation_date": 1535314536,
                "answer_id": 52029922,
                "question_id": 52027546,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This gets the desired output.\r\n\r\n    jq &#39;.members |= map(select(.ln == &quot;smith&quot;))&#39;\r\n\r\nIt updates .members, selecting only objects with .ln == smith",
                "title": "Selecting entries of a sub array"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1535314536,
        "creation_date": 1535296219,
        "question_id": 52027546,
        "body_markdown": "I have json that looks like:\r\n\r\n    {\r\n      &quot;base&quot;: &quot;abc&quot;,\r\n      &quot;members&quot; : [\r\n                {&quot;fn&quot;: &quot;maurice&quot;, &quot;ln&quot;: &quot;hickey&quot;},\r\n                {&quot;fn&quot;: &quot;john&quot;, &quot;ln&quot;: &quot;smith&quot;},\r\n                {&quot;fn&quot;: &quot;robin&quot;, &quot;ln&quot;: &quot;smith&quot;},\r\n                ...\r\n              ],\r\n      &quot;date&quot;: &quot;2018-08-26&quot;\r\n    }\r\n\r\nI am trying to write a jq filter to give me the same schema output but with only a subset of the members array e.g. all the &quot;smith&quot;s\r\n\r\n    {\r\n      &quot;base&quot;: &quot;abc&quot;,\r\n      &quot;members&quot; : [\r\n                {&quot;fn&quot;: &quot;john&quot;, &quot;ln&quot;: &quot;smith&quot;},\r\n                {&quot;fn&quot;: &quot;robin&quot;, &quot;ln&quot;: &quot;smith&quot;}\r\n              ],\r\n      &quot;date&quot;: &quot;2018-08-26&quot;\r\n    }\r\n\r\nAny pointers would be appreciated.\r\n",
        "link": "https://stackoverflow.com/questions/52027546/selecting-entries-of-a-sub-array",
        "title": "Selecting entries of a sub array"
    },
    {
        "tags": [
            "amazon-web-services",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1535347907,
                "creation_date": 1535347907,
                "answer_id": 52033046,
                "question_id": 52028615,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use this for your jq filter:\r\n\r\n    [.Tags[] | select(.Key | contains(&quot;:aws:&quot;) | not) | &quot;Key=\\(.Key),Value=\\(.Value)&quot;] | join(&quot; &quot;)",
                "title": "Print keyvalue on single line for all elements in an array"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1535347907,
        "creation_date": 1535304067,
        "question_id": 52028615,
        "body_markdown": "I&#39;m trying to get the list of tags from an EC2 instance, and apply those tags to all the attached volumes of that instance, like so:\r\n    \r\n    # Get the tags of the instance (filter out tags containing :aws:, since those are tags that AWS applies and they are NOT ours):\r\n    aws ec2 describe-tags --filters &quot;Name=resource-id,Values=${instance_id}&quot; --region us-west-2 | jq &#39;[ .Tags[] | select( .Key | contains(&quot;:aws:&quot;) | not ) ]&#39;\r\n\r\n    # That command produces this output:\r\n    [\r\n      {\r\n        &quot;ResourceType&quot;: &quot;instance&quot;,\r\n        &quot;ResourceId&quot;: &quot;i-0f1da295d8343635b&quot;,\r\n        &quot;Value&quot;: &quot;tester&quot;,\r\n        &quot;Key&quot;: &quot;Name&quot;\r\n      },\r\n      {\r\n        &quot;ResourceType&quot;: &quot;instance&quot;,\r\n        &quot;ResourceId&quot;: &quot;i-0f1da295d8343635b&quot;,\r\n        &quot;Value&quot;: &quot;test_env&quot;,\r\n        &quot;Key&quot;: &quot;environment&quot;\r\n      },\r\n      {\r\n        &quot;ResourceType&quot;: &quot;instance&quot;,\r\n        &quot;ResourceId&quot;: &quot;i-0f1da295d8343635b&quot;,\r\n        &quot;Value&quot;: &quot;ui_tester&quot;,\r\n        &quot;Key&quot;: &quot;role&quot;\r\n      }\r\n    ]\r\n\r\nUnfortunately, the create-tags api command takes a form of:\r\n    \r\n    aws ec2 create-tags --resources vol-076317f0fd49cb024 vol-0e91c84611369fc3f \\\r\n     --tags Key=role,Value=ui_tester Key=environment,Value=test_env Key=Name,Value=tester\r\n\r\nHow do I use jq to convert that array of Key/Values into a single line like so:\r\n    \r\n    Key=role,Value=ui_tester Key=environment,Value=test_env Key=Name,Value=tester",
        "link": "https://stackoverflow.com/questions/52028615/print-keyvalue-on-single-line-for-all-elements-in-an-array",
        "title": "Print keyvalue on single line for all elements in an array"
    },
    {
        "tags": [
            "arrays",
            "json",
            "jq",
            "aws-cli"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 57200,
                    "reputation": 158728,
                    "user_id": 171318,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/ePRKy.jpg?s=256",
                    "display_name": "hek2mgl",
                    "link": "https://stackoverflow.com/users/171318/hek2mgl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1535379778,
                "post_id": 52041260,
                "comment_id": 91033477,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5466887,
                    "reputation": 803,
                    "user_id": 4347446,
                    "user_type": "registered",
                    "accept_rate": 56,
                    "profile_image": "https://www.gravatar.com/avatar/fd9e1aefddc0caac430f00ff67757743?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "TyMac",
                    "link": "https://stackoverflow.com/users/4347446/tymac"
                },
                "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": 1535379905,
                "post_id": 52041260,
                "comment_id": 91033555,
                "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": 1535382412,
                "post_id": 52041260,
                "comment_id": 91035084,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5466887,
                    "reputation": 803,
                    "user_id": 4347446,
                    "user_type": "registered",
                    "accept_rate": 56,
                    "profile_image": "https://www.gravatar.com/avatar/fd9e1aefddc0caac430f00ff67757743?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "TyMac",
                    "link": "https://stackoverflow.com/users/4347446/tymac"
                },
                "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": 1535382616,
                "post_id": 52041260,
                "comment_id": 91035215,
                "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": 1535382702,
                "post_id": 52041260,
                "comment_id": 91035275,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1535379716,
                "last_edit_date": 1535379716,
                "creation_date": 1535379436,
                "answer_id": 52041336,
                "question_id": 52041260,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The value of the `&quot;Command&quot;` key is not a list; it&#39;s simply another object that has `CommandID` as a key. You just want\r\n\r\n    ... | jq -r &#39;.Command.CommandID&#39;\r\n\r\nThe filter `.Command[]` returns the sequence of *values* of the object, so the error you are getting results from the attempt to evaluate something like `&quot;7312718d-2327-43g4-bffc-093a0901a13c&quot;.Command`, not `{&quot;Command: ...}.Command`.",
                "title": "How can I use jq to parse this string?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1535379644,
                "creation_date": 1535379644,
                "answer_id": 52041394,
                "question_id": 52041260,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Seems that in your JSON Command is not an array object.\r\n\r\nIf you require the value of CommandId change your jq to &#39;jq .Command.CommandId&#39;",
                "title": "How can I use jq to parse this string?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1535379716,
        "creation_date": 1535379193,
        "question_id": 52041260,
        "body_markdown": "The CommandID string is not behaving as I would expect when I try to extract with jq:\r\n\r\n\r\n    aws ssm send-command --document-name &quot;AWS-RunPatchBaseline&quot; --instance-ids i-xxxxxxxxxxxx --max-errors &quot;1&quot; --parameters &#39;{&quot;Operation&quot;:[&quot;Install&quot;]}&#39; --timeout-seconds 600 --output-s3-bucket-name &quot;ssm&quot; --region &quot;us-east-1&quot; | jq\r\n\r\nNon selected output:\r\n\r\n        {\r\n      &quot;Command&quot;: {\r\n        &quot;CommandId&quot;: &quot;7312718d-2327-43g4-bffc-093a0901a13c&quot;,\r\n        &quot;DocumentName&quot;: &quot;AWS-RunPatchBaseline&quot;,\r\n        &quot;Comment&quot;: &quot;&quot;,\r\n        &quot;ExpiresAfter&quot;: 1535382731.286,\r\n        &quot;Parameters&quot;: {\r\n          &quot;Operation&quot;: [\r\n            &quot;Install&quot;\r\n          ]\r\n        },\r\n        &quot;InstanceIds&quot;: [\r\n          &quot;i-xxxxxxxxx&quot;\r\n        ],\r\n        &quot;Targets&quot;: [],\r\n        &quot;RequestedDateTime&quot;: 1535378531.286,\r\n        &quot;Status&quot;: &quot;Pending&quot;,\r\n         &quot;StatusDetails&quot;: &quot;Pending&quot;,\r\n        &quot;OutputS3BucketName&quot;: &quot;ssm&quot;,\r\n        &quot;OutputS3KeyPrefix&quot;: &quot;&quot;,\r\n        &quot;MaxConcurrency&quot;: &quot;50&quot;,\r\n        &quot;MaxErrors&quot;: &quot;1&quot;,\r\n         &quot;TargetCount&quot;: 1,\r\n        &quot;CompletedCount&quot;: 0,\r\n        &quot;ErrorCount&quot;: 0,\r\n        &quot;ServiceRole&quot;: &quot;&quot;,\r\n        &quot;NotificationConfig&quot;: {\r\n          &quot;NotificationArn&quot;: &quot;&quot;,\r\n          &quot;NotificationEvents&quot;: [],\r\n          &quot;NotificationType&quot;: &quot;&quot;\r\n        }\r\n      }\r\n    }\r\n\r\nI would have thought I could use this command to get the CommandID string:\r\n\r\n    aws ssm send-command --document-name &quot;AWS-RunPatchBaseline&quot; --instance-ids i-xxxxxxxxxxxxxx --max-errors &quot;1&quot; --parameters &#39;{&quot;Operation&quot;:[&quot;Install&quot;]}&#39; --timeout-seconds 600 --output-s3-bucket-name &quot;ssm&quot; --region &quot;us-east-1&quot; | jq -r &#39;.Command[].CommandID&#39;\r\n\r\nBut that gives me this error:\r\n\r\n     jq: error (at &lt;stdin&gt;:33): Cannot index string with string &quot;CommandID&quot;\r\n\r\nAny ideas on how to extract that?",
        "link": "https://stackoverflow.com/questions/52041260/how-can-i-use-jq-to-parse-this-string",
        "title": "How can I use jq to parse this string?"
    },
    {
        "tags": [
            "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": 1535488342,
                "post_id": 52065570,
                "comment_id": 91082047,
                "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"
                },
                "reply_to_user": {
                    "account_id": 4879,
                    "reputation": 248190,
                    "user_id": 7552,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/b60298053f87465641c1b1192338c8cd?s=256&d=identicon&r=PG",
                    "display_name": "glenn jackman",
                    "link": "https://stackoverflow.com/users/7552/glenn-jackman"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1535491264,
                "post_id": 52065570,
                "comment_id": 91083096,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4879,
                    "reputation": 248190,
                    "user_id": 7552,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/b60298053f87465641c1b1192338c8cd?s=256&d=identicon&r=PG",
                    "display_name": "glenn jackman",
                    "link": "https://stackoverflow.com/users/7552/glenn-jackman"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1535493457,
                "post_id": 52065570,
                "comment_id": 91083818,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": -2,
                "last_activity_date": 1535487740,
                "creation_date": 1535487740,
                "answer_id": 52065683,
                "question_id": 52065570,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use a `for` loop.\r\n\r\n    total=0\r\n    for num in $(hadoop fs -ls -R /reports/dt=2018-08-27 | grep _stats.json | awk &#39;{print $NF}&#39; | xargs hadoop fs -cat | jq &#39;.duration&#39;)\r\n    do\r\n        ((total += num))\r\n    done\r\n    echo $total\r\n\r\n",
                "title": "How do I sum all numbers from output of jq"
            },
            {
                "up_vote_count": 24,
                "is_accepted": true,
                "score": 24,
                "last_activity_date": 1535488022,
                "creation_date": 1535488022,
                "answer_id": 52065738,
                "question_id": 52065570,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Another option (and one that works even if not all your durations are integers) is to make your `jq` code do the work:\r\n\r\n    sample_data=&#39;{&quot;duration&quot;: 1211789}\r\n    {&quot;duration&quot;: 1211789}\r\n    {&quot;duration&quot;: 373585}\r\n    {&quot;duration&quot;: 495379}\r\n    {&quot;duration&quot;: 1211789}&#39;\r\n\r\n    jq -n &#39;[inputs | .duration] | reduce .[] as $num (0; .+$num)&#39; &lt;&lt;&lt;&quot;$sample_data&quot;\r\n\r\n...properly emits as output:\r\n\r\n    4504331\r\n\r\nReplace the `&lt;&lt;&lt;&quot;$sample_data&quot;` with a pipeline on stdin as desired.",
                "title": "How do I sum all numbers from output of jq"
            },
            {
                "up_vote_count": 19,
                "is_accepted": false,
                "score": 18,
                "last_activity_date": 1535488469,
                "last_edit_date": 1535488469,
                "creation_date": 1535488262,
                "answer_id": 52065784,
                "question_id": 52065570,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`awk` to the rescue!\r\n\r\n    $ ... | awk &#39;{sum+=$0} END{print sum}&#39;\r\n\r\n    4504331\r\n\r\n",
                "title": "How do I sum all numbers from output of jq"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1535576120,
                "last_edit_date": 1535576120,
                "creation_date": 1535507588,
                "answer_id": 52068435,
                "question_id": 52065570,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "For clarity and generality, it might be worthwhile defining `sigma(s)` to add a stream of numbers:\r\n\r\n    ... | jq -n &#39;\r\n      def sigma(s): reduce s as $x(0;.+$x); \r\n      sigma(inputs | .duration)&#39;\r\n\r\n",
                "title": "How do I sum all numbers from output of jq"
            },
            {
                "up_vote_count": 15,
                "is_accepted": false,
                "score": 14,
                "last_activity_date": 1570181556,
                "creation_date": 1570181556,
                "answer_id": 58233650,
                "question_id": 52065570,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can just use `add` now.\r\n\r\n    jq &#39;.duration | add&#39;\r\n\r\n",
                "title": "How do I sum all numbers from output of jq"
            },
            {
                "up_vote_count": 66,
                "is_accepted": false,
                "score": 66,
                "last_activity_date": 1656688488,
                "last_edit_date": 1656688488,
                "creation_date": 1584698174,
                "answer_id": 60771918,
                "question_id": 52065570,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "the simplest solution is the `add` filter:\r\n\r\n    jq &#39;[.duration] | add&#39;\r\n\r\nthe `[` brackets `]` are needed around the value to sum because `add` sums the values of an _array_, not a stream. (for stream summation, you would need a more sophisticated solution, e.g. using `reduce`, as detailed in other answers.)\r\n\r\n----\r\n\r\ndepending on the exact format of the input, you may need some preprocessing to get this right.\r\n\r\n e.g. for the sample input in [Charles Duffy’s answer](https://stackoverflow.com/a/52065738/501765) either\r\n* use `inputs`  (note that `-n` is needed to avoid jq swallowing the first line of input): \r\n\r\n      jq -n &#39;[inputs.duration] | add&#39; &lt;&lt;&lt; &quot;$sample_data&quot;\r\n\r\n* or slurp (`-s`) and iterate (`.[]`) / map:\r\n\r\n      jq -s &#39;[.[].duration] | add&#39; &lt;&lt;&lt; &quot;$sample_data&quot;\r\n      jq -s &#39;map(.duration) | add&#39; &lt;&lt;&lt; &quot;$sample_data&quot;",
                "title": "How do I sum all numbers from output of jq"
            },
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1603512753,
                "creation_date": 1603512753,
                "answer_id": 64509897,
                "question_id": 52065570,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "From a combination of other answers.\r\n\r\n```bash\r\n$ jq -n &#39;[inputs | .duration] | add&#39; &lt;&lt;&lt; &quot;$sample_data&quot;\r\n\r\n# 4504331\r\n```\r\n\r\nI had to format the values in an array `[inputs | .duration]` before summing values with `add`.\r\n\r\n",
                "title": "How do I sum all numbers from output of jq"
            }
        ],
        "is_answered": true,
        "answer_count": 7,
        "score": 39,
        "last_activity_date": 1656688488,
        "creation_date": 1535487241,
        "last_edit_date": 1535493428,
        "question_id": 52065570,
        "body_markdown": "I have this command that I would like to sum all the numbers from the output. \r\n\r\nThe command looks like this\r\n\r\n    $(hadoop fs -ls -R /reports/dt=2018-08-27 | grep _stats.json | awk &#39;{print $NF}&#39; | xargs hadoop fs -cat | jq &#39;.duration&#39;)\r\n\r\nSo it&#39;s going to list all the folders in `/reports/dt=2018-08-27` and get only `_stats.json` and pass that through `jq` from `hadoop -cat` and get only `.duration` from the json. Which in the end I get the result like this.\r\n\r\n    1211789 1211789 373585 495379 1211789\r\n\r\nBut I would like the command to sum all those numbers together to become `4504331`",
        "link": "https://stackoverflow.com/questions/52065570/how-do-i-sum-all-numbers-from-output-of-jq",
        "title": "How do I sum all numbers from output of jq"
    },
    {
        "tags": [
            "json",
            "bash",
            "shell",
            "amazon-web-services",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3059801,
                    "reputation": 1404,
                    "user_id": 3443551,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/XfkEC.jpg?s=256",
                    "display_name": "MarkSkayff",
                    "link": "https://stackoverflow.com/users/3443551/markskayff"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1535502225,
                "post_id": 52067816,
                "comment_id": 91085817,
                "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": 0,
                "creation_date": 1535503046,
                "post_id": 52067816,
                "comment_id": 91085972,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 16,
                "is_accepted": true,
                "score": 16,
                "last_activity_date": 1535503721,
                "last_edit_date": 1535503721,
                "creation_date": 1535502906,
                "answer_id": 52067905,
                "question_id": 52067816,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can wrap the entire jq expression into square brackets to make it collect the filter output into an array (documented in [Array construction section](https://stedolan.github.io/jq/manual/#Arrayconstruction:[])):\r\n\r\n    &#39;[ .Snapshots[] | select(.Description | contains(&quot;myorg-database-b&quot;)) ]&#39;\r\n\r\nresults in:\r\n\r\n    [\r\n      {\r\n        &quot;Description&quot;: &quot;myorg-database-b redacted&quot;,\r\n        &quot;Encrypted&quot;: false,\r\n        &quot;VolumeId&quot;: &quot;vol-23456&quot;,\r\n        &quot;State&quot;: &quot;completed&quot;,\r\n        &quot;VolumeSize&quot;: 500,\r\n        &quot;StartTime&quot;: &quot;2018-08-28T19:01:18.000Z&quot;,\r\n        &quot;Progress&quot;: &quot;100%&quot;,\r\n        &quot;OwnerId&quot;: &quot;12345678&quot;,\r\n        &quot;SnapshotId&quot;: &quot;snap-5535&quot;\r\n      },\r\n      {\r\n        &quot;Description&quot;: &quot;myorg-database-b redacted&quot;,\r\n        &quot;Encrypted&quot;: false,\r\n        &quot;VolumeId&quot;: &quot;vol-23456&quot;,\r\n        &quot;State&quot;: &quot;completed&quot;,\r\n        &quot;VolumeSize&quot;: 500,\r\n        &quot;StartTime&quot;: &quot;2018-08-28T19:01:18.000Z&quot;,\r\n        &quot;Progress&quot;: &quot;100%&quot;,\r\n        &quot;OwnerId&quot;: &quot;12345678&quot;,\r\n        &quot;SnapshotId&quot;: &quot;snap-5535&quot;\r\n      }\r\n    ]\r\n",
                "title": "How to get jq to print valid json after applying a filter"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 8,
        "last_activity_date": 1535503721,
        "creation_date": 1535502004,
        "last_edit_date": 1535502428,
        "question_id": 52067816,
        "body_markdown": "I&#39;m working on jq filtering and output of results to output into another program that accepts a JSON payload. Consider the following example:\r\n\r\nINPUT:\r\n\r\n    My-MBP:myorg myname$ aws ec2 describe-snapshots --owner-id 12345678 | jq &#39;.Snapshots[] | select(.Description | contains(&quot;myorg-database-b&quot;))&#39;\r\n\r\nRESULT:\r\n\r\n    {\r\n      &quot;Description&quot;: &quot;myorg-database-b redacted&quot;,\r\n      &quot;Encrypted&quot;: false,\r\n      &quot;VolumeId&quot;: &quot;vol-1234&quot;,\r\n      &quot;State&quot;: &quot;completed&quot;,\r\n      &quot;VolumeSize&quot;: 500,\r\n      &quot;StartTime&quot;: &quot;2018-08-28T17:52:14.000Z&quot;,\r\n      &quot;Progress&quot;: &quot;100%&quot;,\r\n      &quot;OwnerId&quot;: &quot;12345678&quot;,\r\n      &quot;SnapshotId&quot;: &quot;snap-2424&quot;\r\n    }\r\n    {\r\n      &quot;Description&quot;: &quot;myorg-database-b redacted&quot;,\r\n      &quot;Encrypted&quot;: false,\r\n      &quot;VolumeId&quot;: &quot;vol-23456&quot;,\r\n      &quot;State&quot;: &quot;completed&quot;,\r\n      &quot;VolumeSize&quot;: 500,\r\n      &quot;StartTime&quot;: &quot;2018-08-28T19:01:18.000Z&quot;,\r\n      &quot;Progress&quot;: &quot;100%&quot;,\r\n      &quot;OwnerId&quot;: &quot;12345678&quot;,\r\n      &quot;SnapshotId&quot;: &quot;snap-5535&quot;\r\n    }\r\n\r\n\r\nNo matter what I try to do, I can&#39;t get `jq` to print valid JSON so that I can pipe it into another program. \r\n\r\nThe original JSON from AWS was an array of objects, why can&#39;t I get back a valid array of objects? Am I doing something wrong here? \r\n\r\nHere is what the AWS payload looks like before it gets piped into `jq`:\r\n\r\n    {\r\n        &quot;Snapshots&quot;: [\r\n            {\r\n                &quot;Description&quot;: &quot;myorg-database-b redacted&quot;,\r\n                &quot;Encrypted&quot;: false,\r\n                &quot;VolumeId&quot;: &quot;vol-23456&quot;,\r\n                &quot;State&quot;: &quot;completed&quot;,\r\n                &quot;VolumeSize&quot;: 500,\r\n                &quot;StartTime&quot;: &quot;2018-08-28T19:01:18.000Z&quot;,\r\n                &quot;Progress&quot;: &quot;100%&quot;,\r\n                &quot;OwnerId&quot;: &quot;12345678&quot;,\r\n                &quot;SnapshotId&quot;: &quot;snap-5535&quot;\r\n            }, \r\n            {\r\n                &quot;Description&quot;: &quot;myorg-database-b redacted&quot;,\r\n                &quot;Encrypted&quot;: false,\r\n                &quot;VolumeId&quot;: &quot;vol-23456&quot;,\r\n                &quot;State&quot;: &quot;completed&quot;,\r\n                &quot;VolumeSize&quot;: 500,\r\n                &quot;StartTime&quot;: &quot;2018-08-28T19:01:18.000Z&quot;,\r\n                &quot;Progress&quot;: &quot;100%&quot;,\r\n                &quot;OwnerId&quot;: &quot;12345678&quot;,\r\n                &quot;SnapshotId&quot;: &quot;snap-5535&quot;\r\n            }\r\n        ]\r\n    }\r\n\r\n\r\nAny help would be appreciated.",
        "link": "https://stackoverflow.com/questions/52067816/how-to-get-jq-to-print-valid-json-after-applying-a-filter",
        "title": "How to get jq to print valid json after applying a filter"
    },
    {
        "tags": [
            "json",
            "bash",
            "curl",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 203139,
                    "reputation": 2667,
                    "user_id": 450611,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/3b03ea75684fe0dc76bab85cc1fadc2e?s=256&d=identicon&r=PG",
                    "display_name": "weirdan",
                    "link": "https://stackoverflow.com/users/450611/weirdan"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1535589336,
                "post_id": 52087680,
                "comment_id": 91125770,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 10660136,
                    "reputation": 1329,
                    "user_id": 7848350,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/87ad61e783196e7b0cc6236f2397d63b?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "hcdocs",
                    "link": "https://stackoverflow.com/users/7848350/hcdocs"
                },
                "reply_to_user": {
                    "account_id": 203139,
                    "reputation": 2667,
                    "user_id": 450611,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/3b03ea75684fe0dc76bab85cc1fadc2e?s=256&d=identicon&r=PG",
                    "display_name": "weirdan",
                    "link": "https://stackoverflow.com/users/450611/weirdan"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1535591928,
                "post_id": 52087680,
                "comment_id": 91126252,
                "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": 1535592642,
                "post_id": 52087680,
                "comment_id": 91126365,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 203139,
                    "reputation": 2667,
                    "user_id": 450611,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/3b03ea75684fe0dc76bab85cc1fadc2e?s=256&d=identicon&r=PG",
                    "display_name": "weirdan",
                    "link": "https://stackoverflow.com/users/450611/weirdan"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1535595941,
                "post_id": 52087680,
                "comment_id": 91127077,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 203139,
                    "reputation": 2667,
                    "user_id": 450611,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/3b03ea75684fe0dc76bab85cc1fadc2e?s=256&d=identicon&r=PG",
                    "display_name": "weirdan",
                    "link": "https://stackoverflow.com/users/450611/weirdan"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1535596498,
                "post_id": 52087680,
                "comment_id": 91127191,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 9,
                "is_accepted": true,
                "score": 9,
                "last_activity_date": 1535597576,
                "creation_date": 1535597576,
                "answer_id": 52088602,
                "question_id": 52087680,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Assuming my theory about `startIndex` holds water and implementing @CharlesDuffy&#39;s suggestion about `jq`, this becomes\r\n\r\n    for ((i=0; ; i+=100)); do\r\n        contents=$(curl -u &quot;username:password&quot; -H &quot;Content-Type: application/json&quot; &quot;https://&lt;url&gt;/api/core/v3/places?count=100&amp;startIndex=$i&quot;)\r\n        echo &quot;$contents&quot; &gt; $i.json\r\n        if jq -e &#39;.list | length == 0&#39; &gt;/dev/null; then \r\n           break\r\n        fi &lt;&lt;&lt; &quot;$contents&quot;\r\n    done",
                "title": "Detect the final page of a paginated cURL response in a Bash loop"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 7,
        "last_activity_date": 1535597576,
        "creation_date": 1535588547,
        "last_edit_date": 1535592036,
        "question_id": 52087680,
        "body_markdown": "## Goal\r\nInclude all objects from a paginated REST API call in a single JSON file using cURL and Bash. This combined list will be fed into a Power BI report.\r\n\r\n## Details\r\nA request returns a maximum of 100 objects. There are 400+ objects total. The total grows over time. I don&#39;t want to maintain a script that includes something like `for set in 0 100 200 300 400 ; do` because it requires me to manually match the sets to the current number of objects. To save labor, I would like a script to auto-detect when the final page has been processed and then break. \r\n\r\nTo achieve my goal, the plan I have come up with so far is to extract each incremental set of 100 items into its own JSON file, then assemble them with `cat` and extract relevant JSON keys/values using JQ. The reason for Bash is that it is the only programming I know.\r\n\r\n## Attempt\r\n(Based on [this question and answer](https://stackoverflow.com/questions/42866665/bash-scripting-curl-request-with-twist))\r\n\r\n    for ((i=0; ; i+=100)); do\r\n        contents=$(curl -u &quot;username:password&quot; -H &quot;Content-Type: application/json&quot; &quot;https://&lt;url&gt;/api/core/v3/places?count=100&amp;startIndex=$i&quot;)\r\n        echo &quot;$contents&quot; &gt; $i.json\r\n        if [[ $contents =~ &#39;list&quot; : [ ]&#39; ]]\r\n        then break\r\n        fi\r\n    done\r\n\r\n### Result\r\nAll pages export as expected except the first and last pages:\r\n\r\n- The first `startIndex` should be `0` but the code makes the `startIndex` `100`. I have tried a number of variations with `i` but continue to fail.\r\n- [edit: solved, thank you @weirdan] Neither `list&quot;:null` nor `next&quot;:null` end the loop. The script exports incremented JSON files indefinitely.~\r\n\r\n## Reference\r\n### First page of returned paginated JSON\r\n\r\n    {\r\n      &quot;itemsPerPage&quot; : 100,\r\n      &quot;links&quot; : {\r\n        &quot;next&quot; : &quot;https://&lt;url&gt;/api/core/v3/places?sort=titleAsc&amp;count=100&amp;startIndex=0&quot; &lt;--- with my script, startIndex is erroneously 100\r\n      },\r\n      &quot;list&quot; : [ {\r\n    ...\r\n\r\n### Intermediate pages\r\n\r\n    {\r\n      &quot;itemsPerPage&quot; : 100,\r\n      &quot;links&quot; : {\r\n        &quot;previous&quot; : &quot;https://&lt;url&gt;/api/core/v3/places?sort=titleAsc&amp;count=100&quot;,\r\n        &quot;next&quot; : &quot;https://&lt;url&gt;/api/core/v3/places?sort=titleAsc&amp;count=100&amp;startIndex=200&quot;\r\n      },\r\n      &quot;list&quot; : [ {\r\n    ...\r\n\r\n### Final page\r\n\r\n    {\r\n      &quot;itemsPerPage&quot; : 100,\r\n      &quot;links&quot; : {\r\n        &quot;previous&quot; : &quot;https://&lt;url&gt;/api/core/v3/places?sort=titleAsc&amp;count=100&amp;startIndex=400&quot;\r\n      },\r\n      &quot;list&quot; : [ {\r\n    ...\r\n\r\n### Empty page\r\n\r\n    {\r\n      &quot;itemsPerPage&quot; : 100,\r\n      &quot;list&quot; : [ ],\r\n      &quot;startIndex&quot; : 500\r\n    }\r\n\r\n\r\nThank you for any advice or ideas.",
        "link": "https://stackoverflow.com/questions/52087680/detect-the-final-page-of-a-paginated-curl-response-in-a-bash-loop",
        "title": "Detect the final page of a paginated cURL response in a Bash loop"
    },
    {
        "tags": [
            "json",
            "linux",
            "bash",
            "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": 1,
                "creation_date": 1535589192,
                "post_id": 52087737,
                "comment_id": 91125733,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1826277,
                    "reputation": 567,
                    "user_id": 1658988,
                    "user_type": "registered",
                    "accept_rate": 88,
                    "profile_image": "https://www.gravatar.com/avatar/205ebf102d49ca24147918fd50769b22?s=256&d=identicon&r=PG",
                    "display_name": "Ryahn",
                    "link": "https://stackoverflow.com/users/1658988/ryahn"
                },
                "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": 1535589487,
                "post_id": 52087737,
                "comment_id": 91125807,
                "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": 1535589802,
                "post_id": 52087737,
                "comment_id": 91125872,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1535589604,
                "creation_date": 1535589604,
                "answer_id": 52087789,
                "question_id": 52087737,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "@barmar found the simplest solution that I overlooked....\r\n\r\nNeeded to pipe the loop into jq\r\n\r\n    while IFS=&#39;&#39; read -r line || [[ -n &quot;$line&quot; ]]; do\r\n    \tIFS=, read -ra array &lt;&lt;&lt; &quot;$line&quot;\r\n    \tnickname=${array[0]}\r\n    \tuser=${array[1]}\r\n    \tpass=${array[2]}\r\n    \tdata=($(megadf --username=$user --password=$pass))\r\n    \tdata[${#data[@]}]+=&quot;$nickname&quot;\r\n    \tstats=$(join_by $&#39;\\n&#39; ${data[@]})\r\n    \techo $stats\r\n    done &lt; .accounts  | jq --slurp --raw-input &#39;split(&quot;\\n&quot;)[:-1] | map([ split(&quot; &quot;)[] ]) | map({\r\n    \tnick: .[6],\r\n    \ttotal: .[1],\r\n    \tused: .[3],\r\n    \tfree: .[5]\r\n    \t})&#39; &gt;&gt; /opt/stats/json/accounts.json",
                "title": "JQ create json array using bash"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1535589604,
        "creation_date": 1535589034,
        "question_id": 52087737,
        "body_markdown": "I am currently trying to get information about my file hosting accounts. As I keep a lot of my backup media on different accounts. I am using megatools to query information about the account, which I then parse into an array. The array is then flattened using \\n for raw input. \r\n\r\nThe script works wonderfully but its not creating valid json. I am not sure what I am missing to make it valid. Thanks for the help in advance.\r\n\r\nscript\r\n\r\n    function join_by { local IFS=&quot;$1&quot;; shift; echo &quot;$*&quot;; }\r\n    \r\n    while IFS=&#39;&#39; read -r line || [[ -n &quot;$line&quot; ]]; do\r\n    \tIFS=, read -ra array &lt;&lt;&lt; &quot;$line&quot;\r\n\r\n    \tnickname=${array[0]}\r\n    \tuser=${array[1]}\r\n    \tpass=${array[2]}\r\n    \tdata=($(megadf --username=$user --password=$pass))\r\n    \tdata[${#data[@]}]+=&quot;$nickname&quot;\r\n\r\n    \tstats=$(join_by $&#39;\\n&#39; ${data[@]})\r\n\r\n    \techo $stats | jq --slurp --raw-input &#39;split(&quot;\\n&quot;)[:-1] | map([ split(&quot; &quot;)[] ]) | map({\r\n    \tnick: .[6],\r\n    \ttotal: .[1],\r\n    \tused: .[3],\r\n    \tfree: .[5]\r\n    \t})&#39; &gt;&gt; /opt/stats/json/accounts.json\r\n\r\n    done &lt; .accounts\r\n\r\njson output\r\n\r\n    [\r\n      {\r\n        &quot;nick&quot;: &quot;alt&quot;,\r\n        &quot;total&quot;: &quot;53687091200&quot;,\r\n        &quot;used&quot;: &quot;7885201595&quot;,\r\n        &quot;free&quot;: &quot;45801889605&quot;\r\n      }\r\n    ]\r\n    [\r\n      {\r\n        &quot;nick&quot;: &quot;main&quot;,\r\n        &quot;total&quot;: &quot;214748364800&quot;,\r\n        &quot;used&quot;: &quot;87240914483&quot;,\r\n        &quot;free&quot;: &quot;127507450317&quot;\r\n      }\r\n    ]\r\n\r\nWhat should be\r\n\r\n    [\r\n      {\r\n        &quot;nick&quot;: &quot;alt&quot;,\r\n        &quot;total&quot;: &quot;53687091200&quot;,\r\n        &quot;used&quot;: &quot;7885201595&quot;,\r\n        &quot;free&quot;: &quot;45801889605&quot;\r\n      },\r\n      {\r\n        &quot;nick&quot;: &quot;main&quot;,\r\n        &quot;total&quot;: &quot;214748364800&quot;,\r\n        &quot;used&quot;: &quot;87240914483&quot;,\r\n        &quot;free&quot;: &quot;127507450317&quot;\r\n      }\r\n    ]\r\n\r\n.accounts\r\n\r\n    nickname,user,pass\r\n\r\n",
        "link": "https://stackoverflow.com/questions/52087737/jq-create-json-array-using-bash",
        "title": "JQ create json array using bash"
    },
    {
        "tags": [
            "json",
            "regex",
            "jq",
            "wildcard",
            "activemq-artemis"
        ],
        "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": 1536436557,
                "post_id": 52093635,
                "comment_id": 91426407,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1536436877,
                "last_edit_date": 1536436877,
                "creation_date": 1536436483,
                "answer_id": 52238911,
                "question_id": 52093635,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; is there some way I can wildcard the key like this: \r\n&gt; `&quot;org.apache.activemq.artemis:broker=\\&quot;*\\&quot;&quot;` \r\n\r\nThe best way to match wildcards on key names is by using `with_entries` or `to_entries`.  Since you have not provided an example in accordance with the [MCVE](/help/mcve) guidelines, it&#39;s not clear exactly how you&#39;d do so, but by analogy with the example you give, you could start with:\r\n\r\n    .value\r\n    | to_entries[]\r\n    | select(.key | test(&quot;^org.apache.activemq.artemis:broker=\\&quot;.*\\&quot;&quot;))\r\n    | .value",
                "title": "Parse jolokia output with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1696353479,
        "creation_date": 1535621408,
        "last_edit_date": 1696353479,
        "question_id": 52093635,
        "body_markdown": "\r\nI have an Apache Artemis broker, of which I can get some management information through jolokia. This response is in json format; I also have jq to do &quot;json stuff&quot; with it.\r\n\r\n    curl -s -X GET --url &#39;http://localhost:8161/console/jolokia/read/org.apache.activemq.artemis:*&#39;\r\n\r\nThis works; and provides a json response.\r\n\r\nI want to make a kind of generic script to check some values from this response; hence a few questions:\r\n\r\n(For ease of testing I stored the response in a file broker.json, normally I would just pipe the output from curl to jq or store it in a variable, depending on how often jq has to be called)\r\n\r\nOne of the keys I want to query I can get like this:\r\n\r\n     jq &#39;.&quot;value&quot;.&quot;org.apache.activemq.artemis:broker=\\&quot;broker1\\&quot;&quot;&#39; broker.json\r\n\r\nHowever, in a more generic script, I won&#39;t know the name of the broker (which is &quot;broker1&quot; here); is there some way I can wildcard the key like this: `&quot;org.apache.activemq.artemis:broker=\\&quot;*\\&quot;&quot;` ? My attempts so far have not given me anything\r\n\r\nThe second question is a bit harder I think.\r\nIn the response there is a field that can be found by querying .request.timestamp\r\nthe value is in seconds since epoch.\r\n\r\nOn the broker are queues, and some of them might have messages; I want to find those that have messages older than, say, 5 minutes.\r\n\r\nI can find one such object with this key:\r\n\r\n      jq &#39;.&quot;value&quot;.&quot;org.apache.activemq.artemis:address=\\&quot;my.queue\\&quot;,broker=\\&quot;broker1\\&quot;,component=addresses,queue=\\&quot;my.queue\\&quot;,routing-type=\\&quot;anycast\\&quot;,subcomponent=queues&quot;&#39; broker.json\r\n\r\nThis object contains two keys I can use for this purpose:\r\n- FirstMessageAge : age in ms\r\n- FirstMessageTimestamp: timestamp in miliseconds since epoch.\r\n\r\nHow would I query for this? Ideally I&#39;d like to get the answer &quot;my.queue has messages older than X&quot;; where my.queue can also be obtained from having the key &quot;Address&quot; or &quot;Name&quot;\r\n\r\nArtemis uses Address and Queues as separate entities; for all practical purposes here, both have the same name.\r\n\r\nI am trying to make a (simple) script that can periodically monitor the broker health (not too many messages on queues for too long, queues having consumers, stuff like that; which all can be gotten from this single rest call; I think that with the answers to above questions I should be able to figure out how to get this.",
        "link": "https://stackoverflow.com/questions/52093635/parse-jolokia-output-with-jq",
        "title": "Parse jolokia output with jq"
    },
    {
        "tags": [
            "json",
            "jq",
            "mediainfo"
        ],
        "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": 1535880605,
                "post_id": 52118539,
                "comment_id": 91221119,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 173187,
                    "reputation": 699,
                    "user_id": 401713,
                    "user_type": "registered",
                    "accept_rate": 64,
                    "profile_image": "https://www.gravatar.com/avatar/a6c3cac82ba90cdd62fd11d93f265cb8?s=256&d=identicon&r=PG",
                    "display_name": "digitaltoast",
                    "link": "https://stackoverflow.com/users/401713/digitaltoast"
                },
                "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": 1535955501,
                "post_id": 52118539,
                "comment_id": 91237884,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1535729448,
                "creation_date": 1535729448,
                "answer_id": 52118668,
                "question_id": 52118539,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use the `--slurp` option:\r\n\r\n&gt; *   --slurp/-s:  \r\n&gt;  Instead of running the filter for each JSON object in the input, read the entire input stream into a large array and run the filter just once.\r\n\r\ncombined with a `map` to run your filter on each element of the array: `jq -s &#39;map({duration: .media.track[0].Duration, pubDate: .media.track[0].File_Modified_Date_Local, url: .media.&quot;@ref&quot;})&#39;`\r\n\r\nThen the output will still be an array.",
                "title": "Building valid JSON playlist from directory of files using MediaInfo Command Line and jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1535729448,
        "creation_date": 1535728943,
        "question_id": 52118539,
        "body_markdown": "I&#39;m using MediaInfo command line v18.08 on ubuntu to parse multiple files in a directory and output JSON, like this: `mediainfo * --output=JSON`\r\n\r\nWhich outputs the following JSON for each file (trimmed down a bit)\r\n\r\n    {\r\n        &quot;media&quot;: {\r\n            &quot;@ref&quot;: &quot;openingmusic.mp3&quot;,\r\n            &quot;track&quot;: [\r\n                {\r\n                    &quot;@type&quot;: &quot;General&quot;,\r\n                    &quot;Duration&quot;: &quot;17.789&quot;,\r\n                    &quot;Encoded_Library&quot;: &quot;LAME3.98r&quot;\r\n                },\r\n                {\r\n                    &quot;@type&quot;: &quot;Audio&quot;,\r\n                    &quot;Format&quot;: &quot;MPEG Audio&quot;,\r\n                    &quot;Encoded_Library_Settings&quot;: &quot;-m s -V 2 -q 3 -lowpass 18.6 --vbr-old -b 32&quot;\r\n                }\r\n            ]\r\n        }\r\n    }\r\n\r\n\r\nBut I only want a subset of that JSON, so I used jq-1.5-1\r\n\r\n`mediainfo *.mp3 --output=JSON |  jq &#39;. | {duration: .media.track[0].Duration, pubDate: .media.track[0].File_Modified_Date_Local, url: .media.&quot;@ref&quot;}&#39;`\r\n\r\nGreat, except there&#39;s no `,` between the elements, the whole lot isn&#39;t wrapped in [], and of course, while I can fudge that part, if I join the output, I get a trailing comma.\r\n\r\nWhat&#39;s the proper jq way of doing this, please?\r\n\r\n",
        "link": "https://stackoverflow.com/questions/52118539/building-valid-json-playlist-from-directory-of-files-using-mediainfo-command-lin",
        "title": "Building valid JSON playlist from directory of files using MediaInfo Command Line and jq"
    },
    {
        "tags": [
            "arrays",
            "json",
            "shell",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1535787709,
                "creation_date": 1535787709,
                "answer_id": 52126031,
                "question_id": 52125879,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Except that this was not valid json (there are additional `,` at ` &quot;phone&quot;: &quot;123-123-1234&quot;,`) but after removing it I was able to get a valid json here.  \r\nThere are many more arrays `[ { .. } ]` in your json file, you need to get that into account with `[][][]`.  \r\nThe following json:\r\n\r\n    {\r\n      &quot;Emails&quot;: [\r\n        {\r\n          &quot;email@email.com&quot;: [\r\n            {\r\n              &quot;andres&quot;: [\r\n                [\r\n                  {\r\n                    &quot;id&quot;: 1,\r\n                    &quot;email&quot;: &quot;email@email.com&quot;,\r\n                    &quot;username&quot;: &quot;test1&quot;,\r\n                    &quot;password&quot;: &quot;password&quot;,\r\n                    &quot;name&quot;: &quot;Dummy Account&quot;,\r\n                    &quot;address&quot;: &quot;123 st road&quot;,\r\n                    &quot;ip_address&quot;: &quot;0.0.0.0&quot;,\r\n                    &quot;phone&quot;: &quot;123-123-1234&quot;\r\n                  },\r\n                  {\r\n                    &quot;id&quot;: 2,\r\n                    &quot;email&quot;: &quot;email@email.com&quot;,\r\n                    &quot;username&quot;: &quot;test2&quot;,\r\n                    &quot;password&quot;: &quot;password&quot;,\r\n                    &quot;name&quot;: &quot;Dummy Account&quot;,\r\n                    &quot;address&quot;: &quot;123 st road&quot;,\r\n                    &quot;ip_address&quot;: &quot;0.0.0.0&quot;,\r\n                    &quot;phone&quot;: &quot;123-123-1234&quot;\r\n                  }\r\n                ],\r\n                true\r\n              ]\r\n            }\r\n          ]\r\n        }\r\n      ]\r\n    }\r\n\r\nwith the following filter:\r\n\r\n     .Emails[][][].andres[][] | .id, .email, .username, .password, .name, .address, .ip_address, .phone\r\n\r\ngives me:\r\n\r\n    jq: error (at &lt;stdin&gt;:34): Cannot iterate over boolean (true)\r\n    1\r\n    &quot;email@email.com&quot;\r\n    &quot;test1&quot;\r\n    &quot;password&quot;\r\n    &quot;Dummy Account&quot;\r\n    &quot;123 st road&quot;\r\n    &quot;0.0.0.0&quot;\r\n    &quot;123-123-1234&quot;\r\n    2\r\n    &quot;email@email.com&quot;\r\n    &quot;test2&quot;\r\n    &quot;password&quot;\r\n    &quot;Dummy Account&quot;\r\n    &quot;123 st road&quot;\r\n    &quot;0.0.0.0&quot;\r\n    &quot;123-123-1234&quot;\r\n    exit status 5\r\n\r\non [jqplay](https://jqplay.org/). I don&#39;t know what to do with that `true` in json, it&#39;s not valid, it should be an array member, like `{ &quot;true&quot; }`.",
                "title": "jq: Cannot index array with string &quot;id&quot;"
            },
            {
                "up_vote_count": 5,
                "is_accepted": false,
                "score": 5,
                "last_activity_date": 1535816162,
                "last_edit_date": 1535816162,
                "creation_date": 1535815856,
                "answer_id": 52129592,
                "question_id": 52125879,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "[tag:jq] is a funny beast. I find it takes a lot of trial and error.\r\n\r\nAfter fixing your JSON\r\n\r\n    $ jq -r &#39;.andres[][] | map(values) | @csv&#39; file.json\r\n    1,&quot;password&quot;,&quot;test1&quot;,&quot;email@email.com&quot;,&quot;Dummy Account&quot;,&quot;123 st road&quot;,&quot;0.0.0.0&quot;,&quot;123-123-1234&quot;\r\n    2,&quot;email2@email.com&quot;,&quot;test2&quot;,&quot;password&quot;,&quot;Dummy Account&quot;,&quot;123 st road&quot;,&quot;0.0.0.0&quot;,&quot;123-123-1234&quot;\r\n\r\nNote that for id=1, you have the password and email values switched.\r\n\r\nSee also &quot;Format strings and escaping&quot; in [the jq manual](https://stedolan.github.io/jq/manual)",
                "title": "jq: Cannot index array with string &quot;id&quot;"
            },
            {
                "up_vote_count": 7,
                "is_accepted": true,
                "score": 7,
                "last_activity_date": 1535880378,
                "creation_date": 1535880378,
                "answer_id": 52135617,
                "question_id": 52125879,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The value of `andres` in your json is an array of arrays, but you&#39;re accessing it as if it was an array of objects. You would have to flatten the arrays first (or index into) to access the objects. Then from those objects, you will want to map the values you want as csv as an array of values.\r\n\r\n    $ jq -r &#39;\r\n    .andres[][] | [.id, .email, .username, .password, .name, .address, .ip_address, .phone] | @csv\r\n    &#39; &lt; backup.json &gt; backup.csv\r\n\r\nNote the second set of `[]` in `.andres[][]`.\r\n\r\nYou may want to add some headers to your output as well.\r\n\r\n    $ jq -r &#39;\r\n    [&quot;id&quot;, &quot;email&quot;, &quot;username&quot;, &quot;password&quot;, &quot;name&quot;, &quot;address&quot;, &quot;ip_address&quot;, &quot;phone&quot;] as $headers\r\n        | $headers, (.andres[][] | [.[$headers[]]]) | @csv\r\n    &#39; &lt; backup.json &gt; backup.csv",
                "title": "jq: Cannot index array with string &quot;id&quot;"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 3,
        "last_activity_date": 1535880378,
        "creation_date": 1535786398,
        "last_edit_date": 1535791781,
        "question_id": 52125879,
        "body_markdown": "My `backup.json` looks like this:\r\n\r\n    {\r\n      &quot;andres&quot;: [\r\n        [\r\n          {\r\n            &quot;id&quot;: 1,\r\n            &quot;email&quot;: &quot;password&quot;,\r\n            &quot;username&quot;: test1,\r\n            &quot;password&quot;: &quot;email@email.com&quot;,\r\n            &quot;name&quot;: &quot;Dummy Account&quot;,\r\n            &quot;address&quot;: &quot;123 st road&quot;,,\r\n            &quot;ip_address&quot;: &quot;0.0.0.0&quot;,\r\n            &quot;phone&quot;: &quot;123-123-1234&quot;,\r\n          },\r\n          {\r\n            &quot;id&quot;: 2,\r\n            &quot;email&quot;: &quot;email2@email.com&quot;,\r\n            &quot;username&quot;: test2,\r\n            &quot;password&quot;: &quot;password&quot;,\r\n            &quot;name&quot;: &quot;Dummy Account&quot;,\r\n            &quot;address&quot;: &quot;123 st road&quot;,,\r\n            &quot;ip_address&quot;: &quot;0.0.0.0&quot;,\r\n            &quot;phone&quot;: &quot;123-123-1234&quot;\r\n          }\r\n        ],\r\n      ]\r\n    }\r\n\r\nI&#39;m using the command: \r\n\r\n    jq -r &#39;.andres[] | .id, .email, .username, .password, .name, .address, .ip_address, .phone&#39; &lt; backup.json &gt; backup.csv\r\n\r\nBut it gives the error: \r\n\r\n    Cannot index array with string &quot;id&quot;\r\n\r\nI want it to look like this:\r\n\r\n    1,email@email.com,test1,password,Dummy Account,123 st road,0.0.0.0,123-123-1234\r\n    2,email@email.com,test2,password,Dummy Account,123 st road,0.0.0.0,123-123-1234\r\n\r\nI&#39;m new to using JQ. Can someone please fix my command and tell me where i went wrong? \r\n\r\nThanks!",
        "link": "https://stackoverflow.com/questions/52125879/jq-cannot-index-array-with-string-id",
        "title": "jq: Cannot index array with string &quot;id&quot;"
    },
    {
        "tags": [
            "json",
            "linux",
            "bash",
            "command-line",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2641744,
                    "reputation": 1265,
                    "user_id": 2285234,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/a369d099bee36d46e32b964a68394138?s=256&d=identicon&r=PG",
                    "display_name": "Zastai",
                    "link": "https://stackoverflow.com/users/2285234/zastai"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1535910831,
                "post_id": 52139494,
                "comment_id": 91228904,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 11460873,
                    "reputation": 383,
                    "user_id": 8512713,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/ae4b3697ff201def0fae49201d19266f?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Pedro",
                    "link": "https://stackoverflow.com/users/8512713/pedro"
                },
                "reply_to_user": {
                    "account_id": 2641744,
                    "reputation": 1265,
                    "user_id": 2285234,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/a369d099bee36d46e32b964a68394138?s=256&d=identicon&r=PG",
                    "display_name": "Zastai",
                    "link": "https://stackoverflow.com/users/2285234/zastai"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1535913631,
                "post_id": 52139494,
                "comment_id": 91229668,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2641744,
                    "reputation": 1265,
                    "user_id": 2285234,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/a369d099bee36d46e32b964a68394138?s=256&d=identicon&r=PG",
                    "display_name": "Zastai",
                    "link": "https://stackoverflow.com/users/2285234/zastai"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1535917999,
                "post_id": 52139494,
                "comment_id": 91230740,
                "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": 1535930636,
                "post_id": 52139494,
                "comment_id": 91233159,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1535917955,
                "creation_date": 1535917955,
                "answer_id": 52140538,
                "question_id": 52139494,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If what you want is `.&quot;xxx&quot;` as argument, then use `&quot;.\\&quot;$txid\\&quot;&quot;`.\r\nIf you drop the `tr -d &#39;&quot;&#39;`, `&quot;.$txid&quot;` may even be enough.",
                "title": "Looping through a json file using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1535917955,
        "creation_date": 1535909820,
        "last_edit_date": 1535910531,
        "question_id": 52139494,
        "body_markdown": "Related to: \r\nhttps://stackoverflow.com/questions/28844295/getting-data-from-json-using-jq-when-key-is-numerical-string but different as I have the numerical key stored in a variable. See the example below.\r\n\r\nFile `temp.json`:\r\n\r\n    {\r\n      &quot;bccc26321e360ae5fde94aac81eef7c7270bbfd90de0787d0e5b45be4b21ce53&quot;: {\r\n        &quot;size&quot;: 189,\r\n        &quot;fee&quot;: 0.00000678,\r\n        &quot;modifiedfee&quot;: 0.00000678,\r\n        &quot;time&quot;: 1535906461,\r\n        &quot;height&quot;: 539665\r\n      },\r\n      &quot;43906c7227610cd58a1c95714e4f79cd46e0d98ae3f4214f1b2cf325b628b70e&quot;: {\r\n        &quot;size&quot;: 256,\r\n        &quot;fee&quot;: 0.00008328,\r\n        &quot;modifiedfee&quot;: 0.00008328,\r\n        &quot;time&quot;: 1535906461,\r\n        &quot;height&quot;: 539665\r\n      }\r\n    }\r\n\r\nAttempts to index with a variable:\r\n\r\n\r\n    #get second key 43906c7227610cd58a1c95714e4f79cd46e0d98ae3f4214f1b2cf325b628b70e\r\n    &gt;txid=$(cat temp.json | jq &#39;keys&#39; | jq .[1] | tr -d &#39;&quot;&#39;)\r\n    &gt;cat temp.json | jq .$txid\r\n    jq: error: syntax error, unexpected IDENT, expecting $end (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n    .43906c7227610cd58a1c95714e4f79cd46e0d98ae3f4214f1b2cf325b628b70e\r\n    jq: 1 compile error\r\n    \r\n    &gt;cat temp.json | jq &#39;.$txid&#39;\r\n    q: error: syntax error, unexpected &#39;$&#39; (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n    .$txid \r\n    jq: error: try .[&quot;field&quot;] instead of .field for unusually named fields at &lt;top-level&gt;, line 1:\r\n    .$txid\r\n    jq: 2 compile errors\r\n    \r\n    &gt;cat temp.json | jq &#39;.&quot;$txid&quot;&#39;\r\n    null\r\n\r\nThe desired output is simply\r\n\r\n    &gt;cat temp.json | jq &#39;.&quot;43906c7227610cd58a1c95714e4f79cd46e0d98ae3f4214f1b2cf325b628b70e&quot;&#39;\r\n    {\r\n            &quot;size&quot;: 256,\r\n            &quot;fee&quot;: 0.00008328,\r\n            &quot;modifiedfee&quot;: 0.00008328,\r\n            &quot;time&quot;: 1535906461,\r\n            &quot;height&quot;: 539665\r\n          }",
        "link": "https://stackoverflow.com/questions/52139494/looping-through-a-json-file-using-jq",
        "title": "Looping through a json file using 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": 1536412150,
                "post_id": 52142442,
                "comment_id": 91419768,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1535956335,
                "last_edit_date": 1592644375,
                "creation_date": 1535956335,
                "answer_id": 52144277,
                "question_id": 52142442,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "### Working with the output of your existing template:\n\n- Append this filter:\n\n        select(.localDate == &quot;2009-01-01&quot;)\n\n\n- So your modified command becomes:\n\n    &lt;pre&gt;&lt;code&gt;jq -cn --stream &#39;fromstream(1|truncate_stream(inputs | select(.[0][] == &quot;userActivities&quot;) | del(.[0][0]))) &lt;strong&gt;| select(.localDate == &quot;2009-01-01&quot;)&lt;/strong&gt;&#39;&lt;/code&gt;&lt;/pre&gt;\n\n",
                "title": "jq --stream help needed to parse json"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1535964980,
        "creation_date": 1535940773,
        "last_edit_date": 1535964980,
        "question_id": 52142442,
        "body_markdown": "I have a very large JSON text which I need to parse using \r\n\r\n    jq --stream \r\n\r\nHowever, there exists no elaborate use cases or blogs to understand this.\r\n\r\nJSON structure is as follows:\r\n\r\n    {\r\n      &quot;userActivities&quot;: {\r\n        &quot;-----P9E3PJB5bTO1xrO&quot;: {\r\n          &quot;aaid&quot;: &quot;84dae6bd-cb3a-409c-9940-844f035b5fc7&quot;,\r\n          &quot;callsign&quot;: &quot;2day&quot;,\r\n          &quot;deviceId&quot;: &quot;1b771f137d1bc6ea&quot;,\r\n          &quot;dow&quot;: &quot;Thursday&quot;,\r\n          &quot;downloadFlag&quot;: &quot;N&quot;,\r\n          &quot;email&quot;: &quot;ckcafeandcatering@gmail.com&quot;,\r\n          &quot;emailSha256&quot;: &quot;6ab0992297a9478be9ae7ff26d811b1116c45a0c819ff1c9628c9b7ca4ec4129&quot;,\r\n          &quot;event&quot;: &quot;streamStop&quot;,\r\n          &quot;firebaseUID&quot;: &quot;anvlMojJFvQEvMXQW6GeRzLKCIA2&quot;,\r\n          &quot;halfHourFull&quot;: &quot;10h1&quot;,\r\n          &quot;liveFlag&quot;: &quot;Y&quot;,\r\n          &quot;localDate&quot;: &quot;1970-01-01&quot;,\r\n          &quot;localHalfHour&quot;: 1,\r\n          &quot;login&quot;: &quot;google&quot;,\r\n          &quot;minutesSinceMidnight&quot;: 601,\r\n          &quot;quarterHourFull&quot;: &quot;10q1&quot;,\r\n          &quot;stationName&quot;: &quot;2DayFM104.1&quot;\r\n        },\r\n        &quot;-GuGCJDEprMKczAMDUj8&quot;: {\r\n          &quot;deviceId&quot;: &quot;399a649c6cee6209&quot;,\r\n          &quot;dow&quot;: &quot;Thursday&quot;,\r\n          &quot;downloadFlag&quot;: &quot;N&quot;,\r\n          &quot;event&quot;: &quot;streamStart&quot;,\r\n          &quot;halfHourFull&quot;: &quot;18h1&quot;,\r\n          &quot;liveFlag&quot;: &quot;Y&quot;,\r\n          &quot;localDate&quot;: &quot;2009-01-01&quot;,\r\n          &quot;localHalfHour&quot;: 1,\r\n          &quot;minutesSinceMidnight&quot;: 1080,\r\n          &quot;quarterHourFull&quot;: &quot;18q1&quot;,\r\n          &quot;stationName&quot;: &quot;hit 105&quot;,\r\n          &quot;streamListenMethod&quot;: &quot;Headphones&quot;,\r\n          &quot;timestampLocal&quot;: &quot;2009-01-01T18:00:33.679+10:00&quot;,\r\n          &quot;timestampUTC&quot;: &quot;2009-01-01T08:00:33.679Z&quot;\r\n        }\r\n      }\r\n    }\r\n\r\nI want to put a filter on localDate i.e. select only those arrays where localDate = &#39;2009-01-01&#39;.\r\n\r\nCurrently, I&#39;m feeding my JSON to the below command and it gives all the arrays.\r\n\r\n    jq -cn --stream &#39;fromstream(1|truncate_stream(inputs | select(.[0][] == &quot;userActivities&quot;) | del(.[0][0])))&#39;\r\n\r\nHow do I put a filter? Kindly suggest. Any help is greatly appreciated.",
        "link": "https://stackoverflow.com/questions/52142442/jq-stream-help-needed-to-parse-json",
        "title": "jq --stream help needed to parse json"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 5815148,
                    "reputation": 554,
                    "user_id": 4682460,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/YrDMH.jpg?s=256",
                    "display_name": "lobi",
                    "link": "https://stackoverflow.com/users/4682460/lobi"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1574694909,
                "post_id": 52144470,
                "comment_id": 104312824,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1536007083,
                "creation_date": 1536007083,
                "answer_id": 52155970,
                "question_id": 52144470,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If the goal is to just get objects at a certain depth of the json object tree, you can just truncate the stream.\r\n\r\n    $ jq --stream -nc &#39;fromstream(2|truncate_stream(inputs | select(.[0][:1] == [&quot;users&quot;])))&#39;\r\n\r\nJust make sure you&#39;re running the latest available jq. There&#39;s a bug in 1.5 for `truncate_stream/1` that breaks for any other input greater than `1`.",
                "title": "How to access nested json keys in jq --stream"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1536462170,
                "last_edit_date": 1536462170,
                "creation_date": 1536461770,
                "answer_id": 52240955,
                "question_id": 52144470,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With your input in input.json, the following invocation:\r\n\r\n    $ jq -nc --stream &#39;\r\n      fromstream(inputs|select(.[0][0] == &quot;users&quot;))|.[][]&#39; input.json\r\n\r\nyields:\r\n\r\n    {&quot;ageRangeMin&quot;:21,&quot;age_range&quot;:{&quot;min&quot;:21},&quot;gender&quot;:&quot;male&quot;}\r\n    {&quot;ageRangeMin&quot;:22,&quot;age_range&quot;:{&quot;min&quot;:20},&quot;gender&quot;:&quot;male&quot;}\r\n\r\nThe idea is to extract the &quot;users&quot; key-value pair first as a single-key object.\r\n\r\nNote that the -n option must be used here.",
                "title": "How to access nested json keys in jq --stream"
            }
        ],
        "is_answered": false,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1536462473,
        "creation_date": 1535957403,
        "last_edit_date": 1536462473,
        "question_id": 52144470,
        "body_markdown": "I have a huge json file(15 GB) which looks like as follows:\r\n\r\n    {\r\n      &quot;userActivities&quot;: {\r\n        &quot;-L3ATRosRd-bDgSmX75Z&quot;: {\r\n          &quot;deviceId&quot;: &quot;60ee32c2fae8dcf0&quot;,\r\n          &quot;dow&quot;: &quot;Friday&quot;\r\n        }\r\n      },\r\n      &quot;users&quot;: {\r\n        &quot;0GTDyAepIjcKMB1XulHCYLXylFS2&quot;: {\r\n          &quot;ageRangeMin&quot;: 21,\r\n          &quot;age_range&quot;: {\r\n            &quot;min&quot;: 21\r\n          },\r\n          &quot;gender&quot;: &quot;male&quot;\r\n        },\r\n        &quot;0GTDyAepIjcKMB1S2&quot;: {\r\n          &quot;ageRangeMin&quot;: 22,\r\n          &quot;age_range&quot;: {\r\n            &quot;min&quot;: 20\r\n          },\r\n          &quot;gender&quot;: &quot;male&quot;\r\n        }\r\n      }\r\n    }\r\n\r\nI want to extract the objects as if by `.users[]`, but using the streaming parser (`jq --stream`). That is, I want my output to be as follows:\r\n\r\n    {&quot;ageRangeMin&quot;:21,&quot;age_range&quot;:{&quot;min&quot;:21},&quot;gender&quot;:&quot;male&quot;}\r\n\t{&quot;ageRangeMin&quot;:22,&quot;age_range&quot;:{&quot;min&quot;:20},&quot;gender&quot;:&quot;male&quot;}\r\n\r\nAny guidance/help is greatly appreciated. I&#39;m unable to understand how `jq --stream` works.",
        "link": "https://stackoverflow.com/questions/52144470/how-to-access-nested-json-keys-in-jq-stream",
        "title": "How to access nested json keys in jq --stream"
    },
    {
        "tags": [
            "shell",
            "curl",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1536004161,
                "creation_date": 1536004161,
                "answer_id": 52155532,
                "question_id": 52154931,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I&#39;m assuming you mean to get all `EnvName` values that contains a certain value under `Stores`\r\n\r\n    .EnvMappings[] | select(any(.Stores[]; . == &quot;1111&quot;)).EnvName",
                "title": "Jq json parsing for array elements"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1536004161,
        "creation_date": 1536000544,
        "question_id": 52154931,
        "body_markdown": "I have a Json that I get like this by calling an api,how do i use a JQ query in curl to get the envname by passing 1111\r\n\r\n    {\r\n      &quot;EnvMappings&quot;: [\r\n      {\r\n        &quot;EnvName&quot;: &quot;lab&quot;,\r\n        &quot;Stores&quot;: [\r\n           &quot;1111&quot;,\r\n           &quot;2222&quot;\r\n         ]\r\n     }\r\n    ]\r\n }\r\n\r\n    curl -s &quot;&lt;&lt;MYAPI&gt;&gt;&quot; | jq -Mr &#39;.EnvMappings[].EnvName&#39; | tr &#39;[A-Z]&#39; &#39;[a-z]&#39; | sort",
        "link": "https://stackoverflow.com/questions/52154931/jq-json-parsing-for-array-elements",
        "title": "Jq json parsing for array elements"
    },
    {
        "tags": [
            "json",
            "if-statement",
            "edit",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 12682710,
                    "reputation": 103,
                    "user_id": 9215767,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/1111aafa6095b5c1107de52457f8b165?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "CLO",
                    "link": "https://stackoverflow.com/users/9215767/clo"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1536084829,
                "post_id": 52170924,
                "comment_id": 91294490,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1536128277,
                "last_edit_date": 1536128277,
                "creation_date": 1536086298,
                "answer_id": 52172213,
                "question_id": 52170924,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Figured it out. \r\n\r\n    jq &#39;[.[].discoveredEntities[] |= if (.name==&quot;weather&quot;) then (.checked = &quot;false&quot;) else . end]&#39;\\\r\n        ./test.json",
                "title": "jq conditional update an array element"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1536128569,
                "creation_date": 1536128569,
                "answer_id": 52178361,
                "question_id": 52170924,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "For these sorts of updates, it&#39;s easier to visualize if you think of it this way, locate the items you want to update first, then update them.\r\n\r\n     (.[].discoveredEntities[] | select(.name == &quot;weather&quot;).checked) = false\r\n    #[ locate the items to update                         ]\r\n    #                                                      [ update them   ]",
                "title": "jq conditional update an array element"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1536343416,
                "creation_date": 1536343416,
                "answer_id": 52227586,
                "question_id": 52170924,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using `map` here yields a very straightforward if somewhat pedestrian solution:\r\n\r\n    map( .discoveredEntities |=\r\n            map(if .name == &quot;weather&quot; then .checked = false else . end))\r\n\r\nNote that it is evidently more appropriate to use `false` here rather than `&quot;false&quot;`.",
                "title": "jq conditional update an array element"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 5,
        "last_activity_date": 1536343416,
        "creation_date": 1536080133,
        "last_edit_date": 1536291717,
        "question_id": 52170924,
        "body_markdown": "I want to conditionally update an element value based on the value of another element within the same array.\r\n\r\nFor example, I want to find name==&quot;weather&quot; and change checked from &quot;true&quot; to &quot;false&quot;\r\n\r\n    [\r\n      {\r\n        &quot;originalSourceId&quot;: null,\r\n        &quot;sourceConnection&quot;: {\r\n          &quot;id&quot;: null,\r\n          &quot;version&quot;: null,\r\n          &quot;properties&quot;: [\r\n            {\r\n              &quot;id&quot;: null,\r\n              &quot;version&quot;: null\r\n            }\r\n          ],\r\n          &quot;name&quot;: &quot;POSTGRESQL&quot;,\r\n          &quot;businessName&quot;: null\r\n        },\r\n        &quot;checked&quot;: true,\r\n        &quot;newlyAdded&quot;: false,\r\n        &quot;discoveredEntities&quot;: [\r\n          {\r\n            &quot;name&quot;: &quot;weather&quot;,\r\n            &quot;checked&quot;: true,\r\n            &quot;checkedBeforeEdit&quot;: false,\r\n            &quot;storeFieldsAsStrings&quot;: false\r\n          },\r\n          {\r\n            &quot;name&quot;: &quot;weather_2&quot;,\r\n            &quot;checked&quot;: true,\r\n            &quot;checkedBeforeEdit&quot;: false,\r\n            &quot;storeFieldsAsStrings&quot;: false\r\n          }\r\n        ],\r\n        &quot;defaultLevel&quot;: &quot;MANAGED&quot;\r\n      }\r\n    ]\r\n\r\nthe checked element will update to &quot;false&quot; for the same object with name = &quot;weather&quot; \r\n\r\n    [\r\n      {\r\n        &quot;originalSourceId&quot;: null,\r\n        &quot;sourceConnection&quot;: {\r\n          &quot;id&quot;: null,\r\n          &quot;version&quot;: null,\r\n          &quot;properties&quot;: [\r\n            {\r\n              &quot;id&quot;: null,\r\n              &quot;version&quot;: null\r\n            }\r\n          ],\r\n          &quot;name&quot;: &quot;POSTGRESQL&quot;,\r\n          &quot;businessName&quot;: null\r\n        },\r\n        &quot;checked&quot;: true,\r\n        &quot;newlyAdded&quot;: false,\r\n        &quot;discoveredEntities&quot;: [\r\n          {\r\n            &quot;name&quot;: &quot;weather&quot;,\r\n            &quot;checked&quot;: false,\r\n            &quot;checkedBeforeEdit&quot;: false,\r\n            &quot;storeFieldsAsStrings&quot;: false\r\n          },\r\n          {\r\n            &quot;name&quot;: &quot;weather_2&quot;,\r\n            &quot;checked&quot;: true,\r\n            &quot;checkedBeforeEdit&quot;: false,\r\n            &quot;storeFieldsAsStrings&quot;: false\r\n          }\r\n        ],\r\n        &quot;defaultLevel&quot;: &quot;MANAGED&quot;\r\n      }\r\n    ]\r\n\r\n",
        "link": "https://stackoverflow.com/questions/52170924/jq-conditional-update-an-array-element",
        "title": "jq conditional update an array element"
    },
    {
        "tags": [
            "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": 1536092837,
                "post_id": 52173556,
                "comment_id": 91297936,
                "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": 1536092912,
                "post_id": 52173556,
                "comment_id": 91297974,
                "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": 1536093064,
                "post_id": 52173556,
                "comment_id": 91298048,
                "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": 1536093318,
                "post_id": 52173556,
                "comment_id": 91298167,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1536093062,
                "creation_date": 1536093062,
                "answer_id": 52173607,
                "question_id": 52173556,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can&#39;t use `--arg` in that way. The value of a `--arg` is a string, not a jq filter expression. If you do `--arg p .properties`, then `$p` will contain the string `&quot;.properties&quot;`, it won&#39;t be evaluated as a program. Find a different way to do what you want, perhaps by defining a function.\r\n\r\nFor example, if you prefixed your program with `def p: .properties;` then you could use `.|p` in your program in the way that you&#39;re using `$p` now, and it would access the `.properties` of whatever value is in context.",
                "title": "jq: pass string argument without quotes"
            },
            {
                "up_vote_count": 5,
                "is_accepted": false,
                "score": 5,
                "last_activity_date": 1536094779,
                "last_edit_date": 1536094779,
                "creation_date": 1536093685,
                "answer_id": 52173719,
                "question_id": 52173556,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If I understand you correctly, you&#39;re getting sidetracked by thinking you need to set up a variable in `jq`, instead of just letting the shell do an expansion: \r\n\r\n    % foo=&#39;.properties&#39;\r\n    % jq -r -c  &quot;$foo&quot; sample.json \r\n\r\noutput: \r\n\r\n    {&quot;type&quot;:{&quot;description&quot;:&quot;Type&quot;}}\r\n\r\n\r\nNote the double quotes on $foo to still allow the shell to expand the variable to .properties. That said you could unsafely use: `jq -r -c  $foo sample.json` \r\n\r\n",
                "title": "jq: pass string argument without quotes"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1536325439,
                "creation_date": 1536325439,
                "answer_id": 52223191,
                "question_id": 52173556,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Since jq does not have an “eval” function, the appropriate way to specify a path programmatically in jq is using a JSON array in conjunction with jq’s `getpath` and `setpath` built-ins, as appropriate.\r\n\r\nThus in your case you could use the -—argjson command-line option to pass in the path of interest, e.g. \r\n\r\n    -—argson p &#39;[&quot;properties&quot;]&#39;\r\n\r\nand your jq program would use `getpath($p)`.\r\n\r\nNeedless to say, this approach works for arbitrarily nested paths.\r\n\r\n",
                "title": "jq: pass string argument without quotes"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 2,
        "last_activity_date": 1536325439,
        "creation_date": 1536092779,
        "last_edit_date": 1536092892,
        "question_id": 52173556,
        "body_markdown": "I would like to pass an argument without quotes (JQ arg has double quotes by default) since it should be used as a filter. For e.g. \r\n\r\n    propt=&#39;.properties&#39;\r\n    final=($(jq -r -c --arg p $propt &#39;$p&#39; sample.json))\r\n    echo $final\r\n\r\nsample.json\r\n\r\n&lt;!-- language: json --&gt;\r\n\r\n    {\r\n      &quot;type&quot;: &quot;object&quot;,\r\n      &quot;description&quot;: &quot;Contains information&quot;,\r\n      &quot;properties&quot;: {\r\n        &quot;type&quot;: {\r\n          &quot;description&quot;: &quot;Type&quot;\r\n            }\r\n       }\r\n    }\r\n\r\nSo ultimately it prints out ```.properties``` instead of the expected ```{&quot;type&quot;:{&quot;description&quot;:&quot;Type&quot;}}```\r\nI use a bash shell for this purpose. \r\n\r\nPlease let me know what I am doing wrong. \r\n\r\n",
        "link": "https://stackoverflow.com/questions/52173556/jq-pass-string-argument-without-quotes",
        "title": "jq: pass string argument without quotes"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 166270,
                    "reputation": 135171,
                    "user_id": 390278,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/84715fec547362389d02f5be0ed12814?s=256&d=identicon&r=PG",
                    "display_name": "Jeff Mercado",
                    "link": "https://stackoverflow.com/users/390278/jeff-mercado"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1536128085,
                "post_id": 52174288,
                "comment_id": 91306469,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1536129418,
                "creation_date": 1536129418,
                "answer_id": 52178574,
                "question_id": 52174288,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Based on how I interpreted how you were using jq in your [other question](https://stackoverflow.com/q/52173556), it depends on how complicated your filter will be. Any argument that is to be interpreted by `jq` is not the way you should approach it. This is the equivalent of using `eval()` and is not only unsupported, but just not a good way to approach this.\r\n\r\nIf you&#39;re simply accessing a property of the input, you have a couple of ways using simple indexing or using `getpath/1` for nested paths.\r\n\r\n    # indexing\r\n    # { &quot;properties&quot;: ... }\r\n    $ jq --arg p &#39;properties&#39; &#39;.[$p]&#39; input.json\r\n\r\n&lt;!-- --&gt;\r\n\r\n    # using getpath\r\n    # { &quot;foo&quot;: { &quot;bar&quot;: ... } }\r\n    $ jq --argjson path &#39;[&quot;foo&quot;,&quot;bar&quot;]&#39; &#39;getpath($path)&#39; input.json",
                "title": "jq: pass variable argument to be used as filter"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1587413342,
        "creation_date": 1536096914,
        "last_edit_date": 1587413342,
        "question_id": 52174288,
        "body_markdown": "How do I pass a *variable* argument to JQ program that will be used as a filter. Since by default --arg passes the argument as a a string wrapped with quotes the same cannot be used to apply a filter. \r\n\r\nhere is the JQ program that finds a particular path in the given json and adds a static key value to that path but doesn&#39;t work because of the quotes issue. \r\n\r\n```\r\n--argjson name &#39;{ &quot;pattern&quot;: &quot;XYZ&quot;}&#39; &#39;def p: &quot;.&quot; + (paths | select(.[-1] == &quot;p-enum&quot;) | .[0:-1] | join(&quot;.&quot;)) ; .|p += $name&#39; sample.json\r\n```\r\n\r\nhere is the sample json\r\n\r\n```\r\n{\r\n  &quot;type&quot;: &quot;object&quot;,\r\n  &quot;description&quot;: &quot;Contains information.&quot;,\r\n  &quot;properties&quot;: {\r\n    &quot;type&quot;: {\r\n      &quot;description&quot;: &quot;Type.&quot;,\r\n      &quot;type&quot;: &quot;string&quot;,\r\n      &quot;p-enum&quot;: [\r\n        {\r\n          &quot;value&quot;: &quot;IND&quot;,\r\n          &quot;description&quot;: &quot;Ind.&quot;\r\n        },\r\n        {\r\n          &quot;value&quot;: &quot;PROP&quot;,\r\n          &quot;description&quot;: &quot;Prop.&quot;\r\n        }\r\n      ]\r\n    }\r\n  }\r\n}\r\n```",
        "link": "https://stackoverflow.com/questions/52174288/jq-pass-variable-argument-to-be-used-as-filter",
        "title": "jq: pass variable argument to be used as filter"
    },
    {
        "tags": [
            "json",
            "linux",
            "bash",
            "csv",
            "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": 1536109811,
                "post_id": 52175703,
                "comment_id": 91302164,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 11460873,
                    "reputation": 383,
                    "user_id": 8512713,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/ae4b3697ff201def0fae49201d19266f?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Pedro",
                    "link": "https://stackoverflow.com/users/8512713/pedro"
                },
                "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": 1536111039,
                "post_id": 52175703,
                "comment_id": 91302368,
                "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": 1536111630,
                "post_id": 52175703,
                "comment_id": 91302458,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1536109509,
                "creation_date": 1536109509,
                "answer_id": 52175737,
                "question_id": 52175703,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "    jq -r &#39;.[] | [.time, .descendantcount, .ancestorcount] | @csv&#39; &lt;tempST.json &gt;tempOutput.csv\r\n\r\nSee this running at https://jqplay.org/s/QJz5FCmuc9",
                "title": "Rewriting a JSON file into a CSV efficiently in Bash"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1536109685,
        "creation_date": 1536109165,
        "question_id": 52175703,
        "body_markdown": "I want to efficiently rewrite a large json, which has always the same field names, into a csv, ignoring its keys. \r\n\r\nTo give a concrete example, here is a large JSON file (`tempST.json`):\r\nhttps://gist.githubusercontent.com/pedro-roberto/b81672a89368bc8674dae21af3173e68/raw/e4afc62b9aa3092c8722cdbc4b4b4b6d5bbc1b4b/tempST.json\r\n\r\nIf I rewrite just fields `time`, `ancestorcount` and `descendantcount` from this JSON into a CSV I should get:\r\n\r\n    1535995526,1,1\r\n    1535974524,1,1\r\n    1535974528,1,2\r\n    ...\r\n    1535997274,1,1\r\n\r\n\r\n\r\nThe following script `tempSpeedTest.sh` writes the value of the fields `time`, `ancestorcount` and `descendantcount` into each line of the csv:\r\n\r\n    rm tempOutput.csv\r\n    jq -c &#39;.[]&#39; &lt; tempST.json | while read line; do \r\n    descendantcount=$(echo $line | jq &#39;.descendantcount&#39;)\r\n    ancestorcount=$(echo $line | jq &#39;.ancestorcount&#39;)\r\n    time=$(echo $line | jq &#39;.time&#39;)\r\n    echo &quot;${time},${ancestorcount},${descendantcount}&quot; &gt;&gt; tempOutput.csv\r\n    done\r\n\r\nHowever the script takes around 3 minutes to run, which is unsatisfying:\r\n\r\n    &gt;time bash tempSpeedTest.sh\r\n    real\t2m50.254s\r\n    user\t2m43.128s\r\n    sys\t0m34.811s\r\n\r\nWhat is a faster way to achieve the same result?\r\n",
        "link": "https://stackoverflow.com/questions/52175703/rewriting-a-json-file-into-a-csv-efficiently-in-bash",
        "title": "Rewriting a JSON file into a CSV efficiently in Bash"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 7,
                "is_accepted": false,
                "score": 7,
                "last_activity_date": 1538594243,
                "last_edit_date": 1538594243,
                "creation_date": 1536170657,
                "answer_id": 52191066,
                "question_id": 52184815,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Since you&#39;re just checking the start of the keys, you could use `startswith/1` instead in this case, otherwise you could use `test/1` or `test/2`. Then you could pass those paths to be removed to `delpaths/1`.\r\n\r\nYou might want to filter the key by strings (or convert to strings) beforehand to account for arrays in your tree.\r\n\r\n    delpaths([paths | select(.[-1] | strings | startswith(&quot;hide&quot;))])\r\n\r\n&lt;!-- --&gt;\r\n\r\n    delpaths([paths | select(.[-1] | strings | test(&quot;^hide&quot;; &quot;i&quot;))])",
                "title": "JQ: how can I remove keys based on regex?"
            },
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1536327193,
                "creation_date": 1536327193,
                "answer_id": 52223666,
                "question_id": 52184815,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "A straightforward approach to the problem is to use `walk` in conjunction with `with_entries`, e.g.\r\n\r\n    walk(if type == &quot;object&quot; \r\n         then with_entries(select(.key | test(&quot;^hide&quot;) | not))\r\n         else . end)\r\n\r\nIf your jq does not have `walk/1` simply include its def (available e.g. from https://raw.githubusercontent.com/stedolan/jq/master/src/builtin.jq) before invoking it.\r\n",
                "title": "JQ: how can I remove keys based on regex?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1538594243,
        "creation_date": 1536149483,
        "last_edit_date": 1538572507,
        "question_id": 52184815,
        "body_markdown": "I would like to remove all keys that start with &quot;hide&quot;. Important to note that the keys may be nested at many levels. I&#39;d like to see the answer using a regex, although I recognise that in my example a simple `contains` would suffice. (I don&#39;t know how to do this with `contains`, either, BTW.)\r\n\r\nInput JSON 1:\r\n\r\n    {\r\n\t  &quot;a&quot;: 1,\r\n\t  &quot;b&quot;: 2,\r\n\t  &quot;hideA&quot;: 3,\r\n\t  &quot;c&quot;: {\r\n\t\t&quot;d&quot;: 4,\r\n\t\t&quot;hide4&quot;: 5\r\n\t  }\r\n    }\r\n\r\nDesired output JSON:\r\n\r\n    {\r\n\t  &quot;a&quot;: 1,\r\n\t  &quot;b&quot;: 2,\r\n\t  &quot;c&quot;: {\r\n\t\t&quot;d&quot;: 4\r\n\t  }\r\n    }\r\n\r\nInput JSON 2:\r\n\r\n    {\r\n\t  &quot;a&quot;: 1,\r\n\t  &quot;b&quot;: 2,\r\n\t  &quot;hideA&quot;: 3,\r\n\t  &quot;c&quot;: {\r\n\t\t&quot;d&quot;: 4,\r\n\t\t&quot;hide4&quot;: 5\r\n\t  },\r\n\t  &quot;e&quot;: null,\r\n\t  &quot;f&quot;: &quot;hiya&quot;,\r\n\t  &quot;g&quot;: false,\r\n\t  &quot;h&quot;: [{\r\n\t  \t&quot;i&quot;: 343.232,\r\n\t  \t&quot;hide9&quot;: &quot;private&quot;,\r\n        &quot;so_smart&quot;: true\r\n\t  }]\r\n    }\r\n\r\nThanks!",
        "link": "https://stackoverflow.com/questions/52184815/jq-how-can-i-remove-keys-based-on-regex",
        "title": "JQ: how can I remove keys based on regex?"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2000482,
                    "reputation": 903,
                    "user_id": 1791660,
                    "user_type": "registered",
                    "accept_rate": 0,
                    "profile_image": "https://www.gravatar.com/avatar/523d71e4f3fc2caed588975caca6eb61?s=256&d=identicon&r=PG",
                    "display_name": "Rick Baker",
                    "link": "https://stackoverflow.com/users/1791660/rick-baker"
                },
                "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": 1536235223,
                "post_id": 52187776,
                "comment_id": 91356207,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 13795134,
                    "reputation": 3684,
                    "user_id": 10440128,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/xbqD0.jpg?s=256",
                    "display_name": "milahu",
                    "link": "https://stackoverflow.com/users/10440128/milahu"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1707333704,
                "post_id": 52187776,
                "comment_id": 137434415,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 6,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1536170984,
                "last_edit_date": 1536170984,
                "creation_date": 1536159729,
                "answer_id": 52188281,
                "question_id": 52187776,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Asking for a one-liner code is as good as asking for unreadable code. If you want do this in a proper way, read the output of `jq` command in a while loop and strip out unwanted characters as required.\r\n\r\n    #!/usr/bin/env bash\r\n\r\n    # declare an associative array, the -A defines the array of this type\r\n    declare -A _my_Array\r\n\r\n    # The output of jq is separated by &#39;|&#39; so that we have a valid delimiter\r\n    # to read our keys and values. The read command processes one line at a \r\n    # time and puts the values in the variables &#39;key&#39; and &#39;value&#39;\r\n    while IFS=&#39;|&#39; read -r key value; do\r\n        # Strip out the text until the last occurrence of &#39;/&#39; \r\n        strippedKey=&quot;${key##*/}&quot;\r\n        # Putting the key/value pair in the array\r\n        _my_Array[&quot;$strippedKey&quot;]=&quot;$value&quot;\r\n    done&lt; &lt;(jq -r &#39;.Parameters[] | &quot;\\(.Name)|\\(.Value)&quot;&#39; json)\r\n\r\n    # Print the array using the &#39;-p&#39; or do one by one\r\n    declare -p _my_Array\r\n\r\nOr print the array, the traditional way\r\n\r\n    for key in &quot;${!_my_Array[@]}&quot;; do \r\n        printf &#39;%s %s\\n&#39; &quot;${key}&quot; &quot;${_my_Array[$key]}&quot;\r\n    done",
                "title": "Convert json array of objects to bash associative array"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 4,
        "last_activity_date": 1536170984,
        "creation_date": 1536158278,
        "question_id": 52187776,
        "body_markdown": "I have an array of json objects that I&#39;d like to convert to an associative array in bash with a slight alteration to the key\r\n\r\n    {\r\n    &quot;Parameters&quot;: [\r\n        {\r\n            &quot;Name&quot;: &quot;/path/user_management/api_key&quot;,\r\n            &quot;Type&quot;: &quot;SecureString&quot;,\r\n            &quot;Value&quot;: &quot;1234&quot;,\r\n            &quot;Version&quot;: 1\r\n        },\r\n        {\r\n            &quot;Name&quot;: &quot;/path/user_management/api_secret&quot;,\r\n            &quot;Type&quot;: &quot;SecureString&quot;,\r\n            &quot;Value&quot;: &quot;5678&quot;,\r\n            &quot;Version&quot;: 1\r\n        }\r\n    ]\r\n    }\r\n\r\nI know I need to use jq and sed but I just can&#39;t quite find the proper combination of doing what I&#39;m looking for.   Need to strip out &quot;/path/user_management/&quot; and set the remaining as the key, and use Value for value.  \r\n\r\nTrying to find a fairly clean one liner piping commands together.  What I&#39;d like to end up with is a bash associative array of something like:\r\n\r\n    myArray[api_key]=&quot;1234&quot;\r\n    myArray[api_secret]=&quot;5678&quot;",
        "link": "https://stackoverflow.com/questions/52187776/convert-json-array-of-objects-to-bash-associative-array",
        "title": "Convert json array of objects to bash associative array"
    },
    {
        "tags": [
            "linux",
            "bash",
            "csv",
            "jq",
            "paste"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3959308,
                    "reputation": 53394,
                    "user_id": 3266847,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/U0oyt.png?s=256",
                    "display_name": "Benjamin W.",
                    "link": "https://stackoverflow.com/users/3266847/benjamin-w"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1536160369,
                "post_id": 52188321,
                "comment_id": 91326660,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 11460873,
                    "reputation": 383,
                    "user_id": 8512713,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/ae4b3697ff201def0fae49201d19266f?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Pedro",
                    "link": "https://stackoverflow.com/users/8512713/pedro"
                },
                "reply_to_user": {
                    "account_id": 3959308,
                    "reputation": 53394,
                    "user_id": 3266847,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/U0oyt.png?s=256",
                    "display_name": "Benjamin W.",
                    "link": "https://stackoverflow.com/users/3266847/benjamin-w"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1536160713,
                "post_id": 52188321,
                "comment_id": 91326890,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 11460873,
                    "reputation": 383,
                    "user_id": 8512713,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/ae4b3697ff201def0fae49201d19266f?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Pedro",
                    "link": "https://stackoverflow.com/users/8512713/pedro"
                },
                "reply_to_user": {
                    "account_id": 3959308,
                    "reputation": 53394,
                    "user_id": 3266847,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/U0oyt.png?s=256",
                    "display_name": "Benjamin W.",
                    "link": "https://stackoverflow.com/users/3266847/benjamin-w"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1536160831,
                "post_id": 52188321,
                "comment_id": 91326957,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3959308,
                    "reputation": 53394,
                    "user_id": 3266847,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/U0oyt.png?s=256",
                    "display_name": "Benjamin W.",
                    "link": "https://stackoverflow.com/users/3266847/benjamin-w"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1536162610,
                "post_id": 52188321,
                "comment_id": 91327988,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1536160528,
                "creation_date": 1536160528,
                "answer_id": 52188534,
                "question_id": 52188321,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "In Bash, you can use [process substitution](http://wiki.bash-hackers.org/syntax/expansion/proc_subst):\r\n\r\n    paste -d, &lt;(jq ...) &lt;(jq ...) &lt;(jq ...)\r\n\r\nNote that paste accepts multiple files, not only two.",
                "title": "Printing all keys and values in a JSON in a CSV format"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1536214358,
                "last_edit_date": 1536214358,
                "creation_date": 1536160575,
                "answer_id": 52188559,
                "question_id": 52188321,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Why would need `paste` and other bunch of shell utils, when you can do it all it in `jq`\r\n\r\n    jq -r &#39;to_entries[] | &quot;\\(.key),\\(.value | .number),\\(.value | .word)&quot;&#39; json",
                "title": "Printing all keys and values in a JSON in a CSV format"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1536214538,
        "creation_date": 1536159830,
        "last_edit_date": 1536214538,
        "question_id": 52188321,
        "body_markdown": "I have several large JSON files that I need to rewrite into a single file but I am only able to do it in a nasty way that writes a lot of temporary files. Let&#39;s look at a simplified version of my problem, `example.json`:\r\n\r\n    {\r\n      &quot;a&quot;: {\r\n        &quot;number&quot;: 1,\r\n        &quot;word&quot;: &quot;foo&quot;\r\n      },\r\n      &quot;b&quot;: {\r\n        &quot;number&quot;: 2,\r\n        &quot;word&quot;: &quot;bar&quot;\r\n      },\r\n      &quot;c&quot;: {\r\n        &quot;number&quot;: 3,\r\n        &quot;word&quot;: &quot;zebra&quot;\r\n      }\r\n    }\r\n\r\nI want to obtain:\r\n\r\n    a,1,foo\r\n    b,2,bar\r\n    c,3,zebra\r\n\r\nMy solution:\r\n\r\n    jq &#39;keys | .[]&#39; example.json | tr -d &#39;&quot;&#39; &gt; file1.csv\r\n    jq &#39;.[] | .number&#39; example.json &gt; file2.csv\r\n    jq &#39;.[] | .word&#39; example.json | tr -d &#39;&quot;&#39; &gt; file3.csv\r\n    \r\n    paste -d&#39;,&#39; file1.csv file2.csv &gt; file4.csv\r\n    paste -d&#39;,&#39; file4.csv file3.csv &gt; file5.csv\r\n\r\nIn the code above I know I could have simplified it more by writing `jq -r &#39;.[] | [.number, .word] | @csv&#39;` instead of `jq &#39;.[] | .word&#39;` thus avoiding half of the mess but let&#39;s keep it this way because my question is related to the plumbing part.\r\n\r\nI have tried many ways of redirecting the output of `jq` into `paste` but I never succeed:\r\n\r\n    paste &lt;$(jq &#39;keys | .[]&#39; example.json | tr -d &#39;&quot;&#39;) file2.csv\r\n    paste $(jq &#39;keys | .[]&#39; example.json | tr -d &#39;&quot;&#39;) file2.csv\r\n    jq &#39;keys | .[]&#39; example.json | tr -d &#39;&quot;&#39;) | paste file2.csv\r\n\r\nHow do I put the output of `jq` into `paste` without having to create intermediate files?\r\n",
        "link": "https://stackoverflow.com/questions/52188321/printing-all-keys-and-values-in-a-json-in-a-csv-format",
        "title": "Printing all keys and values in a JSON in a CSV format"
    },
    {
        "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": 1,
                "creation_date": 1536169447,
                "post_id": 52190190,
                "comment_id": 91331318,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1536168371,
                "creation_date": 1536168371,
                "answer_id": 52190541,
                "question_id": 52190190,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "just do this\r\n\r\n    jq &#39;{ packages : . }&#39; input.json",
                "title": "Nest array into new object with JQ"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1536168411,
                "creation_date": 1536168411,
                "answer_id": 52190550,
                "question_id": 52190190,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Even things you think of as literals are really filters in `jq`. The filter you need in this case is simply `{packages: .}`:\r\n\r\n\r\n    $ echo &#39;[{}, {}]&#39; | jq &#39;{packages: .}&#39;\r\n    {\r\n      &quot;packages&quot;: [\r\n        {},\r\n        {}\r\n      ]\r\n    }",
                "title": "Nest array into new object with JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1607844453,
        "creation_date": 1536166842,
        "last_edit_date": 1607844453,
        "question_id": 52190190,
        "body_markdown": "I know this one should be easy but it has me stumped. I am looking to take the following json example:\r\n\r\n        [{\r\n      \t\t&quot;Name&quot;: &quot;Test1&quot;,\r\n      \t\t&quot;Version&quot;: &quot;5.0.1&quot;,\r\n      \t\t&quot;source&quot;: &quot;source&quot;\r\n      \t},\r\n      \t{\r\n      \t\t&quot;Name&quot;: &quot;Test2&quot;,\r\n      \t\t&quot;Version&quot;: &quot;2.0.11&quot;,\r\n      \t\t&quot;source&quot;: &quot;source&quot;\r\n      \t},\r\n      \t{\r\n      \t\t&quot;Name&quot;: &quot;Test3&quot;,\r\n      \t\t&quot;Version&quot;: &quot;2.1.2&quot;,\r\n      \t\t&quot;source&quot;: &quot;source&quot;\r\n      \t}]\r\n\r\nand convert it to:\r\n\r\n     {\r\n      \t&quot;packages&quot;: [\r\n            {\r\n      \t\t\t&quot;Name&quot;: &quot;Test1&quot;,\r\n      \t\t\t&quot;Version&quot;: &quot;5.0.1&quot;,\r\n      \t\t\t&quot;source&quot;: &quot;source&quot;\r\n      \t\t},\r\n      \t\t{\r\n      \t\t\t&quot;Name&quot;: &quot;Test2&quot;,\r\n      \t\t\t&quot;Version&quot;: &quot;2.0.11&quot;,\r\n      \t\t\t&quot;source&quot;: &quot;source&quot;\r\n      \t\t},\r\n      \t\t{\r\n      \t\t\t&quot;Name&quot;: &quot;Test3&quot;,\r\n      \t\t\t&quot;Version&quot;: &quot;2.1.2&quot;,\r\n      \t\t\t&quot;source&quot;: &quot;source&quot;\r\n      \t\t}\r\n      \t]\r\n      }\r\n\r\nI&#39;ve tried numerous different ways, the closest I got is using something similar to: `jq &#39;.packages += [input]&#39;`\r\n\r\nBasically it&#39;s just moving the original JSON to be nested. Any help would be appreciated.",
        "link": "https://stackoverflow.com/questions/52190190/nest-array-into-new-object-with-jq",
        "title": "Nest array into new object with JQ"
    },
    {
        "tags": [
            "bash",
            "sh",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1852014,
                    "reputation": 24882,
                    "user_id": 1678362,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/8ba023d18099cde022b9e4394d5714c0?s=256&d=identicon&r=PG",
                    "display_name": "Aaron",
                    "link": "https://stackoverflow.com/users/1678362/aaron"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1536241814,
                "post_id": 52205484,
                "comment_id": 91360270,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1852014,
                    "reputation": 24882,
                    "user_id": 1678362,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/8ba023d18099cde022b9e4394d5714c0?s=256&d=identicon&r=PG",
                    "display_name": "Aaron",
                    "link": "https://stackoverflow.com/users/1678362/aaron"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1536242152,
                "post_id": 52205484,
                "comment_id": 91360502,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1536242115,
                "creation_date": 1536242115,
                "answer_id": 52205735,
                "question_id": 52205484,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The variable is only accessible as `$var`, not `${var}`. Additionnaly, it is expanded to a quoted string, so enclosing it in double quotes is redundant.\r\n\r\nI suggest you use the following :\r\n\r\n    itVersion=$(jq --arg test &quot;${it}&quot; &#39;.[$test]&#39; test-config.json)",
                "title": "Get json field value by variable with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1536242115,
        "creation_date": 1536241428,
        "question_id": 52205484,
        "body_markdown": "I am trying to read the value of a field of a json variable, the field name is stored in a variable as well.\r\n\r\nWhat I tried:\r\n\r\n    $ jsonVar=`cat test-config.json`\r\n    $ echo $jsonVar\r\n    { &quot;server-test&quot;: &quot;xxx&quot;, &quot;server2-test&quot;: &quot;xxx&quot;, &quot;server3-test&quot;: &quot;xxx&quot;}\r\n    $ echo $it\r\n    server-test\r\n    $ itVersion=$(jq --arg test &quot;${it}&quot; &#39;.[&quot;${test}&quot;]&#39; &lt;&lt;&lt; $jsonVar);\r\n    $ echo $itVersion\r\n    null\r\n\r\n`$itVersion` should now have the value of `&quot;server-test&quot;` but is `null`, it seems my JQ command is wrong, but I cant figure out why.",
        "link": "https://stackoverflow.com/questions/52205484/get-json-field-value-by-variable-with-jq",
        "title": "Get json field value by variable with jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1536257698,
                "creation_date": 1536257698,
                "answer_id": 52209991,
                "question_id": 52206321,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Group the objects by category and comment, then map the groupings as you&#39;d like:\r\n\r\n    group_by({ category, comment }) | map({\r\n        category: .[0].category,\r\n        comment: .[0].comment,\r\n        elements: map({\r\n            foo: .element_foo,\r\n            bar: .element_bar\r\n        })\r\n    })",
                "title": "jq: consolidating data into a tree"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1536257698,
        "creation_date": 1536243945,
        "last_edit_date": 1536246331,
        "question_id": 52206321,
        "body_markdown": "My data consists of `categories` containing `elements`. Expressed in .csv format, data about the category is repeated with each element. I want to avoid this by storing the data in a .json tree format instead.\r\n\r\nHow might I consolidate this array of `elements`…\r\n\r\n    [\r\n      {\r\n        &quot;category&quot;: &quot;a&quot;,\r\n        &quot;comment&quot;: &quot;the repetition, oh my&quot;,\r\n        &quot;element_foo&quot;: 1,\r\n        &quot;element_bar&quot;: 10\r\n      },\r\n      {\r\n        &quot;category&quot;: &quot;a&quot;,\r\n        &quot;comment&quot;: &quot;the repetition, oh my&quot;,\r\n        &quot;element_foo&quot;: 2,\r\n        &quot;element_bar&quot;: 20\r\n      }\r\n    ],\r\n\r\n…into this array of `categories` containing arrays of `elements`?\r\n\r\n    [\r\n      {\r\n        &quot;category&quot;: &quot;a&quot;,\r\n        &quot;comment&quot;: &quot;the repetition, oh my&quot;,\r\n        &quot;elements&quot;: [\r\n          {\r\n            &quot;foo&quot;: 1,\r\n            &quot;bar&quot;: 10\r\n          },\r\n          {\r\n            &quot;foo&quot;: 2,\r\n            &quot;bar&quot;: 20\r\n          }\r\n        ]\r\n      }\r\n    ]\r\n\r\nI&#39;m hoping this is something fairly trivial for `jq` to do - otherwise I&#39;ll write something more heavyweight.",
        "link": "https://stackoverflow.com/questions/52206321/jq-consolidating-data-into-a-tree",
        "title": "jq: consolidating data into a tree"
    },
    {
        "tags": [
            "json",
            "bash",
            "avro",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1536291563,
                "creation_date": 1536291563,
                "answer_id": 52214918,
                "question_id": 52214571,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "jq&#39;s -r command-line option converts a JSON string to its &quot;raw&quot; form, so to convert the string in `.bytes`, you could pipe the JSON to:\r\n\r\n    jq -r .bytes \r\n\r\nThe occurrence of NULs in your sample makes it impossible to show the output here on SO.",
                "title": "Avro encoded binary to file"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1536291563,
        "creation_date": 1536288315,
        "question_id": 52214571,
        "body_markdown": "Avro tools `tojson` command escapes binary values. Here&#39;s an example:\r\n\r\n    {&quot;bytes&quot;:&quot;\\u0000\\u0000\\u0000\\u0000\\u0002\\u0000\\u0000\\u0000\\u0002@ol\\u0000\\u0000\\u0000\\u0000\\u0000@f&#184;\\u0000\\u0000\\u0000\\u0000\\u0000@o&#166;\\u0000\\u0000\\u0000\\u0000\\u0000@f&#250;\\u0000\\u0000\\u0000\\u0000\\u0000&quot;}\r\n\r\nHow can I extract these binary values to file in bash? Is it possible using `jq`?\r\n",
        "link": "https://stackoverflow.com/questions/52214571/avro-encoded-binary-to-file",
        "title": "Avro encoded binary to file"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1536317296,
                "creation_date": 1536317296,
                "answer_id": 52220944,
                "question_id": 52220633,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You need to use the `fromjson` construct on the nested JSON field as below. The [`fromjson`](https://stedolan.github.io/jq/manual/) is _not_ so well documented in the official documentation but it allows you to parse JSON texts into values for use in filters.\r\n\r\n    .[] | select((.store_plugin == &quot;s3v8&quot; and .store_endpoint != null) and (.store_endpoint | fromjson | .signature_version == &quot;2&quot;) )\r\n\r\n[jqplay.org - URL](https://jqplay.org/s/JTEvXsyTfl)",
                "title": "get objects that match a key value from a nested object that is quoted"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1536317296,
        "creation_date": 1536316280,
        "question_id": 52220633,
        "body_markdown": "I have a list of JSON objects with this format\r\n\r\n&lt;!-- language-all: json --&gt;\r\n\r\n    [\r\n     {\r\n    \t&quot;uuid&quot;: &quot;2e08c71c-56af-4c1d-9677-0aad7bf38536&quot;,\r\n    \t&quot;name&quot;: &quot;img-s3&quot;,\r\n    \t&quot;summary&quot;: &quot;&quot;,\r\n    \t&quot;retention_name&quot;: &quot;month&quot;,\r\n    \t&quot;retention_uuid&quot;: &quot;beae2f1a-10e9-4b53-b9b1-baf823624ff2&quot;,\r\n    \t&quot;expiry&quot;: 2678400,\r\n    \t&quot;schedule_name&quot;: &quot;daily&quot;,\r\n    \t&quot;schedule_uuid&quot;: &quot;baca1a64-b506-4789-83c8-653573f2b99f&quot;,\r\n    \t&quot;schedule_when&quot;: &quot;daily 2am&quot;,\r\n    \t&quot;paused&quot;: false,\r\n    \t&quot;store_uuid&quot;: &quot;d91fd7b6-4c39-4f73-aa44-8ec55f52da65&quot;,\r\n    \t&quot;store_name&quot;: &quot;default&quot;,\r\n    \t&quot;store_plugin&quot;: &quot;s3v8&quot;,\r\n    \t&quot;store_endpoint&quot;: &quot;{\\&quot;access_key_id\\&quot;:\\&quot;xxxx\\&quot;,\\&quot;bucket\\&quot;:\\&quot;images-c4\\&quot;,\\&quot;s3_host\\&quot;:\\&quot;s3.amazon.com\\&quot;,\\&quot;secret_access_key\\&quot;:\\&quot;yyy\\&quot;,\\&quot;signature_version\\&quot;:\\&quot;2\\&quot;,\\&quot;skip_ssl_validation\\&quot;:true}&quot;,\r\n    \t&quot;target_uuid&quot;: &quot;991c7aa2-cdd3-4f90-bb28-1431c99f8fc8&quot;,\r\n    \t&quot;target_name&quot;: &quot;sc-asd&quot;,\r\n    \t&quot;target_plugin&quot;: &quot;mysql&quot;,\r\n    \t&quot;target_endpoint&quot;: &quot;{\\&quot;mysql_database\\&quot;:\\&quot;users\\&quot;,\\&quot;mysql_host\\&quot;:\\&quot;10.10.22.49\\&quot;,\\&quot;mysql_password\\&quot;:\\&quot;password\\&quot;,\\&quot;mysql_port\\&quot;:\\&quot;3306\\&quot;,\\&quot;mysql_user\\&quot;:\\&quot;user\\&quot;}&quot;,\r\n    \t&quot;agent&quot;: &quot;127.0.0.1:3030&quot;\r\n    }\r\n    ...\r\n    ]\r\n\r\nI need to obtain only the objects using `storege_plugin: &quot;s3v8&quot;` and that in the &quot;quoted&quot; value object of `storage_endpoint` the key `signature_version` is `2`\r\n\r\nTo find the object having `storage_plugin: &quot;s3v8&quot;`, and `store_endpoing != null` I am using this:\r\n\r\n\r\n    $ command | jq &#39;.[] | select(.store_plugin == &quot;s3v8&quot; and .store_endpoint != null)&#39;\r\n\r\nBut the problem I have now is that the value of `store_endpoint` is quoted and I only need to get results based on the value of a key, in this case, `signature_value`\r\n\r\nTo test how to unquote and search for the value I am trying this:\r\n\r\n    $&#160;echo &quot;{\\&quot;access_key_id\\&quot;:\\&quot;xxxx\\&quot;,\\&quot;bucket\\&quot;:\\&quot;images-c4\\&quot;,\\&quot;s3_host\\&quot;:\\&quot;s3.amazon.com\\&quot;,\\&quot;secret_access_key\\&quot;:\\&quot;yyy\\&quot;,\\&quot;signature_version\\&quot;:\\&quot;2\\&quot;,\\&quot;skip_ssl_validation\\&quot;:true}&quot; \\\r\n    | jq -r &#39;select(.signature_version == &quot;2&quot;)&#39;\r\n    {\r\n      &quot;access_key_id&quot;: &quot;xxxx&quot;,\r\n      &quot;bucket&quot;: &quot;images-c4&quot;,\r\n      &quot;s3_host&quot;: &quot;s3.amazon.com&quot;,\r\n      &quot;secret_access_key&quot;: &quot;yyy&quot;,\r\n      &quot;signature_version&quot;: &quot;2&quot;,\r\n      &quot;skip_ssl_validation&quot;: true\r\n    }\r\n\r\nBut would like to know how could I &quot;merge&quot; this options so that I could get a list of objects that have a set of required keys but that depends on a nested key stored on a quoted object.\r\n\r\n",
        "link": "https://stackoverflow.com/questions/52220633/get-objects-that-match-a-key-value-from-a-nested-object-that-is-quoted",
        "title": "get objects that match a key value from a nested object that is quoted"
    },
    {
        "tags": [
            "github",
            "pagination",
            "github-api",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1536355987,
                "creation_date": 1536355987,
                "answer_id": 52229855,
                "question_id": 52228774,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It was a paging problem, as presented in the documentation, the api only gives you 30 items per request, so you need to add some code to include all the pages. I was using bash so my code ended up like this:\r\n\r\n     for i in `seq 1 34`;\r\n            do\r\n    \t\t\tURL=&quot;https://api.github.com/search/repositories?q=language:Java+stars:%3E=500+library+java+in:readme&amp;page=$i&quot;\r\n    \t\t\techo $URL\r\n    \t\t\tcurl -G  $URL \\\r\n    \t\t\t| jq &quot;.items[] | {name, description, language, watchers_count, html_url}&quot; &gt;&gt; parsedOutput1.txt\r\n            done\r\nOn another note, when doing a lot of requests you should authenticate, otherwise you will end up with the API rate limit exceeded message.",
                "title": "GitHub API - Different number of results for jq filtered response"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1536501533,
        "creation_date": 1536349525,
        "last_edit_date": 1536501533,
        "question_id": 52228774,
        "body_markdown": "I am trying to use the GitHub API to make a list of well documented, open source Java libraries. To do so, I went through the GitHub API documentation and made this simple curl.\r\n    \r\n    curl -G  https://api.github.com/search/repositories?q=language:Java+stars:%3E=500+library+java+in:readme &gt; output1.txt\r\n\r\nThe output of this is a giant txt file, containing information about all of the repositories found. In this example, there was a total of 736 matches. However, the file from the command above is quite unreadable, so I decided to do some parsing using `jq`, which resulted in the following code:\r\n\r\n    curl -G  https://api.github.com/search/repositories?q=language:Java+stars:%3E=500+library+java+in:readme \\\r\n     | jq &quot;.items[] | {name, description, language, watchers_count, html_url}&quot; &gt; parsedOutput1.txt\r\n\r\nAfter this, instead of 736 results, I got something around 30 repositories, which is unacceptable for my purposes. \r\n\r\nDoing this search: `language:java stars:&gt;=500  java library in:readme` in the GitHub search box gives me the same 736 results. I don&#39;t really know what i am doing wrong so I could use the help.",
        "link": "https://stackoverflow.com/questions/52228774/github-api-different-number-of-results-for-jq-filtered-response",
        "title": "GitHub API - Different number of results for jq filtered response"
    },
    {
        "tags": [
            "json",
            "object",
            "syntax",
            "key",
            "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": 1536376958,
                "post_id": 52231558,
                "comment_id": 91412806,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 11,
                "is_accepted": true,
                "score": 11,
                "last_activity_date": 1536411563,
                "last_edit_date": 1536411563,
                "creation_date": 1536376908,
                "answer_id": 52231691,
                "question_id": 52231558,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "As explained in the [jq manual][1], when a key name is specified programmatically, the defining expression must be enclosed in parentheses:\r\n\r\n    $ jq -n --arg greeting world --arg mykey hello &#39;{($mykey):$greeting}&#39;\r\n    {\r\n      &quot;hello&quot;: &quot;world&quot;\r\n    }\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/",
                "title": "JQ Create JSON Key and Value Pair"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 4,
        "last_activity_date": 1536411563,
        "creation_date": 1536374863,
        "last_edit_date": 1536380923,
        "question_id": 52231558,
        "body_markdown": "I&#39;m trying to create a JSON file with this very simple command:\r\n\r\n   `jq -n --arg greeting world --arg mykey hello &#39;{&quot;hello&quot;:$greeting}&#39;`\r\n\r\nMy problem is that when I replace the key with $mykey I get this error:\r\n\r\n    # jq -n --arg greeting world --arg mykey hello {$mykey:$greeting}\r\n    jq: error: syntax error, unexpected &#39;:&#39; (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n    {:}\r\n    jq: 1 compile error\r\n\r\nHow can I create a simple JSON file with two arguments/variables?",
        "link": "https://stackoverflow.com/questions/52231558/jq-create-json-key-and-value-pair",
        "title": "JQ Create JSON Key and Value Pair"
    },
    {
        "tags": [
            "arrays",
            "json",
            "bash",
            "count",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 4879,
                    "reputation": 248190,
                    "user_id": 7552,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/b60298053f87465641c1b1192338c8cd?s=256&d=identicon&r=PG",
                    "display_name": "glenn jackman",
                    "link": "https://stackoverflow.com/users/7552/glenn-jackman"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1536501408,
                "post_id": 52244763,
                "comment_id": 91438649,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 7,
                "is_accepted": true,
                "score": 7,
                "last_activity_date": 1536498431,
                "creation_date": 1536498431,
                "answer_id": 52244835,
                "question_id": 52244763,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "    echo &quot;$j&quot; | jq &#39;.Names | .names | length&#39;\r\n\r\nOutput:\r\n&lt;pre&gt;\r\n4\r\n&lt;/pre&gt;",
                "title": "How to get the size of a vector in a JSON in the shell script?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1536498984,
        "creation_date": 1536497959,
        "last_edit_date": 1536498984,
        "question_id": 52244763,
        "body_markdown": "I would like to get the size of a vector in a JSON in the shell script but I&#39;m only getting the size of each vector string, for example:\r\n\r\n    #!/bin/bash\r\n    \r\n    j=&#39;{&quot;Names&quot;: { &quot;names&quot;: [&quot;marry&quot;, &quot;jason&quot;, &quot;frank&quot;,&quot;kelly&quot;] }}&#39;\r\n    \r\n    echo &quot;$j&quot; | jq -r &quot;.Names | .names[] | length&quot;\r\n\r\nThe output is :\r\n\r\n    5\r\n    4\r\n    5\r\n    4\r\n\r\nBut i want to get 4 that is the amount of items in the vector.",
        "link": "https://stackoverflow.com/questions/52244763/how-to-get-the-size-of-a-vector-in-a-json-in-the-shell-script",
        "title": "How to get the size of a vector in a JSON in the shell script?"
    },
    {
        "tags": [
            "json",
            "if-statement",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1536562983,
                "last_edit_date": 1536562983,
                "creation_date": 1536560387,
                "answer_id": 52252089,
                "question_id": 52251370,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It looks as though you want:\r\n\r\n    .gcp_price_list\r\n    | .&quot;CP-COMPUTEENGINE-OS&quot;\r\n    | map_values(\r\n        if .cores == &quot;shared&quot; \r\n        then .cores = 0.5 \r\n        else . end )\r\n\r\nIn any case, be careful when using expressions such as `.[].cores` as arguments of `if`, `then`, or `else`, because they produce a stream of results.  \r\n\r\nIn future, please follow the [MCVE](/help/mcve) guidelines.\r\n\r\n# Postscript\r\nIf you want to edit the JSON document, you would use `|=` like so:\r\n\r\n    .gcp_price_list.&quot;CP-COMPUTEENGINE-OS&quot; |= \r\n      map_values(\r\n        if ( .cores == &quot;shared&quot; ) then\r\n            .cores = 0.5 \r\n        else . end\r\n      )\r\n\r\n",
                "title": "jq if value match then update end"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1536562983,
        "creation_date": 1536555760,
        "last_edit_date": 1536561547,
        "question_id": 52251370,
        "body_markdown": "For this data\r\nhttps://jqplay.org/s/onlU9ghjn1\r\n\r\nI can not figure out the correct syntax to do something like\r\n\r\n    .gcp_price_list | .&quot;CP-COMPUTEENGINE-OS&quot; | \r\n    (\r\n        if ( .[].cores == &quot;shared&quot; ) then\r\n            .[].cores = 0.5 \r\n        end\r\n    )\r\n\r\nSeems I need the `else` part but I&#39;m not sure what to put there. If I do:\r\n\r\n    .gcp_price_list | .&quot;CP-COMPUTEENGINE-OS&quot; | \r\n    (\r\n        if ( .[].cores == &quot;shared&quot; ) then\r\n            .[].cores = 0.5 \r\n        else .[].cores = .[].cores end\r\n    )\r\n\r\nThere is still &quot;shared&quot; in the result, i.e.\r\n\r\n      &quot;win&quot;: {\r\n        &quot;low&quot;: 0.02,\r\n        &quot;high&quot;: 0.04,\r\n        &quot;cores&quot;: &quot;shared&quot;,\r\n        &quot;percore&quot;: true\r\n      }\r\n\r\nInputs get replicated into the result, which is not what I want.\r\n\r\nRelated, but I don&#39;t find them very helpful, questions\r\n\r\nhttps://stackoverflow.com/questions/33572755/jq-if-then-else\r\n\r\nhttps://stackoverflow.com/questions/31034746/how-do-i-update-a-single-value-in-a-json-document-using-jq\r\n\r\n\r\n----------\r\nMy practical alternative is &quot;replaced all&quot; with a text editor,\r\nbut I will leave this question here in case there is an elegant solution.\r\n\r\n",
        "link": "https://stackoverflow.com/questions/52251370/jq-if-value-match-then-update-end",
        "title": "jq if value match then update end"
    },
    {
        "tags": [
            "json",
            "bash",
            "templates",
            "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": 1536563763,
                "post_id": 52252781,
                "comment_id": 91452917,
                "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": 1536563866,
                "post_id": 52252781,
                "comment_id": 91452969,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3260407,
                    "reputation": 1102,
                    "user_id": 2746089,
                    "user_type": "registered",
                    "accept_rate": 80,
                    "profile_image": "https://i.sstatic.net/Bjuob.png?s=256",
                    "display_name": "RNA",
                    "link": "https://stackoverflow.com/users/2746089/rna"
                },
                "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": 1536564100,
                "post_id": 52252781,
                "comment_id": 91453058,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3260407,
                    "reputation": 1102,
                    "user_id": 2746089,
                    "user_type": "registered",
                    "accept_rate": 80,
                    "profile_image": "https://i.sstatic.net/Bjuob.png?s=256",
                    "display_name": "RNA",
                    "link": "https://stackoverflow.com/users/2746089/rna"
                },
                "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": 1536564127,
                "post_id": 52252781,
                "comment_id": 91453078,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1536590520,
                "creation_date": 1536590520,
                "answer_id": 52260284,
                "question_id": 52252781,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Unfortunately there are several parts of the question that don&#39;t quite make sense, but I believe the following should get you on your way.\r\n\r\nFirst, I&#39;ll assume your template is valid JSON:\r\n\r\n    {\r\n        &quot;My_Table&quot;: [\r\n    \t{&quot;PutRequest&quot;:{&quot;Item&quot;:{&quot;type&quot;:{&quot;S&quot;:&quot;test-$NUMBER-Type_A&quot;},&quot;name&quot;:0}}},\r\n    \t{&quot;PutRequest&quot;:{&quot;Item&quot;:{&quot;type&quot;:{&quot;S&quot;:&quot;test-$NUMBER-Type_A&quot;},&quot;name&quot;:1}}},\r\n    \t{&quot;PutRequest&quot;:{&quot;Item&quot;:{&quot;type&quot;:{&quot;S&quot;:&quot;test-$NUMBER-Type_A&quot;},&quot;name&quot;:2}}},\r\n    \t{&quot;PutRequest&quot;:{&quot;Item&quot;:{&quot;type&quot;:{&quot;S&quot;:&quot;test-$NUMBER-Type_B&quot;},&quot;name&quot;:0}}},\r\n    \t{&quot;PutRequest&quot;:{&quot;Item&quot;:{&quot;type&quot;:{&quot;S&quot;:&quot;test-$NUMBER-Type_B&quot;},&quot;name&quot;:1}}},\r\n    \t{&quot;PutRequest&quot;:{&quot;Item&quot;:{&quot;type&quot;:{&quot;S&quot;:&quot;test-$NUMBER-Type_B&quot;},&quot;name&quot;:2}}},\r\n    \t{&quot;PutRequest&quot;:{&quot;Item&quot;:{&quot;type&quot;:{&quot;S&quot;:&quot;test-$NUMBER-Type_C&quot;},&quot;name&quot;:0}}},\r\n    \t{&quot;PutRequest&quot;:{&quot;Item&quot;:{&quot;type&quot;:{&quot;S&quot;:&quot;test-$NUMBER-Type_D&quot;},&quot;name&quot;:1}}},\r\n    \t{&quot;PutRequest&quot;:{&quot;Item&quot;:{&quot;type&quot;:{&quot;S&quot;:&quot;test-$NUMBER-Type_E&quot;},&quot;name&quot;:0}}}\r\n      ]\r\n    }\r\n\r\nSecond, I&#39;ll assume you want the result along the lines of what is shown, not as described, but the following is written so you can easily adapt the code to the described problem.  Specifically, the functionality for making the substitution is encapsulated\r\nin the following definition:\r\n\r\n    def resolve(s; value):\r\n      .My_Table |= map(.PutRequest.Item.type.S |= \r\n         sub(&quot;-&quot; + s + &quot;-&quot;; &quot;-&quot; + (value|tostring) + &quot;-&quot; ));\r\n\r\nThis is written using `sub`, the first argument of which must be a regex. So, to generate the desired output for a single substitution of &quot;$NUMBER&quot; by &quot;1&quot;, one would write:\r\n\r\n\r\n    resolve(&quot;\\\\$NUMBER&quot;; 1)\r\n\r\nSince I&#39;m not sure what your bash snippet is supposed to do exactly, I&#39;ll just suggest that you could use iteration within jq to achieve whatever result you require, rather than using bash iteration.\r\n\r\n",
                "title": "insert bash variable into json using jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1536607662,
                "creation_date": 1536607662,
                "answer_id": 52264277,
                "question_id": 52252781,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If the template is intended to be used with `jq`, it should be changed to work correctly, rather than trying to force `jq` to work with substandard input.\r\n\r\n    {\r\n        &quot;My_Table&quot;:[{\r\n            &quot;PutRequest&quot;:{&quot;Item&quot;:{&quot;type&quot;:{&quot;S&quot;:&quot;test-\\($NUMBER)-Type_A&quot;},&quot;name&quot;:{ ...\r\n            &quot;PutRequest&quot;:{&quot;Item&quot;:{&quot;type&quot;:{&quot;S&quot;:&quot;test-\\($NUMBER)-Type_A&quot;},&quot;name&quot;:{ ...\r\n            &quot;PutRequest&quot;:{&quot;Item&quot;:{&quot;type&quot;:{&quot;S&quot;:&quot;test-\\($NUMBER)-Type_A&quot;},&quot;name&quot;:{ ...        \r\n            &quot;PutRequest&quot;:{&quot;Item&quot;:{&quot;type&quot;:{&quot;S&quot;:&quot;test-\\($NUMBER)-Type_B&quot;},&quot;name&quot;:{ ...\r\n            &quot;PutRequest&quot;:{&quot;Item&quot;:{&quot;type&quot;:{&quot;S&quot;:&quot;test-\\($NUMBER)-Type_B&quot;},&quot;name&quot;:{ ...\r\n            &quot;PutRequest&quot;:{&quot;Item&quot;:{&quot;type&quot;:{&quot;S&quot;:&quot;test-\\($NUMBER)-Type_B&quot;},&quot;name&quot;:{ ...\r\n            &quot;PutRequest&quot;:{&quot;Item&quot;:{&quot;type&quot;:{&quot;S&quot;:&quot;test-\\($NUMBER)-Type_C&quot;},&quot;name&quot;:{ ...\r\n            &quot;PutRequest&quot;:{&quot;Item&quot;:{&quot;type&quot;:{&quot;S&quot;:&quot;test-\\($NUMBER)-Type_C&quot;},&quot;name&quot;:{ ...\r\n            &quot;PutRequest&quot;:{&quot;Item&quot;:{&quot;type&quot;:{&quot;S&quot;:&quot;test-\\($NUMBER)-Type_D&quot;},&quot;name&quot;:{ ...\r\n            &quot;PutRequest&quot;:{&quot;Item&quot;:{&quot;type&quot;:{&quot;S&quot;:&quot;test-\\($NUMBER)-Type_E&quot;},&quot;name&quot;:{ ...\r\n        }]\r\n    }\r\n\r\nNow something like your original attempt will work correctly. (Name your template `template.jq` to emphasize that it is not actually valid JSON.)\r\n\r\n    for ((counter=1 ; counter&lt;2 ;counter++ ))\r\n    do\r\n      JSON=$(jq -n -f template.jq --arg NUMBER &quot;$counter&quot;)\r\n      echo &quot;$JSON&quot;\r\n      #aws dynamodb batch-write-item --request-items &quot;${JSON}&quot;\r\n    done",
                "title": "insert bash variable into json using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1537497258,
        "creation_date": 1536563663,
        "last_edit_date": 1537497258,
        "question_id": 52252781,
        "body_markdown": "I am trying to fill JSON template with increasing counter to generate huge sample data set:\r\n\r\n    #!/bin/bash\r\n    for ((counter=1 ; counter&lt;2 ;counter++ ))\r\n    do\r\n      NUMBER=${counter}\r\n      JSON=$(cat template.json | jq --arg NUMBER &quot;$NUMBER&quot; &#39;.&#39;)\r\n      echo $JSON\r\n      #aws dynamodb batch-write-item --request-items &quot;${JSON}&quot;\r\n    done\r\n\r\nMy `template.json` looks like:\r\n\r\n    {\r\n    &quot;My_Table&quot;:[{\r\n        &quot;PutRequest&quot;:{&quot;Item&quot;:{&quot;type&quot;:{&quot;S&quot;:&quot;test-$NUMBER-Type_A&quot;},&quot;name&quot;:{ ...\r\n        &quot;PutRequest&quot;:{&quot;Item&quot;:{&quot;type&quot;:{&quot;S&quot;:&quot;test-$NUMBER-Type_A&quot;},&quot;name&quot;:{ ...\r\n        &quot;PutRequest&quot;:{&quot;Item&quot;:{&quot;type&quot;:{&quot;S&quot;:&quot;test-$NUMBER-Type_A&quot;},&quot;name&quot;:{ ...        \r\n        &quot;PutRequest&quot;:{&quot;Item&quot;:{&quot;type&quot;:{&quot;S&quot;:&quot;test-$NUMBER-Type_B&quot;},&quot;name&quot;:{ ...\r\n        &quot;PutRequest&quot;:{&quot;Item&quot;:{&quot;type&quot;:{&quot;S&quot;:&quot;test-$NUMBER-Type_B&quot;},&quot;name&quot;:{ ...\r\n        &quot;PutRequest&quot;:{&quot;Item&quot;:{&quot;type&quot;:{&quot;S&quot;:&quot;test-$NUMBER-Type_B&quot;},&quot;name&quot;:{ ...\r\n        &quot;PutRequest&quot;:{&quot;Item&quot;:{&quot;type&quot;:{&quot;S&quot;:&quot;test-$NUMBER-Type_C&quot;},&quot;name&quot;:{ ...\r\n        &quot;PutRequest&quot;:{&quot;Item&quot;:{&quot;type&quot;:{&quot;S&quot;:&quot;test-$NUMBER-Type_C&quot;},&quot;name&quot;:{ ...\r\n        &quot;PutRequest&quot;:{&quot;Item&quot;:{&quot;type&quot;:{&quot;S&quot;:&quot;test-$NUMBER-Type_D&quot;},&quot;name&quot;:{ ...\r\n        &quot;PutRequest&quot;:{&quot;Item&quot;:{&quot;type&quot;:{&quot;S&quot;:&quot;test-$NUMBER-Type_E&quot;},&quot;name&quot;:{ ...\r\n    }]\r\n}\r\n\r\nCan I get any clue to insert bash variable into JSON template?  I guess I am not doing correctly using `jq` here:\r\n\r\n`JSON=$(cat template.json | jq --arg NUMBER &quot;$NUMBER&quot; &#39;.&#39;)`\r\n\r\nEDIT\r\nMy desired output:\r\n\r\n    {\r\n    &quot;My_Table&quot;:[{\r\n        &quot;PutRequest&quot;:{&quot;Item&quot;:{&quot;type&quot;:{&quot;S&quot;:&quot;test-1-Type_A&quot;},&quot;name&quot;:{ ...\r\n        &quot;PutRequest&quot;:{&quot;Item&quot;:{&quot;type&quot;:{&quot;S&quot;:&quot;test-1-Type_A&quot;},&quot;name&quot;:{ ...\r\n        &quot;PutRequest&quot;:{&quot;Item&quot;:{&quot;type&quot;:{&quot;S&quot;:&quot;test-1-Type_A&quot;},&quot;name&quot;:{ ...        \r\n        &quot;PutRequest&quot;:{&quot;Item&quot;:{&quot;type&quot;:{&quot;S&quot;:&quot;test-1-Type_B&quot;},&quot;name&quot;:{ ...\r\n        &quot;PutRequest&quot;:{&quot;Item&quot;:{&quot;type&quot;:{&quot;S&quot;:&quot;test-1-Type_B&quot;},&quot;name&quot;:{ ...\r\n        &quot;PutRequest&quot;:{&quot;Item&quot;:{&quot;type&quot;:{&quot;S&quot;:&quot;test-1-Type_B&quot;},&quot;name&quot;:{ ...\r\n        &quot;PutRequest&quot;:{&quot;Item&quot;:{&quot;type&quot;:{&quot;S&quot;:&quot;test-1-Type_C&quot;},&quot;name&quot;:{ ...\r\n        &quot;PutRequest&quot;:{&quot;Item&quot;:{&quot;type&quot;:{&quot;S&quot;:&quot;test-1-Type_C&quot;},&quot;name&quot;:{ ...\r\n        &quot;PutRequest&quot;:{&quot;Item&quot;:{&quot;type&quot;:{&quot;S&quot;:&quot;test-1-Type_D&quot;},&quot;name&quot;:{ ...\r\n        &quot;PutRequest&quot;:{&quot;Item&quot;:{&quot;type&quot;:{&quot;S&quot;:&quot;test-1-Type_E&quot;},&quot;name&quot;:{ ...\r\n    }]\r\n}\r\n",
        "link": "https://stackoverflow.com/questions/52252781/insert-bash-variable-into-json-using-jq",
        "title": "insert bash variable into json using jq"
    },
    {
        "tags": [
            "json",
            "csv",
            "unix",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1536609251,
                "last_edit_date": 1536609251,
                "creation_date": 1536588661,
                "answer_id": 52259698,
                "question_id": 52256178,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You just have to construct an array of atomic values.  Since `.tags` is not atomic, in the following I&#39;ll assume (as suggested by @chepner) that we can use `.tags|join(&quot;,&quot;)`, though you might want to use something else, such as `.tags|@csv`:\r\n\r\n    [.event, .timestamp, (.tags | join(&quot;,&quot;))]\r\n    + (.data|[._id, .msisdn, .method, .url, .timeTaken, .channelID])\r\n    + [.pid]\r\n    | @tsv ",
                "title": "How to convert JSON to tsv using jq in unix?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1547073091,
        "creation_date": 1536576570,
        "last_edit_date": 1536615979,
        "question_id": 52256178,
        "body_markdown": "I need to convert this JSON to a TSV format. I&#39;ve a source file like this:\r\n\r\n\r\n    {\r\n      &quot;event&quot;: &quot;log&quot;,\r\n      &quot;timestamp&quot;: 1535306331840,\r\n      &quot;tags&quot;: [\r\n        &quot;info&quot;\r\n      ],\r\n      &quot;data&quot;: {\r\n        &quot;_id&quot;: &quot;A301180827005852329209020&quot;,\r\n        &quot;msisdn&quot;: &quot;6282134920902&quot;,\r\n        &quot;method&quot;: &quot;get&quot;,\r\n        &quot;url&quot;: &quot;/api/tcash/balance&quot;,\r\n        &quot;timeTaken&quot;: 32,\r\n        &quot;channelid&quot;: &quot;UX&quot;\r\n      },\r\n      &quot;pid&quot;: 7920\r\n    }\r\n\r\n\r\nThen I want to convert it to tsv which are consist of below column:\r\n\r\n    event, timestamp, tags, _id, msisdn, method, url, timeTaken, channelID, pid ",
        "link": "https://stackoverflow.com/questions/52256178/how-to-convert-json-to-tsv-using-jq-in-unix",
        "title": "How to convert JSON to tsv using jq in unix?"
    },
    {
        "tags": [
            "json",
            "bash",
            "parsing",
            "html-parsing",
            "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": 1536611662,
                "post_id": 52264863,
                "comment_id": 91478192,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6193512,
                    "reputation": 115,
                    "user_id": 4825565,
                    "user_type": "registered",
                    "profile_image": "https://lh6.googleusercontent.com/-PsCFT7yaoxM/AAAAAAAAAAI/AAAAAAAAAFs/d5Y5uOWVhSY/s256-rj/photo.jpg",
                    "display_name": "Sukh",
                    "link": "https://stackoverflow.com/users/4825565/sukh"
                },
                "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": 1536613019,
                "post_id": 52264863,
                "comment_id": 91478780,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6907073,
                    "reputation": 198,
                    "user_id": 5304495,
                    "user_type": "registered",
                    "profile_image": "https://graph.facebook.com/1302062531/picture?type=large",
                    "display_name": "Lucas Alonso",
                    "link": "https://stackoverflow.com/users/5304495/lucas-alonso"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1684198548,
                "post_id": 52264863,
                "comment_id": 134479178,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1536681355,
                "creation_date": 1536681355,
                "answer_id": 52279883,
                "question_id": 52264863,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The connection between the input JSON and the JSON that is said to be the desired output seems tenuous, but one way to solve the problem of tagging the objects with sequentially-numbered keys is to use the following function:\r\n\r\n    def tag(s):\r\n      reduce s as $x ({n:0, o:{}} ;\r\n        .n += 1\r\n        | .o += { (.n|tostring): $x})\r\n      | .o;\r\n     \r\nHere, `s` should be a stream of JSON entities, and the result is a single object with keys &quot;1&quot;, &quot;2&quot;, etc.\r\n\r\nSo the task now is to produce a stream of the desired objects.  Since it&#39;s unclear what you want, the following may be taken as illustrative.  \r\n\r\n    {date: first(.. | objects | select(.tag == &quot;time&quot; and has(&quot;text&quot;)) | .text)} as $date\r\n    | tag(.. \r\n          | objects\r\n          | select(has(&quot;title&quot;) and (has(&quot;children&quot;)|not) and .title == &quot;Album Title&quot;)\r\n          + $date )\r\n\r\n# Output\r\n\r\n    {\r\n      &quot;1&quot;: {\r\n        &quot;alt&quot;: &quot;Album Title - Artist Name - 1&quot;,\r\n        &quot;class&quot;: &quot;lazy image-under&quot;,\r\n        &quot;data-src&quot;: &quot;&quot;,\r\n        &quot;tag&quot;: &quot;img&quot;,\r\n        &quot;title&quot;: &quot;Album Title&quot;,\r\n        &quot;date&quot;: &quot;September 08, 2018&quot;\r\n      },\r\n      &quot;2&quot;: {\r\n        &quot;alt&quot;: &quot;Album Title - Artist Name - 2&quot;,\r\n        &quot;class&quot;: &quot;lazy image-under&quot;,\r\n        &quot;data-src&quot;: &quot;&quot;,\r\n        &quot;tag&quot;: &quot;img&quot;,\r\n        &quot;title&quot;: &quot;Album Title&quot;,\r\n        &quot;date&quot;: &quot;September 08, 2018&quot;\r\n      },\r\n      &quot;3&quot;: {\r\n        &quot;alt&quot;: &quot;Album Title - Artist Name - 3&quot;,\r\n        &quot;class&quot;: &quot;lazy image-under&quot;,\r\n        &quot;data-src&quot;: &quot;&quot;,\r\n        &quot;tag&quot;: &quot;img&quot;,\r\n        &quot;title&quot;: &quot;Album Title&quot;,\r\n        &quot;date&quot;: &quot;September 08, 2018&quot;\r\n      },\r\n      &quot;4&quot;: {\r\n        &quot;alt&quot;: &quot;Album Title - Artist Name - 4&quot;,\r\n        &quot;class&quot;: &quot;lazy image-under&quot;,\r\n        &quot;data-src&quot;: &quot;&quot;,\r\n        &quot;tag&quot;: &quot;img&quot;,\r\n        &quot;title&quot;: &quot;Album Title&quot;,\r\n        &quot;date&quot;: &quot;September 08, 2018&quot;\r\n      },\r\n      &quot;5&quot;: {\r\n        &quot;alt&quot;: &quot;Album Title - Artist Name - 5&quot;,\r\n        &quot;class&quot;: &quot;lazy image-under&quot;,\r\n        &quot;data-src&quot;: &quot;&quot;,\r\n        &quot;tag&quot;: &quot;img&quot;,\r\n        &quot;title&quot;: &quot;Album Title&quot;,\r\n        &quot;date&quot;: &quot;September 08, 2018&quot;\r\n      },\r\n      &quot;6&quot;: {\r\n        &quot;alt&quot;: &quot;Album Title&quot;,\r\n        &quot;class&quot;: &quot;lazy card-main-img&quot;,\r\n        &quot;data-src&quot;: &quot;&quot;,\r\n        &quot;tag&quot;: &quot;img&quot;,\r\n        &quot;title&quot;: &quot;Album Title&quot;,\r\n        &quot;date&quot;: &quot;September 08, 2018&quot;\r\n      },\r\n      &quot;7&quot;: {\r\n        &quot;data-trackid&quot;: &quot;scene-card-info-title Album Title &quot;,\r\n        &quot;href&quot;: &quot;/bhangra/album/view/2842847/title-of-album/&quot;,\r\n        &quot;tag&quot;: &quot;a&quot;,\r\n        &quot;text&quot;: &quot;Album Title&quot;,\r\n        &quot;title&quot;: &quot;Album Title&quot;,\r\n        &quot;date&quot;: &quot;September 08, 2018&quot;\r\n      }\r\n    }\r\n\r\n",
                "title": "Convert HTML to JSON using PUP / JQ &amp; extract data to a variable"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 5,
        "last_activity_date": 1536702105,
        "creation_date": 1536610509,
        "last_edit_date": 1536702105,
        "question_id": 52264863,
        "body_markdown": "I have HTML with data inside that I am trying to get matches for. I am using bash to achieve this and as its not possible to do I am running the HTML into PUP (as recommended here on StackOverflow), using PUP I am then extracting some of the schema however I am left with large json with data I dont need, I am then running sed commands to delete lines that I do not require. I am trying to find a way using JQ on only selecting the data I need so I dont need to run SED commands to delete unwanted lines.\r\n\r\nSo i run the command:-\r\n\r\n    cat test.html | pup &#39;div.scene json{}&#39; &gt; out.json\r\n\r\nThe below is generated.\r\n\r\n\r\n     [\r\n      {\r\n       &quot;children&quot;: [\r\n        {\r\n         &quot;children&quot;: [\r\n          {\r\n           &quot;class&quot;: &quot;icon-new active&quot;,\r\n           &quot;tag&quot;: &quot;div&quot;\r\n          },\r\n          {\r\n           &quot;children&quot;: [\r\n            {\r\n             &quot;children&quot;: [\r\n              {\r\n               &quot;alt&quot;: &quot;Album Title - Artist Name - 1&quot;,\r\n               &quot;class&quot;: &quot;lazy image-under&quot;,\r\n               &quot;data-src&quot;: &quot;&quot;,\r\n               &quot;tag&quot;: &quot;img&quot;,\r\n               &quot;title&quot;: &quot;Album Title&quot;\r\n              },\r\n              {\r\n               &quot;alt&quot;: &quot;Album Title - Artist Name - 2&quot;,\r\n               &quot;class&quot;: &quot;lazy image-under&quot;,\r\n               &quot;data-src&quot;: &quot;&quot;,\r\n               &quot;tag&quot;: &quot;img&quot;,\r\n               &quot;title&quot;: &quot;Album Title&quot;\r\n              },\r\n              {\r\n               &quot;alt&quot;: &quot;Album Title - Artist Name - 3&quot;,\r\n               &quot;class&quot;: &quot;lazy image-under&quot;,\r\n               &quot;data-src&quot;: &quot;&quot;,\r\n               &quot;tag&quot;: &quot;img&quot;,\r\n               &quot;title&quot;: &quot;Album Title&quot;\r\n              },\r\n              {\r\n               &quot;alt&quot;: &quot;Album Title - Artist Name - 4&quot;,\r\n               &quot;class&quot;: &quot;lazy image-under&quot;,\r\n               &quot;data-src&quot;: &quot;&quot;,\r\n               &quot;tag&quot;: &quot;img&quot;,\r\n               &quot;title&quot;: &quot;Album Title&quot;\r\n              },\r\n              {\r\n               &quot;alt&quot;: &quot;Album Title - Artist Name - 5&quot;,\r\n               &quot;class&quot;: &quot;lazy image-under&quot;,\r\n               &quot;data-src&quot;: &quot;&quot;,\r\n               &quot;tag&quot;: &quot;img&quot;,\r\n               &quot;title&quot;: &quot;Album Title&quot;\r\n              },\r\n              {\r\n               &quot;tag&quot;: &quot;span&quot;\r\n              },\r\n              {\r\n               &quot;tag&quot;: &quot;span&quot;\r\n              },\r\n              {\r\n               &quot;tag&quot;: &quot;span&quot;\r\n              },\r\n              {\r\n               &quot;tag&quot;: &quot;span&quot;\r\n              },\r\n              {\r\n               &quot;class&quot;: &quot;last&quot;,\r\n               &quot;tag&quot;: &quot;span&quot;\r\n              }\r\n             ],\r\n             &quot;class&quot;: &quot;sample-picker clearfix&quot;,\r\n             &quot;data-trackid&quot;: &quot;bhangra-tracking-id&quot;,\r\n             &quot;href&quot;: &quot;/bhangra/album/view/2842847/title-of-album/&quot;,\r\n             &quot;tag&quot;: &quot;a&quot;,\r\n             &quot;title&quot;: &quot;Album Title&quot;\r\n            }\r\n           ],\r\n           &quot;class&quot;: &quot;card-overlay&quot;,\r\n           &quot;tag&quot;: &quot;div&quot;\r\n          },\r\n          {\r\n           &quot;children&quot;: [\r\n           {\r\n             &quot;alt&quot;: &quot;Album Title&quot;,\r\n             &quot;class&quot;: &quot;lazy card-main-img&quot;,\r\n             &quot;data-src&quot;: &quot;&quot;,\r\n             &quot;tag&quot;: &quot;img&quot;,\r\n             &quot;title&quot;: &quot;Album Title&quot;\r\n            }\r\n           ],\r\n           &quot;data-trackid&quot;: &quot;bhangra-tracking-id  &quot;,\r\n           &quot;href&quot;: &quot;/bhangra/album/view/2842847/title-of-album/&quot;,\r\n           &quot;tag&quot;: &quot;a&quot;,\r\n           &quot;title&quot;: &quot;Album Title&quot;\r\n          }\r\n         ],\r\n         &quot;class&quot;: &quot;card-image&quot;,\r\n         &quot;tag&quot;: &quot;div&quot;\r\n        },\r\n        {\r\n         &quot;children&quot;: [\r\n          {\r\n           &quot;children&quot;: [\r\n            {\r\n             &quot;data-trackid&quot;: &quot;scene-card-info-title Album Title &quot;,\r\n             &quot;href&quot;: &quot;/bhangra/album/view/2842847/title-of-album/&quot;,\r\n             &quot;tag&quot;: &quot;a&quot;,\r\n             &quot;text&quot;: &quot;Album Title&quot;,\r\n             &quot;title&quot;: &quot;Album Title&quot;\r\n            }\r\n           ],\r\n           &quot;class&quot;: &quot;scene-card-title&quot;,\r\n           &quot;tag&quot;: &quot;div&quot;\r\n          },\r\n          {\r\n           &quot;children&quot;: [\r\n            {\r\n             &quot;data-trackid&quot;: &quot;scene-card-model name Artist Name modelid=1111 &quot;,\r\n             &quot;href&quot;: &quot;/bhangra/profile/view/2842847/artist-name/&quot;,\r\n             &quot;tag&quot;: &quot;a&quot;,\r\n             &quot;text&quot;: &quot;Artist Name&quot;,\r\n             &quot;title&quot;: &quot;Artist Name&quot;\r\n            }\r\n           ],\r\n           &quot;class&quot;: &quot;model-names&quot;,\r\n           &quot;tag&quot;: &quot;div&quot;\r\n          },\r\n          {\r\n           &quot;tag&quot;: &quot;time&quot;,\r\n           &quot;text&quot;: &quot;September 08, 2018&quot;\r\n          },\r\n          {\r\n           &quot;children&quot;: [\r\n            {\r\n             &quot;children&quot;: [\r\n              {\r\n               &quot;class&quot;: &quot;label-left-box&quot;,\r\n               &quot;tag&quot;: &quot;span&quot;,\r\n               &quot;text&quot;: &quot;Website Name&quot;\r\n              },\r\n              {\r\n               &quot;class&quot;: &quot;label-text&quot;,\r\n               &quot;tag&quot;: &quot;span&quot;,\r\n               &quot;text&quot;: &quot;Website URL&quot;\r\n              }\r\n             ],\r\n             &quot;class&quot;: &quot;collection label-small&quot;,\r\n             &quot;data-trackid&quot;: &quot;scene-card-collection&quot;,\r\n             &quot;href&quot;: &quot;/bhangra/main/id/url/&quot;,\r\n             &quot;tag&quot;: &quot;a&quot;,\r\n             &quot;title&quot;: &quot;Website URL&quot;\r\n            },\r\n            {\r\n             &quot;class&quot;: &quot;label-hd &quot;,\r\n             &quot;tag&quot;: &quot;span&quot;\r\n            },\r\n            {\r\n             &quot;children&quot;: [\r\n              {\r\n               &quot;children&quot;: [\r\n                {\r\n                 &quot;class&quot;: &quot;icons like-icon&quot;,\r\n                 &quot;tag&quot;: &quot;span&quot;\r\n                },\r\n                {\r\n                 &quot;class&quot;: &quot;like-amount&quot;,\r\n                 &quot;tag&quot;: &quot;var&quot;,\r\n                 &quot;text&quot;: &quot;0&quot;\r\n                }\r\n               ],\r\n               &quot;class&quot;: &quot;likes&quot;,\r\n               &quot;tag&quot;: &quot;span&quot;\r\n              },\r\n              {\r\n               &quot;children&quot;: [\r\n                {\r\n                 &quot;class&quot;: &quot;icons dislike-icon&quot;,\r\n                 &quot;tag&quot;: &quot;span&quot;\r\n                },\r\n                {\r\n                 &quot;class&quot;: &quot;dislike-amount&quot;,\r\n                 &quot;tag&quot;: &quot;var&quot;,\r\n                 &quot;text&quot;: &quot;0&quot;\r\n                }\r\n               ],\r\n               &quot;class&quot;: &quot;dislikes&quot;,\r\n               &quot;tag&quot;: &quot;span&quot;\r\n              }\r\n             ],\r\n             &quot;class&quot;: &quot;label-rating&quot;,\r\n             &quot;tag&quot;: &quot;span&quot;\r\n            }\r\n           ],\r\n           &quot;class&quot;: &quot;bhangra-information&quot;,\r\n           &quot;tag&quot;: &quot;div&quot;\r\n          }\r\n         ],\r\n         &quot;class&quot;: &quot;scene-card-info&quot;,\r\n         &quot;tag&quot;: &quot;div&quot;\r\n        }\r\n       ],\r\n       &quot;class&quot;: &quot;bhangra-card scene &quot;,\r\n       &quot;tag&quot;: &quot;div&quot;\r\n      }\r\n     ]\r\n\r\nI am then using JQ to return some details I want.\r\n\r\n     cat out.json | jq &#39;.[] | {&quot;1&quot;: .children[1].children[0].children, &quot;2&quot;: .children[1].children[1].children, &quot;date&quot;: .children[1].children[2].text}&#39;\r\n\r\nThis is returning back the below.\r\n\r\n     {\r\n       &quot;1&quot;: [\r\n         {\r\n           &quot;data-trackid&quot;: &quot;scene-card-info-title Album Title &quot;,\r\n           &quot;href&quot;: &quot;/bhangra/album/view/2842847/title-of-album/&quot;,\r\n           &quot;tag&quot;: &quot;a&quot;,\r\n           &quot;text&quot;: &quot;Album Title&quot;,\r\n           &quot;title&quot;: &quot;Album Title&quot;\r\n         }\r\n       ],\r\n       &quot;2&quot;: [\r\n         {\r\n           &quot;data-trackid&quot;: &quot;scene-card-model name Artist Name modelid=1111 &quot;,\r\n           &quot;href&quot;: &quot;/bhangra/profile/view/2842847/artist-name/&quot;,\r\n           &quot;tag&quot;: &quot;a&quot;,\r\n           &quot;text&quot;: &quot;Artist Name&quot;,\r\n           &quot;title&quot;: &quot;Artist Name&quot;\r\n         }\r\n       ],\r\n       &quot;date&quot;: &quot;September 08, 2018&quot;\r\n     }\r\n\r\nWith the above the next Album2 also has key&#39;s of 1 &amp; 2 followed by date, this results in the syntax being invalid and me not being able to target the data I want as the keys are all the same.\r\n\r\nIn order to fix this I am then running a bunch of sed commands to remove the lines that I don&#39;t need from the above.\r\n\r\nThe below is what I would like to be returned from my initial jq query but just unsure how I get this specific data returned.\r\n\r\n     { \r\n       &quot;1&quot; : {\r\n                &quot;album&quot;: &quot;Album Title&quot;,\r\n                &quot;href&quot;: &quot;/bhangra/album/view/2842847/title-of-album/&quot;,\r\n     \t\t    &quot;artist&quot;: &quot;Artist Name&quot;,\r\n     \t\t    &quot;date&quot;: &quot;September 08, 2018&quot;\r\n       },\r\n       &quot;2&quot; : {\r\n                &quot;album&quot;: &quot;Album1 Title&quot;,\r\n                &quot;href&quot;: &quot;/bhangra/album/view/2842847/title-of-album/&quot;,\r\n     \t\t    &quot;artist&quot;: &quot;Artist1 Name&quot;,\r\n     \t\t    &quot;date&quot;: &quot;September 08, 2018&quot;\r\n       },\r\n       &quot;3&quot; : {\r\n                &quot;album&quot;: &quot;Album2 Title&quot;,\r\n                &quot;href&quot;: &quot;/bhangra/album/view/2842847/title-of-album/&quot;,\r\n     \t\t    &quot;artist&quot;: &quot;Artist2 Name&quot;,\r\n     \t\t    &quot;date&quot;: &quot;September 09, 2018&quot;\r\n       }\r\n     }\r\n\r\nUPDATE EDIT 11/09/2018\r\n\r\nSo I have made some slight progress on this, using the below query I have managed to pull back the data I require however they are still separate arrays.\r\n\r\n     cat out.json | jq &#39;.[] | .children[1].children[0].children[], .children[1].children[1].children[], .children[1].children[2] | {WTF: .title, href, text}&#39;\r\n\r\nThis outputs the below which has got me slightly closer to what I want (above last example).\r\n\r\n     {\r\n       &quot;WTF&quot;: &quot;Album Title&quot;,\r\n       &quot;href&quot;: &quot;/bhangra/album/view/2842847/title-of-album/&quot;,\r\n       &quot;text&quot;: &quot;Album Title&quot;\r\n     }\r\n       &quot;WTF&quot;: &quot;Artist Name&quot;,\r\n       &quot;href&quot;: &quot;/bhangra/profile/view/2842847/artist-name/&quot;,\r\n       &quot;text&quot;: &quot;Artist Name&quot;\r\n     }\r\n     {\r\n       &quot;WTF&quot;: &quot;Null&quot;,\r\n       &quot;href&quot;: &quot;Null&quot;,\r\n       &quot;text&quot;: &quot;September 08, 2018&quot;\r\n     }",
        "link": "https://stackoverflow.com/questions/52264863/convert-html-to-json-using-pup-jq-extract-data-to-a-variable",
        "title": "Convert HTML to JSON using PUP / JQ &amp; extract data to a variable"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1536704648,
                "creation_date": 1536704648,
                "answer_id": 52284957,
                "question_id": 52284745,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Saving the json:\r\n\r\n    {\r\n        &quot;Names&quot;: [\r\n            { &quot;Name&quot;: &quot;A&quot;, &quot;Age&quot;: &quot;1&quot; },\r\n            { &quot;Name&quot;: &quot;B&quot;, &quot;Age&quot;: &quot;2&quot; },\r\n            { &quot;Name&quot;: &quot;C&quot;, &quot;Age&quot;: &quot;3&quot; }\r\n        ]\r\n    }\r\n\r\nas /tmp/input.txt I can run:\r\n\r\n    &lt;/tmp/input.txt jq --raw-output &#39;foreach .Names[] as $name ([];[];$name | .Name, .Age )&#39; \\\r\n    | while read -r name &amp;&amp; read -r age; do \r\n          printf &quot;My name is %s, I&#39;m %d years old.\\n&quot; &quot;$name&quot; &quot;$age&quot;; \r\n          printf -- &quot;--\\n&quot;;\r\n    done\r\n\r\nThe `--raw-output` with `| .Name, .Age` just prints two lines per .Names array member, one with name and another with age. Then I read two lines at a time with `while read &amp;&amp; read` and use that to loop through them.\r\n\r\nIf you rather have:\r\n\r\n    [&quot;A&quot;,&quot;1&quot;]\r\n    [&quot;B&quot;,&quot;2&quot;]\r\n    [&quot;C&quot;,&quot;3&quot;]\r\n\r\nthat&#39;s sad, the best would be to write a full parser that would take strings like `&quot;\\&quot;&quot;` into account. Anyway then you can:\r\n\r\n    &lt;/tmp/input2.txt sed &#39;s/^\\[//;s/\\]$//;&#39; \\\r\n    | while IFS=, read name age; do \r\n           name=${name%\\&quot;}; \r\n           name=${name#\\&quot;};   \r\n           age=${age%\\&quot;};\r\n           age=${age#\\&quot;};\r\n           printf &quot;My name is %s, I&#39;m %d years old.\\n&quot; &quot;$name&quot; &quot;$age&quot;;\r\n           printf -- &quot;--\\n&quot;;\r\n    done\r\n\r\nThe first sed removed the leading and enclosing `[` and `]` in each line. Then I read two strings separated by `,` (so vars like `&quot;a,b&quot;,&quot;c,d&quot;` will be read incorrectly). Then these two strings are stripped of leading and enclosing `&quot;`. Then the usuall printf is used to output the result.",
                "title": "How to manipulate a jq output using bash?"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1536705722,
                "creation_date": 1536705722,
                "answer_id": 52285090,
                "question_id": 52284745,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I have a written a simple script to achieve what you need:\r\n\r\nMy Json file `test.json` which is similar to your snippet:\r\n\r\n    {\r\n        &quot;Names&quot;: [\r\n            { &quot;Name&quot;: &quot;A&quot;, &quot;Age&quot;: &quot;1&quot; },\r\n            { &quot;Name&quot;: &quot;B&quot;, &quot;Age&quot;: &quot;2&quot; },\r\n            { &quot;Name&quot;: &quot;C&quot;, &quot;Age&quot;: &quot;3&quot; }\r\n        ]\r\n    }\r\n\r\nMy script:\r\n\r\n    #!/bin/bash\r\n    for i in $(cat test.json | jq -r &#39;.Names[] | @base64&#39;); do\r\n        _jq() {\r\n         echo ${i} | base64 --decode | jq -r ${1}\r\n        }\r\n       echo &quot;My Name is $(_jq &#39;.Name&#39;), I&#39;m $(_jq &#39;.Age&#39;) years old&quot;\r\n    done\r\n",
                "title": "How to manipulate a jq output using bash?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1536720984,
                "creation_date": 1536720984,
                "answer_id": 52286841,
                "question_id": 52284745,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Note that `foreach .Names[] as $name ([];[];$name | .Name, .Age )`\r\n can be simplified to:\r\n\r\n    .Names[] | ( .Name, .Age )\r\n\r\nor even in this specific case to:\r\n\r\n    .Names[][]\r\n\r\nor for that matter to:\r\n\r\n    .[][][]\r\n\r\n\r\nThe important point, however, is that `foreach` is not needed to achieve simple iteration.",
                "title": "How to manipulate a jq output using bash?"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1536720984,
        "creation_date": 1536703122,
        "question_id": 52284745,
        "body_markdown": "I have the following jq code snippet:\r\n\r\nhttps://jqplay.org/s/QzOttRHoz1\r\n\r\nI want to loop each element from the result array using bash such as the pseudo code shows:\r\n\r\n    #!/bin/bash\r\n    foreach result\r\n      print &quot;My name is {name}, I&#39;m {age} years old&quot;\r\n      print &quot;--&quot;\r\n\r\nThe result would be:\r\n\r\n    My name is A, I&#39;m 1 years old.\r\n    ---\r\n    My name is B, I&#39;m 2 years old.\r\n    ---\r\n    My name is C, I&#39;m 3 years old.\r\n    ---\r\n\r\nOf course this is a trivial example just to clarify that my goal is to manipulate each array from the jq result individually.\r\n\r\nAny suggestions on how to write the pseudo code into valid bash statements?",
        "link": "https://stackoverflow.com/questions/52284745/how-to-manipulate-a-jq-output-using-bash",
        "title": "How to manipulate a jq output using bash?"
    },
    {
        "tags": [
            "json",
            "object",
            "key",
            "command-line-interface",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 9,
                "is_accepted": false,
                "score": 9,
                "last_activity_date": 1536787179,
                "creation_date": 1536787179,
                "answer_id": 52303630,
                "question_id": 52303570,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using your approach, simply add `add` to your filter:\r\n\r\n    map( { (.name): .value } ) | add\r\n\r\n",
                "title": "Using jq, convert array of name/value pairs to object with named keys"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1683216676,
                "creation_date": 1683216676,
                "answer_id": 76175252,
                "question_id": 52303570,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This happens to be the exact use case for `from_entries`\r\n\r\n```bash\r\n$ echo &#39;[\r\n  {\r\n    &quot;name&quot; : &quot;A&quot;,\r\n    &quot;value&quot; : &quot;4&quot;\r\n  },\r\n  {\r\n    &quot;name&quot; : &quot;B&quot;,\r\n    &quot;value&quot; : &quot;2&quot;\r\n  },\r\n  {\r\n    &quot;name&quot; : &quot;C&quot;,\r\n    &quot;value&quot; : {\r\n      &quot;X&quot;: &quot;Something&quot;,\r\n      &quot;Y&quot;: &quot;Else&quot;\r\n    }\r\n  }\r\n]&#39; | jq &#39;from_entries&#39;\r\n```\r\n```json\r\n{\r\n  &quot;A&quot;: &quot;4&quot;,\r\n  &quot;B&quot;: &quot;2&quot;,\r\n  &quot;C&quot;: {\r\n    &quot;X&quot;: &quot;Something&quot;,\r\n    &quot;Y&quot;: &quot;Else&quot;\r\n  }\r\n}\r\n```\r\nSee: https://stedolan.github.io/jq/manual/v1.6/#to_entries,from_entries,with_entries (linking to `1.6` because it&#39;s the latest at the time of this writing, but `from_entries` has been available at least since `1.2`.)\r\n\r\nIn case you noticed `from_entries` already but thought it wouldn&#39;t work because your data has `name` instead of `key`, note this quote from the docs (linked above):\r\n\r\n&gt; `from_entries` accepts key, Key, name, Name, value and Value as keys.\r\n\r\nSo `name` works just fine, here.\r\n\r\nIf the use of `key` is acceptable, then (using `to_entries`) the reverse works also:\r\n\r\n```bash\r\necho &#39;{\r\n  &quot;A&quot;: &quot;4&quot;,\r\n  &quot;B&quot;: &quot;2&quot;,\r\n  &quot;C&quot;: {\r\n    &quot;X&quot;: &quot;Something&quot;,\r\n    &quot;Y&quot;: &quot;Else&quot;\r\n  }\r\n}&#39; | jq &#39;to_entries&#39;\r\n```\r\n```json\r\n[\r\n  {\r\n    &quot;key&quot;: &quot;A&quot;,\r\n    &quot;value&quot;: &quot;4&quot;\r\n  },\r\n  {\r\n    &quot;key&quot;: &quot;B&quot;,\r\n    &quot;value&quot;: &quot;2&quot;\r\n  },\r\n  {\r\n    &quot;key&quot;: &quot;C&quot;,\r\n    &quot;value&quot;: {\r\n      &quot;X&quot;: &quot;Something&quot;,\r\n      &quot;Y&quot;: &quot;Else&quot;\r\n    }\r\n  }\r\n]\r\n```\r\n",
                "title": "Using jq, convert array of name/value pairs to object with named keys"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 7,
        "last_activity_date": 1683216676,
        "creation_date": 1536786818,
        "question_id": 52303570,
        "body_markdown": "Given a json file in the format as :\r\n\r\n    [\r\n      {\r\n        &quot;name&quot; : &quot;A&quot;,\r\n        &quot;value&quot; : &quot;4&quot;\r\n      },\r\n      {\r\n        &quot;name&quot; : &quot;B&quot;,\r\n        &quot;value&quot; : &quot;2&quot;\r\n      },\r\n      {\r\n        &quot;name&quot; : &quot;C&quot;,\r\n        &quot;value&quot; : {\r\n          &quot;X&quot;: &quot;Something&quot;,\r\n          &quot;Y&quot;: &quot;Else&quot;\r\n        }\r\n      }\r\n    ]\r\n\r\nHow would I convert it to something like this using jq:\r\n\r\n    {\r\n      &quot;A&quot;: &quot;4&quot;,\r\n      &quot;B&quot;: &quot;2&quot;,\r\n      &quot;C&quot;: {\r\n        &quot;X&quot;: &quot;Something&quot;,\r\n        &quot;Y&quot;: &quot;Else&quot;\r\n      }\r\n    }\r\n\r\nI did come close using ` jq &#39;map( { (.name): .value } )` but that still leaves each object in its separate braces instead of having them all together.",
        "link": "https://stackoverflow.com/questions/52303570/using-jq-convert-array-of-name-value-pairs-to-object-with-named-keys",
        "title": "Using jq, convert array of name/value pairs to object with named keys"
    },
    {
        "tags": [
            "json",
            "jq",
            "parameterization"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1536803446,
                "last_edit_date": 1536803446,
                "creation_date": 1536802903,
                "answer_id": 52305510,
                "question_id": 52305343,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The following should be sufficient to get you on your way.\r\n\r\nFirst, let&#39;s assume the JSON is in a file name galaxy.json; second, let&#39;s assume the file galaxy.jq contains the following:\r\n\r\n    .Result[]\r\n    | select(.Coordinate | (.Galaxy==$galaxy and .System==$system and .Position==$position))\r\n\r\nThen the invocation:\r\n\r\n    jq -f so-galaxy.jq --argjson galaxy 1 --argjson system 22 --argjson position 3 galaxy.json\r\n\r\nwould yield the corresponding object:\r\n\r\n    {\r\n      &quot;ID&quot;: 123456,\r\n      &quot;Activity&quot;: 27,\r\n      &quot;Name&quot;: &quot;Example1&quot;,\r\n      &quot;Coordinate&quot;: {\r\n        &quot;Galaxy&quot;: 1,\r\n        &quot;System&quot;: 22,\r\n        &quot;Position&quot;: 3\r\n      },\r\n      &quot;Administrator&quot;: false,\r\n      &quot;Inactive&quot;: false,\r\n      &quot;Vacation&quot;: false,\r\n      &quot;HonorableTarget&quot;: false,\r\n      &quot;Debris&quot;: {\r\n        &quot;Metal&quot;: 0,\r\n        &quot;Crystal&quot;: 0,\r\n        &quot;RecyclersNeeded&quot;: 0\r\n      },\r\n      &quot;Moon&quot;: null,\r\n      &quot;Player&quot;: {\r\n        &quot;ID&quot;: 111111,\r\n        &quot;Name&quot;: &quot;foo&quot;,\r\n        &quot;Rank&quot;: 4\r\n      },\r\n      &quot;Alliance&quot;: null\r\n    }\r\n\r\n# Key: Value format\r\n\r\nIf you want the output to be in `key: value` format, simply add -r to the command-line options, and append the following to the jq filter:\r\n\r\n    | to_entries[]\r\n    | &quot;\\(.key): \\(.value)&quot;\r\n\r\n# Output\r\n\r\n    ID: 123456\r\n    Activity: 27\r\n    Name: Example1\r\n    Coordinate: {&quot;Galaxy&quot;:1,&quot;System&quot;:22,&quot;Position&quot;:3}\r\n    Administrator: false\r\n    Inactive: false\r\n    Vacation: false\r\n    HonorableTarget: false\r\n    Debris: {&quot;Metal&quot;:0,&quot;Crystal&quot;:0,&quot;RecyclersNeeded&quot;:0}\r\n    Moon: null\r\n    Player: {&quot;ID&quot;:111111,&quot;Name&quot;:&quot;foo&quot;,&quot;Rank&quot;:4}\r\n    Alliance: null\r\n\r\n\r\n",
                "title": "How to parse this file with jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1537443845,
        "creation_date": 1536801336,
        "last_edit_date": 1537443845,
        "question_id": 52305343,
        "body_markdown": "I just started using [tag:jq] and json files, and I&#39;m trying to parse a specific file.\r\nI&#39;m tring to do it with jq in command line, but if there&#39;s any other way to do it properly, I&#39;m in to give it a try.\r\n\r\nThe file itself looks like this : \r\n\r\n    {\r\n      &quot;Status&quot;: &quot;ok&quot;,\r\n      &quot;Code&quot;: 200,\r\n      &quot;Message&quot;: &quot;&quot;,\r\n      &quot;Result&quot;: [\r\n        {\r\n          &quot;ID&quot;: 123456,\r\n          &quot;Activity&quot;: 27,\r\n          &quot;Name&quot;: Example1&quot;,\r\n          &quot;Coordinate&quot;: {\r\n            &quot;Galaxy&quot;: 1,\r\n            &quot;System&quot;: 22,\r\n            &quot;Position&quot;: 3\r\n      },\r\n          &quot;Administrator&quot;: false,\r\n          &quot;Inactive&quot;: false,\r\n          &quot;Vacation&quot;: false,\r\n          &quot;HonorableTarget&quot;: false,\r\n          &quot;Debris&quot;: {\r\n            &quot;Metal&quot;: 0,\r\n            &quot;Crystal&quot;: 0,\r\n            &quot;RecyclersNeeded&quot;: 0\r\n          },\r\n          &quot;Moon&quot;: null,\r\n          &quot;Player&quot;: {\r\n            &quot;ID&quot;: 111111,\r\n            &quot;Name&quot;: &quot;foo&quot;,\r\n            &quot;Rank&quot;: 4\r\n          },\r\n          &quot;Alliance&quot;: null\r\n        },\r\n        {\r\n          &quot;ID&quot;: 223344,\r\n          &quot;Activity&quot;: 17,\r\n          &quot;Name&quot;: &quot;Example2&quot;,\r\n          &quot;Coordinate&quot;: {\r\n                &quot;Galaxy&quot;: 3,\r\n                &quot;System&quot;: 44,\r\n                &quot;Position&quot;: 5\r\n              },\r\n              &quot;Administrator&quot;: false,\r\n              &quot;Inactive&quot;: false,\r\n              &quot;Vacation&quot;: false,\r\n              &quot;StrongPlayer&quot;: false,\r\n              &quot;HonorableTarget&quot;: false,\r\n              &quot;Debris&quot;: {\r\n                &quot;Metal&quot;: 0,\r\n                &quot;Crystal&quot;: 0,\r\n                &quot;RecyclersNeeded&quot;: 0\r\n              },\r\n              &quot;Moon&quot;: null,\r\n              &quot;Player&quot;: {\r\n                &quot;ID&quot;: 765432,\r\n                &quot;Name&quot;: &quot;Player 2&quot;,\r\n                &quot;Rank&quot;: 3\r\n              },\r\n              &quot;Alliance&quot;: null\r\n            },\r\n      (...)\r\n      ]\r\n    }\r\n\r\nI would need to extract information based on the galaxy/system/position.\r\nFor example, having a script with the proper filters in it and execute something like that : \r\n\r\n    ./parser --galaxy=1 --system=22 --position=3\r\n\r\nAnd it would give me : \r\n\r\n    ID : 123456\r\n    Name : Example1\r\n    Activity : 27\r\n    ...\r\n\r\nI tried to do that with curl to grab my json file and jq to parse my file, but I have no idea how I can make that kind of request. \r\n",
        "link": "https://stackoverflow.com/questions/52305343/how-to-parse-this-file-with-jq",
        "title": "How to parse this file with jq?"
    },
    {
        "tags": [
            "json",
            "nested",
            "sum",
            "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": 1536876129,
                "post_id": 52321830,
                "comment_id": 91592279,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1536878011,
                "last_edit_date": 1536878011,
                "creation_date": 1536875975,
                "answer_id": 52322355,
                "question_id": 52321830,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "After fixing your JSON, the query:\r\n\r\n    jq &#39;[.. | objects | .avg_amount] | add&#39;\r\n\r\nyields `1099`.\r\n\r\n(This query is robust w.r.t. the existence of the key &quot;avg_amount&quot; as `add` handles `null` as 0.)\r\n\r\n# hjson\r\nIf fixing the JSON manually is an issue, you could (for example) use `hjson -j`.  See https://hjson.org/ ",
                "title": "How do I sum arbitrarily nested values with jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1536878011,
        "creation_date": 1536872877,
        "last_edit_date": 1536876525,
        "question_id": 52321830,
        "body_markdown": "I&#39;ve been struggling to come up with a way to sum arbitrarily nested fields with `jq`. The level of &quot;buckets&quot; varies between calls (different levels of rollup fields). So how would I sum all the `avg_amount` fields in the following snippet (ideally without hardcoding each `.buckets.[]`)?\r\n\r\n    [\r\n       {\r\n          &quot;buckets&quot;:[\r\n             {\r\n                &quot;buckets&quot;:[\r\n                   {\r\n                      &quot;buckets&quot;:[\r\n                         {\r\n                            &quot;avg_amount&quot;:25,\r\n                         }\r\n                      ],\r\n                      &quot;destination&quot;:&quot;Apple&quot;\r\n                   },\r\n                   {\r\n                      &quot;buckets&quot;:[\r\n                         {\r\n                            &quot;avg_amount&quot;:74,\r\n                         }\r\n                      ],\r\n                      &quot;destination&quot;:&quot;Google&quot;\r\n                   }\r\n                ],\r\n                &quot;vendor_name&quot;:&quot;Vendor Bee&quot;\r\n             },\r\n             {\r\n                &quot;buckets&quot;:[\r\n                   {\r\n                      &quot;buckets&quot;:[\r\n                         {\r\n                            &quot;avg_amount&quot;:1000,\r\n                         }\r\n                      ],\r\n                      &quot;destination&quot;:&quot;&quot;\r\n                   }\r\n                ],\r\n                &quot;vendor_name&quot;:&quot;&quot;\r\n             }\r\n          ],\r\n          &quot;company_id&quot;:1\r\n       }\r\n    ]\r\nThanks!",
        "link": "https://stackoverflow.com/questions/52321830/how-do-i-sum-arbitrarily-nested-values-with-jq",
        "title": "How do I sum arbitrarily nested values with jq?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1536897869,
                "creation_date": 1536897869,
                "answer_id": 52324822,
                "question_id": 52324497,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The simplest way to retain the key-value pair while making a selection based on the values is to use `with_entries`:\r\n\r\n    jq &#39;.userActivities\r\n    | with_entries(select(.value.localDate==&quot;2018-01-20&quot;))&#39; input.json\r\n\r\n# Output\r\n\r\n    {\r\n      &quot;L3ATSFGrpAYRkIIKqrh&quot;: {\r\n        &quot;deviceId&quot;: &quot;60ee32c2fae8dcf0&quot;,\r\n        &quot;dow&quot;: &quot;Friday&quot;,\r\n        &quot;localDate&quot;: &quot;2018-01-20&quot;\r\n      }\r\n    }\r\n\r\n",
                "title": "How to filter JSON using jq stream"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1536906260,
                "creation_date": 1536906260,
                "answer_id": 52326049,
                "question_id": 52324497,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "    jq -cn --stream &#39;fromstream(1|truncate_stream(inputs | select(.[0][] == &quot;userActivities&quot;))) | with_entries(select(.value.localDate==&quot;2018-01-19&quot;)) &#39; input.json\r\n\r\noutput: \r\n\r\n    {&quot;L3ATRosRdbDgSmX75Z&quot;:{&quot;deviceId&quot;:&quot;60ee32c2fae8dcf0&quot;,&quot;dow&quot;:&quot;Friday&quot;,&quot;localDate&quot;:&quot;2018-01-19&quot;}}\r\n\r\n\r\n\r\n",
                "title": "How to filter JSON using jq stream"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1536906260,
        "creation_date": 1536895078,
        "question_id": 52324497,
        "body_markdown": "I have a very large JSON file and the sample data looks like as:\r\n\r\n    {&quot;userActivities&quot;:{&quot;L3ATRosRdbDgSmX75Z&quot;:{&quot;deviceId&quot;:&quot;60ee32c2fae8dcf0&quot;,&quot;dow&quot;:&quot;Friday&quot;,&quot;localDate&quot;:&quot;2018-01-19&quot;},&quot;L3ATSFGrpAYRkIIKqrh&quot;:{&quot;deviceId&quot;:&quot;60ee32c2fae8dcf0&quot;,&quot;dow&quot;:&quot;Friday&quot;,&quot;localDate&quot;:&quot;2018-01-20&quot;}}}\r\n\r\nI need to put a filter on &quot;localDate&quot; field in jq stream such that the output looks like the following JSON as:\r\n\r\n    {&quot;L3ATSFGrpAYRkIIKqrh&quot;:{&quot;deviceId&quot;:&quot;60ee32c2fae8dcf0&quot;,&quot;dow&quot;:&quot;Friday&quot;,&quot;localDate&quot;:&quot;2018-01-19&quot;}}\r\n\r\nAny help/guidance is greatly appreciated!\r\n",
        "link": "https://stackoverflow.com/questions/52324497/how-to-filter-json-using-jq-stream",
        "title": "How to filter JSON using jq stream"
    },
    {
        "tags": [
            "json",
            "bigdata",
            "filtering",
            "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": 1536917492,
                "post_id": 52326989,
                "comment_id": 91604790,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 12951196,
                    "reputation": 477,
                    "user_id": 9363455,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/bf0c48c68e2d04ef6a3c4f8d1fd69b9b?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Sains",
                    "link": "https://stackoverflow.com/users/9363455/sains"
                },
                "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": 1536919648,
                "post_id": 52326989,
                "comment_id": 91606097,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1537239661,
                "last_edit_date": 1537239661,
                "creation_date": 1536921380,
                "answer_id": 52330230,
                "question_id": 52326989,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "From the [jq Cookbook][1], let&#39;s borrow `def atomize(s)`:\r\n\r\n    # Convert an object (presented in streaming form as the stream s) into\r\n    # a stream of single-key objects\r\n    # Examples:\r\n    #   atomize({a:1,b:2}|tostream)\r\n    #   atomize(inputs) (used in conjunction with &quot;jq -n --stream&quot;)\r\n    def atomize(s):\r\n      fromstream(foreach s as $in ( {previous:null, emit: null};\r\n          if ($in | length == 2) and ($in|.[0][0]) != .previous and .previous != null\r\n          then {emit: [[.previous]], previous: $in|.[0][0]}\r\n          else { previous: ($in|.[0][0]), emit: null}\r\n          end;\r\n          (.emit // empty), $in) ) ;\r\n\r\nSince the top-level object described by the OP contains just one key, we can select the August 2018 objects as follows:\r\n\r\n    atomize(1|truncate_stream(inputs))\r\n    | select( .[].localDate[0:7] == &quot;2018-08&quot;)\r\n\r\nIf you want these collected into a composite object, you might have to be careful about memory, so you might want to pipe the selected objects to another program (e.g. awk or jq). Otherwise, I&#39;d go with:\r\n\r\n    def add(s): reduce s as $x (null; .+$x);\r\n\r\n    {&quot;userActivities&quot;: add(\r\n        atomize(1|truncate_stream(inputs | select(.[0][0] == &quot;userActivities&quot;)))\r\n        | select( .[].localDate[0:7] ==&quot;2018-01&quot;) ) }\r\n\r\n\r\n## Variation\r\n\r\nIf the top-level object has more than one key, then the following variation would be appropriate:\r\n\r\n    atomize(1|truncate_stream(inputs | select(.[0][0] == &quot;userActivities&quot;)))\r\n    | select( .[].localDate[0:7] ==&quot;2018-08&quot;)\r\n\r\n  [1]: https://github.com/stedolan/jq/wiki/Cookbook\r\n",
                "title": "jq --stream filter on multiple values of same key"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1537239661,
        "creation_date": 1536910213,
        "last_edit_date": 1536921606,
        "question_id": 52326989,
        "body_markdown": "I am processing a very large JSON wherein I need to filter the inner JSON objects using a value of a key. My JSON looks like as follows:\r\n\r\n    {&quot;userActivities&quot;:{&quot;L3ATRosRdbDgSmX75Z&quot;:{&quot;deviceId&quot;:&quot;60ee32c2fae8dcf0&quot;,&quot;dow&quot;:&quot;Friday&quot;,&quot;localDate&quot;:&quot;2018-01-20&quot;},&quot;L3ATSFGrpAYRkIIKqrh&quot;:{&quot;deviceId&quot;:&quot;60ee32c2fae8dcf0&quot;,&quot;dow&quot;:&quot;Friday&quot;,&quot;localDate&quot;:&quot;2018-01-21&quot;},&quot;L3AVHvmReBBPNGluvHl&quot;:{&quot;deviceId&quot;:&quot;60ee32c2fae8dcf0&quot;,&quot;dow&quot;:&quot;Friday&quot;,&quot;localDate&quot;:&quot;2018-01-22&quot;},&quot;L3AVIcqaDpZxLf6ispK&quot;:{&quot;deviceId&quot;:&quot;60ee32c2fae8dcf0&quot;,&quot;dow&quot;:&quot;Friday,&quot;localDate&quot;:&quot;2018-01-19&quot;}}}\r\n\r\nI want to put a filter on localDate values such that localDate in 2018-01-20 or localDate in &quot;2018-01-21&quot; such that the output look like.\r\n\r\n    {&quot;userActivities&quot;:{&quot;L3ATRosRdbDgSmX75Z&quot;:{&quot;deviceId&quot;:&quot;60ee32c2fae8dcf0&quot;,&quot;dow&quot;:&quot;Friday&quot;,&quot;localDate&quot;:&quot;2018-01-20&quot;},&quot;L3ATSFGrpAYRkIIKqrh&quot;:{&quot;deviceId&quot;:&quot;60ee32c2fae8dcf0&quot;,&quot;dow&quot;:&quot;Friday&quot;,&quot;localDate&quot;:&quot;2018-01-21&quot;}}}\r\n\r\nI have asked a similar question here and realised that I need to put filter on multiple values and retain the original structure of JSON.\r\n\r\n    https://stackoverflow.com/questions/52324497/how-to-filter-json-using-jq-stream\r\n\r\nThanks a ton in advance!\r\n\r\n",
        "link": "https://stackoverflow.com/questions/52326989/jq-stream-filter-on-multiple-values-of-same-key",
        "title": "jq --stream filter on multiple values of same key"
    },
    {
        "tags": [
            "json",
            "linux",
            "bash",
            "sed",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 4879,
                    "reputation": 248190,
                    "user_id": 7552,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/b60298053f87465641c1b1192338c8cd?s=256&d=identicon&r=PG",
                    "display_name": "glenn jackman",
                    "link": "https://stackoverflow.com/users/7552/glenn-jackman"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1536946485,
                "post_id": 52336715,
                "comment_id": 91620764,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3752493,
                    "reputation": 1516,
                    "user_id": 3119675,
                    "user_type": "registered",
                    "accept_rate": 94,
                    "profile_image": "https://www.gravatar.com/avatar/6e2b365c744c31f78765f077e5ff4ed2?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "DomainsFeatured",
                    "link": "https://stackoverflow.com/users/3119675/domainsfeatured"
                },
                "reply_to_user": {
                    "account_id": 4879,
                    "reputation": 248190,
                    "user_id": 7552,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/b60298053f87465641c1b1192338c8cd?s=256&d=identicon&r=PG",
                    "display_name": "glenn jackman",
                    "link": "https://stackoverflow.com/users/7552/glenn-jackman"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1536948386,
                "post_id": 52336715,
                "comment_id": 91621598,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1536947920,
                "creation_date": 1536947920,
                "answer_id": 52337114,
                "question_id": 52336715,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`numbers` is an object, not just a array of keys. Just get the (unsorted) keys from that object.\r\n\r\n    .data.numbers | keys_unsorted[]\r\n\r\nYou will probably want to get the raw output as well so be sure to add the `-r` switch.",
                "title": "How To Filter Nested JSON Data Without Nested Ranges"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1536947920,
        "creation_date": 1536946041,
        "question_id": 52336715,
        "body_markdown": "I have the following code and I&#39;m trying to extract only the &quot;numbers&quot; using `jq`. I have researched various `jq` code examples. \r\n\r\nI tried different variation of code:\r\n\r\n`jq &#39;.data | .numbers&#39;` \r\n\r\nand \r\n\r\n`jq &#39;.data | .numbers[1:3]&#39;` \r\n\r\nbut I&#39;m unable to get just the numbers. \r\n\r\n    {\r\n    \tpage_size: 3,\r\n    \tdata: {\r\n    \t\tnumbers: {\r\n    \t\t\t+18459939294: {\r\n    \t\t\t\tstate: in_service,\r\n    \t\t\t\tfeatures: [e911, outbound_cnam, inbound_cnam],\r\n    \t\t\t\tfeatures_allowed: [],\r\n    \t\t\t\tfeatures_denied: [],\r\n    \t\t\t},\r\n    \t\t\t+12018986776: {\r\n    \t\t\t\tstate: in_service,\r\n    \t\t\t\tfeatures: [],\r\n    \t\t\t\tfeatures_allowed: [],\r\n    \t\t\t\tfeatures_denied: [],\r\n    \t\t\t},\r\n    \t\t\t+12120098763: {\r\n    \t\t\t\tstate: in_service,\r\n    \t\t\t\tfeatures: [],\r\n    \t\t\t\tfeatures_allowed: [],\r\n    \t\t\t\tfeatures_denied: [],\r\n    \t\t\t}\r\n    \t\t},\r\n    \t\tcasquade_quantity: 3\r\n    \t},\r\n    \trevision: 79807405987349087540983759804,\r\n    \ttimestamp: 2018 - 09 - 14T17: 07: 49,\r\n    \tversion: x.x.x,\r\n    \tnode: aojflksajflkmaMmiaonfsd,\r\n    \trequest_id: -098230-49823049-82309,\r\n    \tstatus: success,\r\n    }\r\n\r\nHow can I get the output:\r\n\r\n    +18459939294\r\n    +12018986776\r\n    +12120098763",
        "link": "https://stackoverflow.com/questions/52336715/how-to-filter-nested-json-data-without-nested-ranges",
        "title": "How To Filter Nested JSON Data Without Nested Ranges"
    },
    {
        "tags": [
            "arrays",
            "json",
            "edit",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1537203341,
                "creation_date": 1537203341,
                "answer_id": 52372501,
                "question_id": 52372349,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "After much fooling around, I think I got it:\r\n\r\n    cat tags.json | jq &#39;(.[] | select(.Key == &quot;role&quot;) | .Value) |= (. + &quot;- MY_SUFFIX&quot;)&#39;",
                "title": "Modify one value in array"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1537203876,
                "last_edit_date": 1537203876,
                "creation_date": 1537203553,
                "answer_id": 52372558,
                "question_id": 52372349,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Close indeed.  You could simply replace `.Value + &quot;-MY_SUFFIX&quot;` by\r\n\r\n\r\n    . + &quot;-MY_SUFFIX&quot;\r\n\r\n\r\nOr better yet, use `+=`, as in:  `... += &quot;-MY_SUFFIX&quot;`\r\n\r\nPersonally, I&#39;d use the filter:\r\n\r\n    map(if .Key == &quot;role&quot; then .Value += &quot;-MY_SUFFIX&quot; else . end)\r\n\r\n\r\n\r\n\r\n(Actually, the stated requirements would accord better with using the suffix `&quot;-MY-SUFFIX&quot;` :-)",
                "title": "Modify one value in array"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1537234624,
        "creation_date": 1537202659,
        "last_edit_date": 1537234624,
        "question_id": 52372349,
        "body_markdown": "This is VERY similar to https://stackoverflow.com/questions/29772676/update-one-value-in-array-of-dicts-using-jq\r\n\r\nI have a foo.json and I want to update AAA to AAA-MY-SUFFIX.\r\nBasically, I want to get the current value (AAA), and then add a suffix to it.\r\n\r\n```\r\n[\r\n  {\r\n    &quot;Key&quot;: &quot;Name&quot;,\r\n    &quot;Value&quot;: &quot;awesome&quot;\r\n  },\r\n  {\r\n    &quot;Key&quot;: &quot;role&quot;,\r\n    &quot;Value&quot;: &quot;AAA&quot;\r\n  }\r\n]\r\n```\r\n\r\nFrom the previous question, I can REPLACE the value of AAA using this:\r\n\r\n    cat foo.json | jq &#39;(.[] | select(.Key == &quot;role&quot;) | .Value) |= &quot;-MY_SUFFIX&quot;&#39;\r\n\r\nBut I want to APPEND a suffix to the existing value, not completely replace it.\r\n\r\nSomething like this (but it doesn&#39;t work, of course):\r\n\r\n    cat tags.json | jq &#39;(.[] | select(.Key == &quot;role&quot;) | .Value) |= .Value + &quot;-MY_SUFFIX&quot;&#39;\r\n\r\nI feel I&#39;m SO close, but I just can figure it out :(",
        "link": "https://stackoverflow.com/questions/52372349/modify-one-value-in-array",
        "title": "Modify one value in array"
    },
    {
        "tags": [
            "json",
            "bash",
            "shell",
            "jq",
            "backslash"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1537229016,
                "creation_date": 1537229016,
                "answer_id": 52377165,
                "question_id": 52376815,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`\\n` does not mean linefeed/newline in a bash double quoted string. It&#39;s just backslash+lowercase n.\r\n\r\nIf you use linefeeds instead of backslashes and Ns, they will encode the way you want:\r\n\r\n    textb=&quot;\r\n    1\r\n    2\r\n    3\r\n    4&quot;\r\n    jq -n --arg textb &quot;$textb&quot; &#39;.&quot;the string is:&quot; = $textb&#39;\r\n\r\noutputs:\r\n\r\n    {\r\n      &quot;the string is:&quot;: &quot;\\n1\\n2\\n3\\n4&quot;\r\n    }\r\n\r\nHere are few other equivalent ways of putting literal linefeeds into a bash variable:\r\n\r\n    textb=$&#39;\\n1\\n2\\n3\\n4&#39;\r\n    textb=$(printf &#39;\\n%s&#39; {1..4})",
                "title": "Jq variable add extra \\"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1537234875,
        "creation_date": 1537225892,
        "last_edit_date": 1537234875,
        "question_id": 52376815,
        "body_markdown": "Hi i have this bash code\r\n\r\n    #!/bin/bash\r\n    textb=&quot;\\n 1 \\n 2 \\n 3 \\n 4&quot;\r\n    jq  --arg textb &quot;$textb&quot; &#39;. | {plain_text: (  $textb +  desc.envi )&#39;\r\n\r\n When i  run the comand  this giveme the next example\r\n    \r\n  \r\n\r\n     #!/bin/bash\r\n        \\\\n1 \\\\n2 \\\\n3 \\\\n4\r\n\r\nWhy jq add and extra &quot;\\&quot;?  What i m going wrong?\r\nI try some like this \r\n\r\n    textb=&quot;\\n&quot; 1 &quot;\\n&quot; 2 &quot;\\n&quot; 3 &quot;\\n&quot; 4&quot;\r\n\r\nBut i  have this result\r\n \r\n\r\n    n1 n2 n3 n4\r\n\r\nThx",
        "link": "https://stackoverflow.com/questions/52376815/jq-variable-add-extra",
        "title": "Jq variable add extra \\"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq",
            "aws-cli"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6543722,
                    "reputation": 518,
                    "user_id": 5851645,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/e9oVt.png?s=256",
                    "display_name": "Ashutosh",
                    "link": "https://stackoverflow.com/users/5851645/ashutosh"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1537268902,
                "post_id": 52384260,
                "comment_id": 91714398,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5075932,
                    "reputation": 815,
                    "user_id": 4073304,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/YTtdo.jpg?s=256",
                    "display_name": "Parvez Kazi",
                    "link": "https://stackoverflow.com/users/4073304/parvez-kazi"
                },
                "reply_to_user": {
                    "account_id": 6543722,
                    "reputation": 518,
                    "user_id": 5851645,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/e9oVt.png?s=256",
                    "display_name": "Ashutosh",
                    "link": "https://stackoverflow.com/users/5851645/ashutosh"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1537271274,
                "post_id": 52384260,
                "comment_id": 91715931,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 6,
                "is_accepted": true,
                "score": 6,
                "last_activity_date": 1537270893,
                "creation_date": 1537270893,
                "answer_id": 52385816,
                "question_id": 52384260,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can try this:\r\n\r\n    jq &#39; .EventId + &quot;,&quot; + ([(.Resources[] | join(&quot;=&quot;))] | join(&quot;#&quot;))&#39; -r file\r\n    60a0490c,AWS::STS::AssumedRole=AutoScaling#AWS::IAM::Role=arn:aws:iam:autoscaling.amazonaws.com/AWSServiceRoleForAutoScaling\r\n\r\nTo use the second `join()`, just enclose the result in an array `[...]`.\r\n\r\nNote that the first key/value is not swapped as shown in your example (i.e. `Autoscaling` is the value and not the key).",
                "title": "Concatenate json array objects with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1537271911,
        "creation_date": 1537265688,
        "last_edit_date": 1537271911,
        "question_id": 52384260,
        "body_markdown": "I have below json file :\r\n\r\n    {\r\n    &quot;EventId&quot;: &quot;60a0490c&quot;,\r\n    &quot;Resources&quot;: [\r\n        {\r\n            &quot;ResourceType&quot;: &quot;AWS::STS::AssumedRole&quot;, \r\n            &quot;ResourceName&quot;: &quot;AutoScaling&quot;\r\n        }, \r\n        {\r\n            &quot;ResourceType&quot;: &quot;AWS::IAM::Role&quot;, \r\n            &quot;ResourceName&quot;: &quot;arn:aws:iam:autoscaling.amazonaws.com/AWSServiceRoleForAutoScaling&quot;\r\n        }\r\n        ]\r\n    }\r\n\r\nI want to concatenate the key-value pairs from Resources element, and output on single line as:\r\n\r\n    60a0490c,AutoScaling=AWS::STS::AssumedRole#AWS::IAM::Role=arn:aws:iam:autoscaling.amazonaws.com/AWSServiceRoleForAutoScaling\r\n\r\nI tried it as :\r\n\r\n    cat file.json | jq &#39;.EventId + &quot;,&quot; + (.Resources[] | join(&quot;=&quot;))&#39; -r\r\n\r\nIt gives me output as :\r\n\r\n    60a0490c,AutoScaling=AWS::STS::AssumedRole\r\n    60a0490c,AutoScaling=AWS::IAM::Role=arn:aws:iam:autoscaling.amazonaws.com/AWSServiceRoleForAutoScaling\r\n\r\nIt creates new entry for each key-value pair, I want it to be on single line with different delimeter (#)\r\n\r\nThanks in advance.\r\n\r\n",
        "link": "https://stackoverflow.com/questions/52384260/concatenate-json-array-objects-with-jq",
        "title": "Concatenate json array objects with jq"
    },
    {
        "tags": [
            "gitlab",
            "yaml",
            "jq",
            "gitlab-ci",
            "jfrog-cli"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 18610746,
                    "reputation": 302,
                    "user_id": 13563244,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/91ea053c1772423ae62a3da998d616e3?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "ddorsogna",
                    "link": "https://stackoverflow.com/users/13563244/ddorsogna"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1647288684,
                "post_id": 52388153,
                "comment_id": 126329570,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1549640768,
                "creation_date": 1549640768,
                "answer_id": 54595897,
                "question_id": 52388153,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is a working example of a job in a .gitlab-ci with a loop running on GNU/Linux OS and using Sh/Bash shell :\r\n\r\n    edit:\r\n      stage: edit\r\n      script:\r\n         - for file in  $(find ${CI_PROJECT_DIR} -type f -name deployment.yml)\r\n           do \r\n             CURRENT_IMAGE=$(grep &quot;image:&quot; $file | cut -d&#39;:&#39; -f2- | tr -d &#39;[:space:]&#39; | cut -d&#39;:&#39; -f3)\r\n             sed -ie &quot;s/$CURRENT_IMAGE/$VERSION/g&quot; &quot;$file&quot;\r\n           done\r\n      only:\r\n         - master\r\n\r\nI&#39;m not an expert on Gitlab-Runner on Windows but [Windows Batch][1] is default shell used but you can also use [Powershell][2].\r\n\r\n\r\n  [1]: https://docs.gitlab.com/runner/shells/#windows-batch\r\n  [2]: https://docs.gitlab.com/runner/shells/#powershell",
                "title": "GitLab CI syntax to write FOR loop statement?"
            },
            {
                "up_vote_count": 39,
                "is_accepted": false,
                "score": 39,
                "last_activity_date": 1648641088,
                "last_edit_date": 1648641088,
                "creation_date": 1553942273,
                "answer_id": 55430565,
                "question_id": 52388153,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Since there is still no good answer to this question, I will give it a try. I used this snippet to start multiple Docker builds for every directory in my repository. Notice the `|+` and the `&gt;` characters, which lets you put [multi-line commands in YAML][1] and are [part of GitLab syntax][2].\r\n\r\nLinux example:\r\n\r\n    build:\r\n      stage: loop\r\n      script:\r\n        - |+\r\n          for i in $(seq 1 3)\r\n          do\r\n            echo &quot;Hello $i&quot;\r\n          done\r\n\r\nWindows example:\r\n\r\n    build:\r\n      stage: loop\r\n      script:\r\n        - &gt;\r\n          setlocal enabledelayedexpansion\r\n          for %%a in (&quot;C:\\Test\\*.txt&quot;) do (\r\n            set FileName=%%~a\r\n            echo Filename is: !FileName!\r\n          )\r\n          endlocal\r\n\r\n\r\n  [1]: https://yaml-multiline.info/\r\n  [2]: https://forum.gitlab.com/t/for-loop-fails-in-giltlab-ci-yaml-with-bash-eval-line-85-syntax-error-unexpected-end-of-file-error-job-failed-exit-status-2/28721/2",
                "title": "GitLab CI syntax to write FOR loop statement?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": -3,
                "last_activity_date": 1565967670,
                "creation_date": 1565967670,
                "answer_id": 57526912,
                "question_id": 52388153,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "In .gitlab.yml anything you write under &quot;script&quot; is shell. Thus for loop will be same as it works in shell script.\r\n\r\n```\r\nfor var in ${NAME_1} ${NAME_2} ${NAME_3} ; do\r\n *----computations----*\r\ndone\r\n```",
                "title": "GitLab CI syntax to write FOR loop statement?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1739470120,
                "creation_date": 1739470120,
                "answer_id": 79437364,
                "question_id": 52388153,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "In my Yaml i have scripted in this way and it works to change repo variable using curl command:\r\n\r\n          - name: Stop Schedule Job &amp; Health Check\r\n        run: |\r\n            declare -A variables=(\r\n                [&quot;SCHEDULE_JOB&quot;]=false\r\n                [&quot;PAUSE_CHECK&quot;]=true\r\n              )\r\n          \r\n            for key in &quot;${!variables[@]}&quot;; do      \r\n              curl -X PATCH \\\r\n                -H &quot;Authorization: Bearer ${{ secrets.GH_TOKEN }}&quot; \\\r\n                -H &quot;Accept: application/vnd.github.v3+json&quot; \\\r\n                https://api.github.com/repos/${{ github.repository }}/actions/variables/$key \\\r\n                -d &quot;{\\&quot;value\\&quot;: \\&quot;${variables[$key]}\\&quot;}&quot;\r\n            done",
                "title": "GitLab CI syntax to write FOR loop statement?"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": 33,
        "last_activity_date": 1739470120,
        "creation_date": 1537278645,
        "last_edit_date": 1537348659,
        "question_id": 52388153,
        "body_markdown": "Below is the script mentioned in the gitlab-ci.yml file. This GitLab CI configuration is valid. But, when the CI/CD build is run, the job fails. Is it something to do with the FOR loop syntax? \r\n\r\n    deploy_dv:\r\n      stage: deploy_dv\r\n      variables:\r\n        GIT_STRATEGY: none\r\n    script:\r\n      - echo &quot;Deploying Artifacts...&quot;\r\n      - echo &quot;Configure JFrog CLI with parameters of your Artifactory instance&quot;\r\n      - &#39;c:\\build-tools\\JFROG-CLI\\jfrog rt config --url  %ARTIFACTORY_WEBSITE% --user %ARTIFACTORY_USER% --apikey %APIKEY%&#39;\r\n      - &#39;cd ..\\artifacts&#39;\r\n      - &#39;SETLOCAL ENABLEDELAYEDEXPANSION&#39;\r\n      - FOR %%i in (*) do (\r\n            &#39;c:\\build-tools\\curl\\bin\\curl.exe --header &quot;PRIVATE-TOKEN:%HCA_ACCESS_TOKEN%&quot; --insecure https://code.example.com/api/repository/tags/%CI_COMMIT_TAG% | c:\\build-tools\\jq\\jq-win64.exe &quot;.release.description&quot; &gt; temp.txt&#39;\r\n             &#39;set /p releasenote=&lt;temp.txt&#39;\r\n             &#39;rem del temp.txt&#39;\r\n             &#39;set mydate=%DATE:~6,4%-%DATE:~3,2%-%DATE:~0,2%&#39;\r\n             &#39;c:\\build-tools\\JFROG-CLI\\jfrog rt u &quot;%%i&quot; %ARTIFACTORY_ROOT_PATH%/%PROJECT_NAME%/%%i --build-name=%%i --build-number=%BUILDVERSION%  --props releasenote=%releasenote%;releaseversion=%BUILDVERSION%;releasedate=%mydate% --flat=false&#39;\r\n         )\r\n    \r\n        - &#39;%CURL% -X POST -F token=%REPOSITORY_TOKEN% -F ref=master  -F &quot;variables[RELEASE]=false&quot; -F &quot;variables[PROGRAM]=test&quot; --insecure https://code.example.com/api/repository/trigger&#39;\r\n    \r\n      only:\r\n      - /^(dv-)(\\d+\\.)(\\d+\\.)(\\d+)$/\r\nI get this below error:\r\n\r\n      $ echo &quot;Deploying Artifacts...&quot;\r\n    &quot;Deploying Artifacts...&quot;\r\n    $ echo &quot;Configure JFrog CLI with parameters of your Artifactory instance&quot;\r\n    &quot;Configure JFrog CLI with parameters of your Artifactory instance&quot;\r\n    $ c:\\build-tools\\JFROG-CLI\\jfrog rt config --url  %ARTIFACTORY_WEBSITE% --user %ARTIFACTORY_USER% --apikey %APIKEY%\r\n    Artifactory server ID [Default-Server]: $ cd ..\\artifacts\r\n    $ SETLOCAL ENABLEDELAYEDEXPANSION\r\n    $ FOR %%i in (*) do ( &#39;c:\\build-tools\\curl\\bin\\curl.exe --header &quot;PRIVATE-TOKEN:%HCA_ACCESS_TOKEN%&quot; --insecure  https://code.example.com/api/repository/tags/%CI_COMMIT_TAG% | c:\\build-tools\\jq\\jq-win64.exe &quot;.release.description&quot; &gt; temp.txt&#39; &#39;set /p releasenote=&lt;temp.txt&#39; &#39;rem del temp.txt&#39; &#39;set mydate=%DATE:~6,4%-%DATE:~3,2%-%DATE:~0,2%&#39; &#39;c:\\build-tools\\JFROG-CLI\\jfrog rt u &quot;%%i&quot; %ARTIFACTORY_ROOT_PATH%/%PROJECT_NAME%/%%i --build-name=%%i --build-number=%BUILDVERSION%  --props releasenote=%releasenote%;releaseversion=%BUILDVERSION%;releasedate=%mydate% --flat=false&#39; )\r\n    The filename, directory name, or volume label syntax is incorrect.\r\n    ERROR: Job failed: exit status 255",
        "link": "https://stackoverflow.com/questions/52388153/gitlab-ci-syntax-to-write-for-loop-statement",
        "title": "GitLab CI syntax to write FOR loop statement?"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq",
            "data-partitioning"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1537288691,
                "post_id": 52391042,
                "comment_id": 91727266,
                "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": 1537288735,
                "post_id": 52391042,
                "comment_id": 91727291,
                "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": 1537288856,
                "post_id": 52391042,
                "comment_id": 91727346,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 14371912,
                    "reputation": 13,
                    "user_id": 10381440,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/ce4ca32bb639e0925cedf65d14d59b01?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Tyler",
                    "link": "https://stackoverflow.com/users/10381440/tyler"
                },
                "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": 1537289260,
                "post_id": 52391042,
                "comment_id": 91727535,
                "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": 1537290013,
                "post_id": 52391042,
                "comment_id": 91727873,
                "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": 1537290417,
                "post_id": 52391042,
                "comment_id": 91728066,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1537301716,
                "last_edit_date": 1537301716,
                "creation_date": 1537289979,
                "answer_id": 52391409,
                "question_id": 52391042,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can do this with one copy of `jq` splitting out data items from the input file, and then another instance *per state* collating those data items together, with bash providing the glue. See the following example, for bash 4.2 or newer (might work with 4.1, I&#39;d need to check).\r\n\r\n    #!/usr/bin/env bash\r\n    case $BASH_VERSION in &#39;&#39;|[123].*|4.[01].*) echo &quot;ERROR: Bash 4.2 required&quot; &gt;&amp;2; exit 1;; esac\r\n\r\n    input_file=$1\r\n    [[ -s $input_file ]] || { echo &quot;Usage: ${0##*/} input-file&quot; &gt;&amp;2; exit 1; }\r\n\r\n    jq_split_script=&#39;\r\n    # modify this function to fit your needs\r\n    def relevantContentOnly:\r\n      { fipscode, level, polid, polnum, precinctsreporting, precinctsreportingpct, precinctstotal, raceid, runoff, statepostal, votecount, votepct, winner };\r\n\r\n    .[] | [.statename, (relevantContentOnly | tojson)] | @tsv\r\n    &#39;\r\n\r\n    # Use an associative array to map from state names to output FDs\r\n    declare -A out_fds=( )\r\n\r\n    # Read state / line-of-data pairs from our JQ script...\r\n    while IFS=$&#39;\\t&#39; read -r state data; do\r\n      # If we don&#39;t already have a writer for the current state, start one.\r\n      if [[ ! ${out_fds[$state]} ]]; then\r\n        exec {new_fd}&gt; &gt;(jq -n &#39;[inputs]&#39; &gt;&quot;$state.json&quot;)\r\n        out_fds[$state]=$new_fd\r\n      fi\r\n      # Regardless, send the data to the FD we have for this state\r\n      printf &#39;%s\\n&#39; &quot;$data&quot; &gt;&amp;${out_fds[$state]}\r\n    done &lt; &lt;(jq -rc &quot;$jq_split_script&quot; &lt;&quot;$input_file&quot;) # ...running the JQ script above.\r\n    \r\n    # close output FDs, so the JQ instances all flush\r\n    for fd in &quot;${!out_fds[@]}&quot;; do\r\n      exec {fd}&gt;&amp;-\r\n    done",
                "title": "jq: How can I pipe objects from array to different files based on data in object?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1537320400,
                "last_edit_date": 1537320400,
                "creation_date": 1537292537,
                "answer_id": 52392001,
                "question_id": 52391042,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a simple solution piggybacking on what you started with:\r\n\r\n    &lt; master.json jq -cn --stream &#39;fromstream(1|truncate_stream(inputs))&#39; |\r\n      jq -cr &#39;.statename, {\r\n        fipscode,\r\n        level,\r\n        polid,\r\n        polnum,\r\n        precinctsreporting,\r\n        precinctsreportingpct,\r\n        precinctstotal,\r\n        raceid,\r\n        runoff,\r\n        statepostal,\r\n        votecount,\r\n        votepct,\r\n        winner\r\n    }&#39; | while read -r statename &amp;&amp; read -r object\r\n    do\r\n      echo &quot;$object&quot; &gt;&gt; &quot;$statename.json&quot;\r\n    done\r\n\r\nNote that this will append the objects to any existing &quot;$statename.json&quot; files.  \r\n\r\nWith your [original] sample data, the above produces Arizona.json, Florida.json, and Oklahoma.json \r\n\r\n## Tweak\r\nIf the overhead in using `echo` is an issue, then you could use `awk`:\r\n\r\n    awk &#39;\r\n      fn!=&quot;&quot; {print &gt; fn; fn=&quot;&quot;; next}\r\n      {fn=$0 &quot;.json&quot;;\r\n       if (fns[fn]!=1){fns[fn]=1; print fn &gt; &quot;filenames.txt&quot;}}&#39;\r\n\r\n## Finale\r\n\r\nSince you want these files to contain arrays of objects, you could then use `jq -s` to achieve the final results.  I&#39;d probably collect the filenames within the `while` loop (naively, e.g. `echo &quot;$statename.json&quot; &gt;&gt; filenames.txt`), and then use `sponge`:\r\n\r\n    sort -u filenames.txt | \r\n      while read -r fn ; do \r\n        jq -s . &quot;$fn&quot; | sponge &quot;$fn&quot;\r\n      done\r\n",
                "title": "jq: How can I pipe objects from array to different files based on data in object?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1537445185,
        "creation_date": 1537288377,
        "last_edit_date": 1537445185,
        "question_id": 52391042,
        "body_markdown": "I have a large array of objects stored in a master JSON file. I want to loop through that array, take each object, and append it to a new file based on a field in the object (in this case, the state name). In other words, in a set of data containing many states, I want to filter it out to a file for each state.\r\n\r\nI&#39;m using an existing JQ expression to filter for only the data I actually need:\r\n\r\n    { fipscode: .fipscode, level: .level, polid: .polid, polnum: .polnum, precinctsreporting: .precinctsreporting, precinctsreportingpct: .precinctsreportingpct, precinctstotal: .precinctstotal, raceid: .raceid, runoff: .runoff, statepostal: .statepostal, votecount: .votecount, votepct: .votepct, winner: .winner }\r\n\r\nHere&#39;s a sample of my input:\r\n\r\n    [\r\n        { &quot;ballotorder&quot;: 2, &quot;candidateid&quot;: &quot;9718&quot;, &quot;delegatecount&quot;: 0, &quot;description&quot;: null, &quot;electiondate&quot;: &quot;2018-08-28&quot;, &quot;electtotal&quot;: 0, &quot;electwon&quot;: 0, &quot;fipscode&quot;: null, &quot;first&quot;: &quot;Doug&quot;, &quot;id&quot;: &quot;3015-polid-64364-state-AZ-1&quot;, &quot;incumbent&quot;: true, &quot;initialization_data&quot;: false, &quot;is_ballot_measure&quot;: false, &quot;last&quot;: &quot;Ducey&quot;, &quot;lastupdated&quot;: &quot;2018-08-30T00:01:38.897Z&quot;, &quot;level&quot;: &quot;state&quot;, &quot;national&quot;: true, &quot;officeid&quot;: &quot;G&quot;, &quot;officename&quot;: &quot;Governor&quot;, &quot;party&quot;: &quot;GOP&quot;, &quot;polid&quot;: &quot;64364&quot;, &quot;polnum&quot;: &quot;5554&quot;, &quot;precinctsreporting&quot;: 1488, &quot;precinctsreportingpct&quot;: 0.9993000000000001, &quot;precinctstotal&quot;: 1489, &quot;raceid&quot;: &quot;3015&quot;, &quot;racetype&quot;: &quot;Primary&quot;, &quot;racetypeid&quot;: &quot;R&quot;, &quot;reportingunitid&quot;: &quot;state-AZ-1&quot;, &quot;reportingunitname&quot;: null, &quot;runoff&quot;: false, &quot;seatname&quot;: null, &quot;seatnum&quot;: null, &quot;statename&quot;: &quot;Arizona&quot;, &quot;statepostal&quot;: &quot;AZ&quot;, &quot;test&quot;: false, &quot;uncontested&quot;: false, &quot;votecount&quot;: 355455, &quot;votepct&quot;: 0.705493, &quot;winner&quot;: true },\r\n        { &quot;ballotorder&quot;: 2, &quot;candidateid&quot;: &quot;21689&quot;, &quot;delegatecount&quot;: 0, &quot;description&quot;: null, &quot;electiondate&quot;: &quot;2018-08-28&quot;, &quot;electtotal&quot;: 0, &quot;electwon&quot;: 0, &quot;fipscode&quot;: null, &quot;first&quot;: &quot;Ron&quot;, &quot;id&quot;: &quot;10046-polid-62557-state-FL-1&quot;, &quot;incumbent&quot;: false, &quot;initialization_data&quot;: false, &quot;is_ballot_measure&quot;: false, &quot;last&quot;: &quot;DeSantis&quot;, &quot;lastupdated&quot;: &quot;2018-08-29T19:29:50.367Z&quot;, &quot;level&quot;: &quot;state&quot;, &quot;national&quot;: true, &quot;officeid&quot;: &quot;G&quot;, &quot;officename&quot;: &quot;Governor&quot;, &quot;party&quot;: &quot;GOP&quot;, &quot;polid&quot;: &quot;62557&quot;, &quot;polnum&quot;: &quot;13918&quot;, &quot;precinctsreporting&quot;: 5968, &quot;precinctsreportingpct&quot;: 1.0, &quot;precinctstotal&quot;: 5968, &quot;raceid&quot;: &quot;10046&quot;, &quot;racetype&quot;: &quot;Primary&quot;, &quot;racetypeid&quot;: &quot;R&quot;, &quot;reportingunitid&quot;: &quot;state-FL-1&quot;, &quot;reportingunitname&quot;: null, &quot;runoff&quot;: false, &quot;seatname&quot;: null, &quot;seatnum&quot;: null, &quot;statename&quot;: &quot;Florida&quot;, &quot;statepostal&quot;: &quot;FL&quot;, &quot;test&quot;: false, &quot;uncontested&quot;: false, &quot;votecount&quot;: 913997, &quot;votepct&quot;: 0.564728, &quot;winner&quot;: true },\r\n        { &quot;ballotorder&quot;: 2, &quot;candidateid&quot;: &quot;45555&quot;, &quot;delegatecount&quot;: 0, &quot;description&quot;: null, &quot;electiondate&quot;: &quot;2018-08-28&quot;, &quot;electtotal&quot;: 0, &quot;electwon&quot;: 0, &quot;fipscode&quot;: null, &quot;first&quot;: &quot;Rex&quot;, &quot;id&quot;: &quot;38538-polid-67011-state-OK-1&quot;, &quot;incumbent&quot;: false, &quot;initialization_data&quot;: false, &quot;is_ballot_measure&quot;: false, &quot;last&quot;: &quot;Lawhorn&quot;, &quot;lastupdated&quot;: &quot;2018-08-29T02:44:44.610Z&quot;, &quot;level&quot;: &quot;state&quot;, &quot;national&quot;: true, &quot;officeid&quot;: &quot;G&quot;, &quot;officename&quot;: &quot;Governor&quot;, &quot;party&quot;: &quot;Lib&quot;, &quot;polid&quot;: &quot;67011&quot;, &quot;polnum&quot;: &quot;40784&quot;, &quot;precinctsreporting&quot;: 1951, &quot;precinctsreportingpct&quot;: 1.0, &quot;precinctstotal&quot;: 1951, &quot;raceid&quot;: &quot;38538&quot;, &quot;racetype&quot;: &quot;Runoff&quot;, &quot;racetypeid&quot;: &quot;L&quot;, &quot;reportingunitid&quot;: &quot;state-OK-1&quot;, &quot;reportingunitname&quot;: null, &quot;runoff&quot;: false, &quot;seatname&quot;: null, &quot;seatnum&quot;: null, &quot;statename&quot;: &quot;Oklahoma&quot;, &quot;statepostal&quot;: &quot;OK&quot;, &quot;test&quot;: false, &quot;uncontested&quot;: false, &quot;votecount&quot;: 379, &quot;votepct&quot;: 0.409287, &quot;winner&quot;: false }\r\n    ]\r\n\r\nAs output, I would expect to have a `Arizona.json` containing only the item(s) from that state, and also filtered to remove unwanted fields:\r\n\r\n    [\r\n      { &quot;fipscode&quot;: null, &quot;level&quot;: &quot;state&quot;, &quot;polid&quot;: &quot;64364&quot;, &quot;polnum&quot;: &quot;5554&quot;, &quot;precinctsreporting&quot;: 1488, &quot;precinctsreportingpct&quot;: 0.9993000000000001, &quot;precinctstotal&quot;: 1489, &quot;raceid&quot;: &quot;3015&quot;, &quot;runoff&quot;: false, &quot;statepostal&quot;: &quot;AZ&quot;, &quot;votecount&quot;: 355455, &quot;votepct&quot;: 0.705493, &quot;winner&quot;: true }\r\n    ]\r\n\r\n...and likewise for the other states involved (`Florida.json` and `Oklahoma.json`).\r\n\r\n---\r\n\r\nHere&#39;s the bash and jq script I have so far:\r\n\r\n    cat master.json |\r\n    jq -cn --stream &#39;fromstream(1|truncate_stream(inputs))&#39; |\r\n    jq -c &#39;.statename as $state | {\r\n        fipscode: .fipscode,\r\n        level: .level,\r\n        polid: .polid,\r\n        polnum: .polnum,\r\n        precinctsreporting: .precinctsreporting,\r\n        precinctsreportingpct: .precinctsreportingpct,\r\n        precinctstotal: .precinctstotal,\r\n        raceid: .raceid,\r\n        runoff: .runoff,\r\n        statepostal: .statepostal,\r\n        votecount: .votecount,\r\n        votepct: .votepct,\r\n        winner: .winner\r\n    }&#39;\r\n\r\nWhat I can&#39;t figure out is how to intercept each row so I can determine where the output should go. Is this possible?\r\n\r\n",
        "link": "https://stackoverflow.com/questions/52391042/jq-how-can-i-pipe-objects-from-array-to-different-files-based-on-data-in-object",
        "title": "jq: How can I pipe objects from array to different files based on data in object?"
    },
    {
        "tags": [
            "bash",
            "shell",
            "command",
            "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": 1,
                "creation_date": 1537290654,
                "post_id": 52391547,
                "comment_id": 91728174,
                "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": 1537290753,
                "post_id": 52391547,
                "comment_id": 91728215,
                "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": 1537290818,
                "post_id": 52391547,
                "comment_id": 91728244,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 47502,
                    "reputation": 213658,
                    "user_id": 140750,
                    "user_type": "registered",
                    "accept_rate": 92,
                    "profile_image": "https://www.gravatar.com/avatar/4c7af12cad08c95bc206a9636d164224?s=256&d=identicon&r=PG",
                    "display_name": "William Pursell",
                    "link": "https://stackoverflow.com/users/140750/william-pursell"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1537290933,
                "post_id": 52391547,
                "comment_id": 91728289,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 47502,
                    "reputation": 213658,
                    "user_id": 140750,
                    "user_type": "registered",
                    "accept_rate": 92,
                    "profile_image": "https://www.gravatar.com/avatar/4c7af12cad08c95bc206a9636d164224?s=256&d=identicon&r=PG",
                    "display_name": "William Pursell",
                    "link": "https://stackoverflow.com/users/140750/william-pursell"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1537291031,
                "post_id": 52391547,
                "comment_id": 91728329,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 13955929,
                    "reputation": 21,
                    "user_id": 10078321,
                    "user_type": "registered",
                    "profile_image": "https://graph.facebook.com/2223566354326969/picture?type=large",
                    "display_name": "Jess",
                    "link": "https://stackoverflow.com/users/10078321/jess"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1537295173,
                "post_id": 52391547,
                "comment_id": 91730205,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1537300507,
                "creation_date": 1537300507,
                "answer_id": 52393720,
                "question_id": 52391547,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I  found the solution   whit this code\r\n \r\n\r\n        else\r\n    VAR1=$(head -n 1 ${fname}.ml)\r\n    IFS=&quot;,&quot; read -ra images &lt;&lt;&lt; &quot;$VAR1&quot;\r\n    \r\n    \r\n     echo  que ha y $images\r\n\r\nThx alot to Barmar and William",
                "title": "Bash Find File check IF and execute"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1537300507,
        "creation_date": 1537290541,
        "last_edit_date": 1537290989,
        "question_id": 52391547,
        "body_markdown": "i have this files\r\n\r\n    1.json2    - 2.json2    - 3.json2\r\n    1.json2.ml - 2.json2.ml -\r\n\r\nExample  ml file\r\n\r\n    1.json2.ml\r\n    {&quot;message&quot;:&quot;Validation error&quot;,&quot;error&quot;:&quot;validation_error&quot;,...\r\n \r\n    2.json2.ml\r\n    {&quot;Ok&quot;:&quot;OK&quot;:&quot;OK&quot;...}\r\n \r\nI want  to search  if  *.json2.ml isnt execute a post and save.\r\nIf the  file exist  look if error is there and  execute  Post.\r\n\r\nHere is the code i use for this\r\n\r\n       find . -type f -name &#39;*.json2&#39; | xargs bash -c &#39;for fname\r\n    do if [ ! -e ${fname}.ml ]\r\n    then curl -X POST -H &quot;Content-Type: application/json&quot; -d @${fname} https://web/api/post &gt; ${fname}.ml  \r\n    \r\n    \r\n    else\r\n    \r\n    sed &#39;1d&#39; ${fname}.ml  | while read line\r\n    do\r\n    FS=&#39;,&#39; read pid pname\r\n    if [ &quot;$var&quot; -e &quot;&quot;error&quot;:&quot;validation_error&quot;&quot; ] \r\n    then \r\n    curl -X POST -H &quot;Content-Type: application/json&quot; -d @${fname} https://web/api/post &gt; ${fname}.ml\r\n     echo  que ha y $pname\r\n    \r\n    \r\n    fi\r\n    \r\n    done\r\n    \r\n    &#39; bash\r\n\r\nI have this result\r\n\r\n    syntax error near unexpected token `fi&#39;\r\n\r\n\r\nWhat is the expected result\r\n\r\n    1 - Post  3.json2 ( file .ml no exist )\r\n    2-  Post  1.json2 ( File .ml exist and  have error in )\r\n    3- 2.json2 and  3.json2 ( do nothing because json2.ml is OK)\r\n    \r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/52391547/bash-find-file-check-if-and-execute",
        "title": "Bash Find File check IF and execute"
    },
    {
        "tags": [
            "bash",
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1537340488,
                "post_id": 52399819,
                "comment_id": 91743892,
                "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": 3,
                "creation_date": 1537340683,
                "post_id": 52399819,
                "comment_id": 91743986,
                "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": 1,
                "creation_date": 1537342218,
                "post_id": 52399819,
                "comment_id": 91744765,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 32384,
                    "reputation": 127026,
                    "user_id": 89817,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/df253c3b6533949ea94f31f328f3e769?s=256&d=identicon&r=PG",
                    "display_name": "Gordon Davisson",
                    "link": "https://stackoverflow.com/users/89817/gordon-davisson"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1537342881,
                "post_id": 52399819,
                "comment_id": 91745134,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1039443,
                    "reputation": 6753,
                    "user_id": 1293013,
                    "user_type": "registered",
                    "accept_rate": 85,
                    "profile_image": "https://i.sstatic.net/9oztA.jpg?s=256",
                    "display_name": "Raja G",
                    "link": "https://stackoverflow.com/users/1293013/raja-g"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1537343338,
                "post_id": 52399819,
                "comment_id": 91745379,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2177344,
                    "reputation": 3128,
                    "user_id": 1927695,
                    "user_type": "registered",
                    "accept_rate": 55,
                    "profile_image": "https://i.sstatic.net/QMEM1.png?s=256",
                    "display_name": "hpaknia",
                    "link": "https://stackoverflow.com/users/1927695/hpaknia"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1537343610,
                "post_id": 52399819,
                "comment_id": 91745522,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2177344,
                    "reputation": 3128,
                    "user_id": 1927695,
                    "user_type": "registered",
                    "accept_rate": 55,
                    "profile_image": "https://i.sstatic.net/QMEM1.png?s=256",
                    "display_name": "hpaknia",
                    "link": "https://stackoverflow.com/users/1927695/hpaknia"
                },
                "reply_to_user": {
                    "account_id": 468289,
                    "reputation": 190915,
                    "user_id": 874188,
                    "user_type": "registered",
                    "accept_rate": 62,
                    "profile_image": "https://www.gravatar.com/avatar/091f411d57db5be8298e057a32e5ad72?s=256&d=identicon&r=PG",
                    "display_name": "tripleee",
                    "link": "https://stackoverflow.com/users/874188/tripleee"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1537345278,
                "post_id": 52399819,
                "comment_id": 91746428,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 468289,
                    "reputation": 190915,
                    "user_id": 874188,
                    "user_type": "registered",
                    "accept_rate": 62,
                    "profile_image": "https://www.gravatar.com/avatar/091f411d57db5be8298e057a32e5ad72?s=256&d=identicon&r=PG",
                    "display_name": "tripleee",
                    "link": "https://stackoverflow.com/users/874188/tripleee"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1537345399,
                "post_id": 52399819,
                "comment_id": 91746497,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1343699,
                    "reputation": 91,
                    "user_id": 1284837,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/2667dfba05380059f44a6f259c3a8277?s=256&d=identicon&r=PG",
                    "display_name": "DidierH",
                    "link": "https://stackoverflow.com/users/1284837/didierh"
                },
                "edited": false,
                "score": 5,
                "creation_date": 1568969370,
                "post_id": 52399819,
                "comment_id": 102452276,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 301110,
                    "reputation": 103185,
                    "user_id": 608639,
                    "user_type": "registered",
                    "accept_rate": 64,
                    "profile_image": "https://i.sstatic.net/aPIhh.jpg?s=256",
                    "display_name": "jww",
                    "link": "https://stackoverflow.com/users/608639/jww"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1577024867,
                "post_id": 52399819,
                "comment_id": 105072841,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2177344,
                    "reputation": 3128,
                    "user_id": 1927695,
                    "user_type": "registered",
                    "accept_rate": 55,
                    "profile_image": "https://i.sstatic.net/QMEM1.png?s=256",
                    "display_name": "hpaknia",
                    "link": "https://stackoverflow.com/users/1927695/hpaknia"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1593717238,
                "post_id": 52399819,
                "comment_id": 110885625,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1268682,
                    "reputation": 1958,
                    "user_id": 1225434,
                    "user_type": "registered",
                    "accept_rate": 75,
                    "profile_image": "https://www.gravatar.com/avatar/a68b1b3b26070d23b5027d71a3bffdf8?s=256&d=identicon&r=PG",
                    "display_name": "Wil",
                    "link": "https://stackoverflow.com/users/1225434/wil"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1600255438,
                "post_id": 52399819,
                "comment_id": 113028401,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2133031,
                    "reputation": 1275,
                    "user_id": 1893392,
                    "user_type": "registered",
                    "accept_rate": 50,
                    "profile_image": "https://www.gravatar.com/avatar/655d7dfc6a0bef43a175bcca278feaba?s=256&d=identicon&r=PG",
                    "display_name": "Joseph Ishak",
                    "link": "https://stackoverflow.com/users/1893392/joseph-ishak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1600814995,
                "post_id": 52399819,
                "comment_id": 113205915,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 881137,
                    "reputation": 111,
                    "user_id": 224659,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/a1745ebc29c933bbdd48bc4583bc5d86?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Johan Bergens",
                    "link": "https://stackoverflow.com/users/224659/johan-bergens"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1610006051,
                "post_id": 52399819,
                "comment_id": 115997919,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1109961,
                    "reputation": 393,
                    "user_id": 1100614,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/WUKbM.jpg?s=256",
                    "display_name": "Martin von Wittich",
                    "link": "https://stackoverflow.com/users/1100614/martin-von-wittich"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1620317478,
                "post_id": 52399819,
                "comment_id": 119171430,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1109961,
                    "reputation": 393,
                    "user_id": 1100614,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/WUKbM.jpg?s=256",
                    "display_name": "Martin von Wittich",
                    "link": "https://stackoverflow.com/users/1100614/martin-von-wittich"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1620317897,
                "post_id": 52399819,
                "comment_id": 119171622,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 461373,
                    "reputation": 118,
                    "user_id": 863028,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/36bc6d061c1a62d63148e27725436338?s=256&d=identicon&r=PG",
                    "display_name": "pawrog",
                    "link": "https://stackoverflow.com/users/863028/pawrog"
                },
                "edited": false,
                "score": 6,
                "creation_date": 1622306279,
                "post_id": 52399819,
                "comment_id": 119757719,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 37,
        "last_activity_date": 1645533525,
        "creation_date": 1537339930,
        "last_edit_date": 1645533525,
        "question_id": 52399819,
        "body_markdown": "I have a function like:\r\n\r\n    getServers() {\r\n        curl -s -X GET ...\r\n    }\r\n\r\nThe output is a complex JSON string. I can parse the JSON like this:\r\n\r\n    serverId=$(getServers | jq -r &quot;.[] | select(whatever...)&quot;)\r\n    echo $serverId\r\n\r\nBut if I store the output of the function call in a variable, I get an error:\r\n\r\n    servers=$(getServers)\r\n    echo $servers | jq .\r\n    # jq can not process this\r\n    # parse error: Invalid string: control characters from U+0000 through             \r\n    echo &quot;$servers&quot; | jq .\r\n    # does not work either\r\nU+001F must be escaped at line ...\r\n\r\nEven though I `$servers` contain the same value as function call, `jq` fails to process it. What&#39;s happening here?\r\n\r\n&gt; $ jq --version    \r\n&gt; jq-1.5\r\n\r\n&lt;br&gt;\r\n\r\nThis is not a duplicate question! This issue roots in existence of `\\r\\n` in the string. Adding quotes does not fix the problem.\r\n\r\n\r\n## Answer\r\nPipe the string into `tr &#39;\\r\\n&#39; &#39; &#39;`:\r\n\r\n    servers=$(getServers)\r\n    echo $servers | tr &#39;\\r\\n&#39; &#39; &#39; | jq .\r\n\r\nThis script and its output show how adding `&quot;` does not fix the problem, but `tr` does:\r\n\r\n    #!/bin/env bash\r\n    \r\n    get() {\r\n        x=$&#39;multi\\r\\nline&#39;\r\n        echo $x\r\n    }\r\n    \r\n    \r\n    g=$(get)\r\n    \r\n    echo &#39;Without &quot;&#39;\r\n    echo $g\r\n    echo &#39;With &quot;&#39;\r\n    echo &quot;$g&quot;\r\n    echo &#39;With tr&#39;\r\n    echo $g | tr &#39;\\r\\n&#39; &#39;\\n&#39;\r\n\r\nOutput:\r\n\r\n    Without &quot;\r\n     line\r\n    With &quot;\r\n     line\r\n    With tr\r\n    multi\r\n     line\r\n\r\nI hope community votes to reopen this question.\r\n",
        "link": "https://stackoverflow.com/questions/52399819/invalid-string-control-characters-from-u0000-through-u001f-must-be-escaped-us",
        "title": "Invalid string: control characters from U+0000 through U+001F must be escaped using Bash?"
    },
    {
        "tags": [
            "json",
            "regex",
            "sed",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1007076,
                    "reputation": 48901,
                    "user_id": 1020526,
                    "user_type": "registered",
                    "accept_rate": 73,
                    "profile_image": "https://i.sstatic.net/Scjj8.jpg?s=256",
                    "display_name": "revo",
                    "link": "https://stackoverflow.com/users/1020526/revo"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1537357062,
                "post_id": 52404988,
                "comment_id": 91753668,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1537357421,
                "creation_date": 1537357421,
                "answer_id": 52405100,
                "question_id": 52404988,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use `jq` json parser!\r\n\r\n    jq &#39;.servers[].server_url=&quot;application2_server.com&quot;&#39; file",
                "title": "sed for dictionary keyword"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1537444639,
        "creation_date": 1537357004,
        "last_edit_date": 1537444639,
        "question_id": 52404988,
        "body_markdown": "My json looks as below\r\n\r\n&gt; {&quot;servers&quot;: \r\n [{&quot;server_type&quot;:&quot;application_server&quot;,&quot;server_url&quot;:&quot;application_server.com&quot;},{&quot;server_type&quot;:&quot;relay_server&quot;,&quot;server_url&quot;:&quot;application_server.com&quot;}] }\r\n\r\nI need to replace server_url ( **application_server.com** ) to a different value say (**application2_server.com**) using sed or any  regex .\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/52404988/sed-for-dictionary-keyword",
        "title": "sed for dictionary keyword"
    },
    {
        "tags": [
            "bash",
            "shell",
            "find",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2686715,
                    "reputation": 8666,
                    "user_id": 2320961,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/AdwXN.png?s=256",
                    "display_name": "Nic3500",
                    "link": "https://stackoverflow.com/users/2320961/nic3500"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1537371313,
                "post_id": 52409207,
                "comment_id": 91762671,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6591726,
                    "reputation": 1183,
                    "user_id": 5092659,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/hCBWY.png?s=256",
                    "display_name": "Samuel Kirschner",
                    "link": "https://stackoverflow.com/users/5092659/samuel-kirschner"
                },
                "reply_to_user": {
                    "account_id": 2686715,
                    "reputation": 8666,
                    "user_id": 2320961,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/AdwXN.png?s=256",
                    "display_name": "Nic3500",
                    "link": "https://stackoverflow.com/users/2320961/nic3500"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1537371589,
                "post_id": 52409207,
                "comment_id": 91762831,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 13955929,
                    "reputation": 21,
                    "user_id": 10078321,
                    "user_type": "registered",
                    "profile_image": "https://graph.facebook.com/2223566354326969/picture?type=large",
                    "display_name": "Jess",
                    "link": "https://stackoverflow.com/users/10078321/jess"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1537372602,
                "post_id": 52409207,
                "comment_id": 91763415,
                "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": 1537376442,
                "post_id": 52409207,
                "comment_id": 91765408,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1537380655,
                "last_edit_date": 1537380655,
                "creation_date": 1537377639,
                "answer_id": 52411185,
                "question_id": 52409207,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It&#39;s unclear to me how `desc` is supposed to be set, but the following should get you on your way once you&#39;ve fixed the JSON in the .json file:\r\n\r\n    acounte=0\r\n    while read fname\r\n    do\t\t\t\t      \r\n      # Check if exists and non-empty\r\n      fname=${fname/.json/.ml}\r\n      if [ -s &quot;${fname}&quot; ] ; then \r\n        # SET desc here\r\n        id=$(jq -r .id &quot;${fname}&quot; )\r\n        echo id=&quot;$id&quot; &gt;&amp;2\r\n        curl -X PUT -H &quot;Content-Type: application/json&quot; -d  &quot;$desc&quot; &quot;https://api.web.com/id/$id/&quot;\r\n      else\r\n        (( acounte++ ))\r\n      fi\r\n    done &lt; &lt;(find . -type f -name &#39;*.json&#39;)\r\n    \r\n    echo acounte=$acounte &gt;&amp;2\r\n\r\n",
                "title": "Find file , extract from other file and post"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1537380655,
        "creation_date": 1537370297,
        "last_edit_date": 1537372241,
        "question_id": 52409207,
        "body_markdown": "i have multiple files  and need to do  whit all\r\nSo  i  use find .\r\ni need to extract from  .json line 12   and  extract the id from .json.ml\r\nand merge in a CURL PUT\r\n\r\nJson file  is:\r\n\r\n   \r\n\r\n     &quot;title&quot;:&quot;Hamaca&quot;,\r\n        &quot;price&quot;:&quot;620&quot;,\r\n        &quot;currency_id&quot;:&quot;ARS&quot;,\r\n        &quot;available_quantity&quot;:&quot;110&quot;,\r\n        &quot;buying_mode&quot;:&quot;buy_it_now&quot;,\r\n        &quot;listing_type_id&quot;:&quot;bronze&quot;,\r\n        &quot;condition&quot;:&quot;new&quot;,\r\n        &quot;description&quot;:{\r\n      &quot;plain_text&quot;: &quot; Text Update&quot;\r\n    },\r\n    &quot;pictures&quot;:[\r\n        {&quot;source&quot;:&quot;https://web/img/p/2/9/29.jpg&quot;},\r\n        {&quot;source&quot;:&quot;https://web/img/p/3/0/30.jpg&quot;},\r\n        {&quot;source&quot;:&quot;https:/qweb/img/p/9/2/3/923.jpg&quot;},\r\n    ],\r\n        &quot;attributes&quot;:[\r\n        {&quot;id&quot;:&quot;BRAND&quot;,\r\n        &quot;value_name&quot;:&quot; TIENDA&quot;  },\r\n        {&quot;id&quot;:&quot;MODEL&quot;,\r\n        &quot;value_name&quot;:&quot;Q&quot; }]\r\n\r\nJson.ml file:\r\n\r\n    {&quot;id&quot;:&quot;MLA745474956&quot;,&quot;site_id&quot;:&quot;MLA&quot;,&quot;title&quot;:&quot;Hamaca&quot;,&quot;subtitle&quot;:null,&quot;seller_id&quot;:335445253,&quot;category_id&quot;:&quot;MLA94987&quot;,&quot;official_store_id&quot;:null,&quot;price&quot;:550,&quot;base_price&quot;:550,&quot;original_price&quot;:null,&quot;currency_id&quot;:&quot;ARS&quot;,&quot;initial_quantity&quot;:110,&quot;available_quantity&quot;:110,&quot;sold_quantity&quot;:0,&quot;sale_terms&quot;:[],&quot;buying_mode&quot;:&quot;buy_it_now&quot;,&quot;listing_type_id&quot;:&quot;gold_special&quot;,&quot;start_time&quot;:&quot;2018-08-29T15:00:37.897Z&quot;,&quot;stop_time&quot;:&quot;2038-08-24T04:00:00.000Z&quot;,&quot;end_time&quot;:&quot;2038-08-24T04:00:00.000Z&quot;,&quot;expiration_time&quot;:&quot;2018-11-17T15:00:38.018Z&quot;,&quot;condition&quot;:&quot;new&quot;,&quot;permalink&quot;:&quot;http://articulo.mercadolibre.com.ar/MLA-745474956-hamaca-_JM&quot;,&quot;pictures&quot;:[{&quot;id&quot;:&quot;706112-MLA28051912310_082018&quot;,&quot;url&quot;:&quot;http://www.mercadolibre.com/jm/img?s=STC&amp;v=O&amp;f=proccesing_image_es.jpg&quot;,&quot;secure_url&quot;:&quot;https://www.mercadolibre.com/jm/img?s=STC&amp;v=O&amp;f=proccesing_image_es.jpg&quot;,&quot;size&quot;:&quot;500x500&quot;,&quot;max_size&quot;:&quot;500x500&quot;,&quot;quality&quot;:&quot;&quot;},{&quot;id&quot;:&quot;949384-MLA28051912309_082018&quot;,&quot;url&quot;:&quot;http://www.mercadolibre.com/jm/img?s=STC&amp;v=O&amp;f=proccesing_image_es.jpg&quot;,&quot;secure_url&quot;:&quot;https://www.mercadolibre.com/jm/img?s=STC&amp;v=O&amp;f=proccesing_image_es.jpg&quot;,&quot;size&quot;:&quot;500x500&quot;,&quot;max_size&quot;:&quot;500x500&quot;,&quot;quality&quot;:&quot;&quot;},{&quot;id&quot;:&quot;803007-MLA28051912308_082018&quot;,&quot;url&quot;:&quot;http://www.mercadolibre.com/jm/img?s=STC&amp;v=O&amp;f=proccesing_image_es.jpg&quot;,&quot;secure_url&quot;:&quot;https://www.mercadolibre.com/jm/img?s=STC&amp;v=O&amp;f=proccesing_image_es.jpg&quot;,&quot;size&quot;:&quot;500x500&quot;,&quot;max_size&quot;:&quot;500x500&quot;,&quot;quality&quot;:&quot;&quot;}],&quot;video_id&quot;:null,&quot;descriptions&quot;:[{&quot;id&quot;:&quot;MLA745474956-1797576680&quot;}],&quot;accepts_mercadopago&quot;:true,&quot;non_mercado_pago_payment_methods&quot;:[],&quot;shipping&quot;:{&quot;mode&quot;:&quot;me2&quot;,&quot;local_pick_up&quot;:false,&quot;free_shipping&quot;:false,&quot;methods&quot;:[],&quot;dimensions&quot;:null,&quot;tags&quot;:[],&quot;logistic_type&quot;:&quot;drop_off&quot;,&quot;store_pick_up&quot;:false},&quot;international_delivery_mode&quot;:&quot;none&quot;,&quot;seller_address&quot;:{&quot;id&quot;:978130375,&quot;comment&quot;:&quot;&quot;,&quot;address_line&quot;:&quot;Pastor Luna 6250&quot;,&quot;zip_code&quot;:&quot;1682&quot;,&quot;city&quot;:{&quot;id&quot;:&quot;&quot;,&quot;name&quot;:&quot;Tres de febrero&quot;},&quot;state&quot;:{&quot;id&quot;:&quot;AR-B&quot;,&quot;name&quot;:&quot;Buenos Aires&quot;},&quot;country&quot;:{&quot;id&quot;:&quot;AR&quot;,&quot;name&quot;:&quot;Argentina&quot;},&quot;latitude&quot;:-34.5861404,&quot;longitude&quot;:-58.58094730000001,&quot;search_location&quot;:{&quot;neighborhood&quot;:{&quot;id&quot;:&quot;TUxBQlZJTDI2MTc2Mw&quot;,&quot;name&quot;:&quot;Villa Bosch&quot;},&quot;city&quot;:{&quot;id&quot;:&quot;TUxBQ1RSRTMxODE5NA&quot;,&quot;name&quot;:&quot;Tres de febrero&quot;},&quot;state&quot;:{&quot;id&quot;:&quot;TUxBUEdSQWVmNTVm&quot;,&quot;name&quot;:&quot;Bs.As. G.B.A. Oeste&quot;}}},&quot;seller_contact&quot;:null,&quot;location&quot;:{},&quot;geolocation&quot;:{&quot;latitude&quot;:-34.5861404,&quot;longitude&quot;:-58.58094730000001},&quot;coverage_areas&quot;:[],&quot;attributes&quot;:[{&quot;id&quot;:&quot;ITEM_CONDITION&quot;,&quot;name&quot;:&quot;Condici&#243;n del &#237;tem&quot;,&quot;value_id&quot;:&quot;2230284&quot;,&quot;value_name&quot;:&quot;Nuevo&quot;,&quot;value_struct&quot;:null,&quot;attribute_group_id&quot;:&quot;&quot;,&quot;attribute_group_name&quot;:&quot;&quot;},{&quot;id&quot;:&quot;BRAND&quot;,&quot;name&quot;:&quot;Marca&quot;,&quot;value_id&quot;:null,&quot;value_name&quot;:&quot;QUIEROTODO TIENDA&quot;,&quot;value_struct&quot;:null,&quot;attribute_group_id&quot;:&quot;OTHERS&quot;,&quot;attribute_group_name&quot;:&quot;Otros&quot;},{&quot;id&quot;:&quot;MODEL&quot;,&quot;name&quot;:&quot;Modelo&quot;,&quot;value_id&quot;:null,&quot;value_name&quot;:&quot;QPM02&quot;,&quot;value_struct&quot;:null,&quot;attribute_group_id&quot;:&quot;OTHERS&quot;,&quot;attribute_group_name&quot;:&quot;Otros&quot;}],&quot;warnings&quot;:[],&quot;listing_source&quot;:&quot;&quot;,&quot;variations&quot;:[],&quot;thumbnail&quot;:&quot;http://www.mercadolibre.com/jm/img?s=STC&amp;v=I&amp;f=proccesing_image_es.jpg&quot;,&quot;secure_thumbnail&quot;:&quot;https://www.mercadolibre.com/jm/img?s=STC&amp;v=I&amp;f=proccesing_image_es.jpg&quot;,&quot;status&quot;:&quot;active&quot;,&quot;sub_status&quot;:[],&quot;tags&quot;:[&quot;immediate_payment&quot;,&quot;cart_eligible&quot;],&quot;warranty&quot;:&quot;Cambios por falla de fabrica dentro de 72 hs de haber recibido el producto sin indicios de uso en su caja original! Los cambios de talle corren por cuenta del comprador de ida y vuelta sin exepcion. No hacemos reintegro de dinero ni devolcuion de art&quot;,&quot;catalog_product_id&quot;:null,&quot;domain_id&quot;:&quot;MLA-PLAYGROUND_SWING_SETS&quot;,&quot;seller_custom_field&quot;:null,&quot;parent_item_id&quot;:null,&quot;differential_pricing&quot;:null,&quot;deal_ids&quot;:[],&quot;automatic_relist&quot;:false,&quot;date_created&quot;:&quot;2018-08-29T15:00:38.208Z&quot;,&quot;last_updated&quot;:&quot;2018-08-29T15:00:38.208Z&quot;,&quot;health&quot;:null}\r\n\r\nI need to extract  line 9 from json   and   id from json.ml \r\nMerge in a Curl \r\n\r\nThx\r\n\r\nHere is my code`\r\n\r\n    find . -type f -name &#39;*.json&#39; | xargs bash -c &#39;for fname\r\n    \r\n    # Check if exist\r\n    do if [ ! -e ${fname}.ml ]\r\n    then \r\n    desc=$(sed -n &quot;12p&quot;  ${fname})\r\n    id=$(cat ${fname}.ml | jq -r &quot;.| .id &quot; )\r\n    curl -X PUT -H &quot;Content-Type: application/json&quot; -d  &quot;$desc&quot; https://api.web.com/id/$id/\r\n    \r\n    else\r\n    (( acounte++ ))\r\n    fi\r\n    \r\n    done\r\n    \r\n    &#39; bash\r\n\r\nWhen i run my script  nothing work  but i dont see any error.\r\nThx",
        "link": "https://stackoverflow.com/questions/52409207/find-file-extract-from-other-file-and-post",
        "title": "Find file , extract from other file and post"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1537532672,
                "last_edit_date": 1537532672,
                "creation_date": 1537460393,
                "answer_id": 52429365,
                "question_id": 52428038,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You need to pull `to_entries[]` outside the `if ... then ... else ... end` clause:\r\n\r\n    .regions | to_entries[] | if .value.domains[$arg1] then .value.name else empty end\r\n\r\nThis can be shortened to:\r\n\r\n    .regions | to_entries[] | .value | select(.domains[$arg1]) | .name\r\n",
                "title": "jq - find parent element based on search result on child element"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1537532672,
        "creation_date": 1537455493,
        "last_edit_date": 1537464342,
        "question_id": 52428038,
        "body_markdown": "For the following json file I need to get &#39;name&#39; element based on search results for that specific entry\r\n\r\neg: json.txt\r\n\r\n    {\r\n      &quot;regions&quot;: {\r\n        &quot;var1&quot;: {\r\n          &quot;name&quot;: &quot;City 1&quot;,\r\n          &quot;domains&quot;: {\r\n            &quot;var3&quot;: {\r\n              &quot;Owner&quot;: &quot;Joe&quot;\r\n            }\r\n          }\r\n        },\r\n        &quot;var2&quot;: {\r\n          &quot;name&quot;: &quot;City 2&quot;,\r\n          &quot;domains&quot;: {\r\n            &quot;var4&quot;: {\r\n              &quot;Owner&quot;: &quot;Brown&quot;\r\n            }\r\n          }\r\n        }\r\n      }\r\n    }\r\n\r\nI tried \r\n\r\n    $ jq --arg arg1 &#39;var4&#39; &#39;.regions | if (to_entries[].value.domains[$arg1]) then to_entries[].value.name else empty end&#39; json.txt\r\n\r\nbut that returns\r\n\r\n    &quot;City 1&quot;\r\n    &quot;City 2&quot;\r\n\r\nI want the result to only fetch\r\n\r\n    &quot;City 2&quot;\r\n\r\n\r\nAny assistance would be greatly appreciated\r\n",
        "link": "https://stackoverflow.com/questions/52428038/jq-find-parent-element-based-on-search-result-on-child-element",
        "title": "jq - find parent element based on search result on child element"
    },
    {
        "tags": [
            "json",
            "jq",
            "parameterization"
        ],
        "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": 1537464549,
                "post_id": 52429120,
                "comment_id": 91804211,
                "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": 1537464598,
                "post_id": 52429120,
                "comment_id": 91804229,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 6,
                "is_accepted": true,
                "score": 6,
                "last_activity_date": 1537508709,
                "last_edit_date": 1537508709,
                "creation_date": 1537461935,
                "answer_id": 52429739,
                "question_id": 52429120,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "First, the shown input is neither valid JSON nor a valid stream of JSON documents.  Since you&#39;ve\r\nused `..|objects` I&#39;ll assume your intent was that the input be an array.\r\n\r\nSecond, the -n option means: don&#39;t automatically read STDIN or the specified file.  Since you&#39;ve\r\nused `cat`, I&#39;ll drop it.\r\n\r\nThird, you have used $TESTDATE and $test1 without giving sample values.  I&#39;m going to use\r\nthe variables and values shown below.\r\n\r\nFourth, it&#39;s generally best to pass in parameter values using the --arg or --argjson option,\r\nas you have done for $TESTDATE but not $test1.\r\n\r\nFifth, it&#39;s a minor point, but I&#39;m going to lose the `cat`: see https://stackoverflow.com/questions/11710552/useless-use-of-cat\r\n\r\nPutting it all together, we could write:\r\n\r\n    testdate=&quot;September 13, 2018&quot;\r\n    testname=&quot;Artist Name&quot;\r\n\r\n    &lt; test.json jq -r --arg testdate &quot;$testdate&quot; --arg testname &quot;$testname&quot; &#39;\r\n        .[]\r\n        | select((.Date == $testdate) and (.ArtistName | contains($testname)))\r\n        | .AlbumLink &#39;\r\n\r\n`contains`, however, is a funny beast, and generally I&#39;d recommend using `index` instead.",
                "title": "How to pass a variable into JQ select/contains query"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1537508709,
        "creation_date": 1537459545,
        "last_edit_date": 1537464285,
        "question_id": 52429120,
        "body_markdown": "I am trying to pass two variables into a jq query.\r\n\r\nMy JSON\r\n\r\n     {\r\n     &quot;AlbumTitle&quot;: &quot;Name Of Album&quot;,\r\n     &quot;AlbumLink&quot;: &quot;/album/link/id/1/album-name/&quot;,\r\n     &quot;ArtistName&quot;: &quot;Artist Name&quot;,\r\n     &quot;Date&quot;: &quot;September 14, 2018&quot;\r\n     },\r\n     {\r\n     &quot;AlbumTitle&quot;: &quot;Name Of Album&quot;,\r\n     &quot;AlbumLink&quot;: &quot;/album/link/id/2/album-name/&quot;,\r\n     &quot;ArtistName&quot;: &quot;Artist Name&quot;,\r\n     &quot;Date&quot;: &quot;September 13, 2018&quot;\r\n     }\r\n\r\nI two variables as the Date and Artist Name, and I am trying to pull back the ArtistLink depending on the variables.\r\n\r\nI am using the JQ line below.\r\n\r\n     cat test.json | jq -n -r --arg TESTDATE &quot;$TESTDATE&quot; &#39;.. | objects | {select(.Date == &#39;&quot;$TESTDATE&quot;&#39;)} | select(.ArtistName | contains(&#39;&quot;$test1&quot;&#39;)) | .AlbumLink&#39;\r\n\r\nAnd I am getting the error\r\n\r\n     &quot;jq: error: syntax error, unexpected &#39;(&#39;, expecting &#39;}&#39;      (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n     .. | objects | {select(.Date == September 13, 2018)} | select(.ArtistName | contains(Artist)) | .AlbumLink                      \r\n     jq: 1 compile error&quot;",
        "link": "https://stackoverflow.com/questions/52429120/how-to-pass-a-variable-into-jq-select-contains-query",
        "title": "How to pass a variable into JQ select/contains query"
    },
    {
        "tags": [
            "json",
            "jq",
            "template-engine"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1537461870,
                "creation_date": 1537461870,
                "answer_id": 52429724,
                "question_id": 52429459,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Define a function to replace the tokens with the new values.\r\n\r\n    def format($map): gsub(&quot;\\\\{(?&lt;key&gt;[^}]+)\\\\}&quot;; &quot;\\($map[.key])&quot;);\r\n\r\nWith this, you can then pass in the map for the replacements.\r\n\r\n    .ma as $map | .text | format($map)\r\n\r\nUpdate the mapping as needed.\r\n\r\n    (.ma * .mb) as $map | .text | format($map)",
                "title": "JQ: perform token replacement"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1537463473,
                "last_edit_date": 1537463473,
                "creation_date": 1537463121,
                "answer_id": 52430033,
                "question_id": 52429459,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you&#39;re stuck with the `{a}`-style template names, then see @JeffMercado&#39;s answer; if, however, you have control over the templating style, it would make things much simpler if you used jq&#39;s string-interpolation feature.  \r\n\r\nFor example, if the template string (.text) were `&quot;https://ph.com?a=\\\\(.a)&amp;b=\\\\(.b)&quot;` then if you just want the value of `.text` after substitution, you could simply write:\r\n\r\n    (.ma + .mb) as $map | .text | $map\r\n\r\nOr if you wanted in-place substitution:\r\n\r\n    (.ma + .mb) as $map\r\n    | .text |= $map\r\n\r\n  \r\n\r\n",
                "title": "JQ: perform token replacement"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1537463473,
        "creation_date": 1537460808,
        "last_edit_date": 1537463213,
        "question_id": 52429459,
        "body_markdown": "I&#39;d like to replace the tokens in `text` with the variables defined in `ma`. Input JSON:\r\n\r\n    {\r\n        &quot;ma&quot;:{\r\n            &quot;a&quot;:&quot;1&quot;,\r\n            &quot;b&quot;:&quot;2&quot;,\r\n            &quot;c&quot;:&quot;3&quot;\r\n        },\r\n        &quot;mb&quot;:{\r\n            &quot;a&quot;:&quot;11&quot;\r\n        },\r\n        &quot;text&quot;:&quot;https://ph.com?a={a}&amp;b={b}&quot;\r\n    }\r\n\r\nDesired result: `https://ph.com?a=1&amp;b=2`\r\n\r\nExtra credit, how can I have `mb` variables take precedence over `ma` variables so that my resulting text is: `https://ph.com?a=11&amp;b=2` ?\r\n\r\nI&#39;ve tried using combinations of `scan` and `sub` and `walk` but can&#39;t figure it out.\r\n\r\nThanks!",
        "link": "https://stackoverflow.com/questions/52429459/jq-perform-token-replacement",
        "title": "JQ: perform token replacement"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1537510198,
                "post_id": 52437569,
                "comment_id": 91818032,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3422788,
                    "reputation": 75,
                    "user_id": 2869728,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/5851e6b3da15e6a536d02f070fb4619c?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "VN-",
                    "link": "https://stackoverflow.com/users/2869728/vn"
                },
                "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": 1537510810,
                "post_id": 52437569,
                "comment_id": 91818265,
                "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": 1537510849,
                "post_id": 52437569,
                "comment_id": 91818284,
                "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": 1537539721,
                "post_id": 52437569,
                "comment_id": 91834259,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1537514201,
                "creation_date": 1537514201,
                "answer_id": 52438501,
                "question_id": 52437569,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using `jq`:\r\n\r\n    jq &#39;.data[] | select(.name == &quot;dev&quot;) | .id&#39; file\r\n\r\nUse `-r` option if you want raw data (without quote).",
                "title": "Search for key value in JSON and print value from different key"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1537541649,
                "creation_date": 1537541649,
                "answer_id": 52446338,
                "question_id": 52437569,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Under reasonable assumptions, you could probably get away with the following, or something very much like it:\r\n\r\n    awk &#39;\r\n      function check() { \r\n        if (flag &amp;&amp; id) {\r\n          sub(&quot;.[^:]*:\\&quot;&quot;,&quot;&quot;,id); sub(/.,$/,&quot;&quot;,id); \r\n          print id; flag=id=&quot;&quot;;\r\n        }\r\n      }\r\n      $1 ~ /},?/ { check(); next; }\r\n      /^ *&quot;id&quot;:/ { id=$0; next; }\r\n      /^ *&quot;name&quot;:&quot;dev&quot;/ {flag=1} &#39;\r\n\r\n",
                "title": "Search for key value in JSON and print value from different key"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1537541649,
        "creation_date": 1537510039,
        "last_edit_date": 1537512405,
        "question_id": 52437569,
        "body_markdown": "I have following JSON file:\r\n\r\n    {  \r\n       &quot;data&quot;:[  \r\n          {  \r\n             &quot;id&quot;:&quot;34c4s5f7-175f-480a-adff-d8d0bef4e8c4&quot;,\r\n             &quot;name&quot;:&quot;test&quot;,\r\n             &quot;organizationId&quot;:&quot;7er337a-714c-4043-90b1-6a4e7we82d87&quot;,\r\n             &quot;isProduction&quot;:false,\r\n             &quot;type&quot;:&quot;test&quot;,\r\n             &quot;clientId&quot;:&quot;6d4720062eab494c45ewedaa78de1&quot;\r\n          },\r\n          {  \r\n             &quot;id&quot;:&quot;4856a92-9e46-4430-aac7-6ed8674569f&quot;,\r\n             &quot;name&quot;:&quot;dev&quot;,\r\n             &quot;organizationId&quot;:&quot;7er337a-714c-4043-90b1-6a4e7we82d87&quot;,\r\n             &quot;isProduction&quot;:false,\r\n             &quot;type&quot;:&quot;sandbox&quot;,\r\n             &quot;clientId&quot;:&quot;bs34dea7749494daa8deert908bcd9&quot;\r\n          }\r\n       ],\r\n       &quot;total&quot;:2\r\n    }\r\n\r\nMy requirement is to find records where key name is `dev` and then print the id key.\r\n\r\nI have come across \r\n\r\n    awk -F: &#39;$1~/&quot;name&quot;/{l=$2} l~/dev/ &amp;&amp; $1 ~ /id/ {sub(/,/,&quot;&quot;,$2);print $2}&#39; \r\n\r\nbut this prints key value which appears in subsequent lines for the matched key. I need to find the value which is before the matched key.",
        "link": "https://stackoverflow.com/questions/52437569/search-for-key-value-in-json-and-print-value-from-different-key",
        "title": "Search for key value in JSON and print value from different key"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 6,
                "is_accepted": true,
                "score": 6,
                "last_activity_date": 1537529906,
                "last_edit_date": 1537529906,
                "creation_date": 1537529829,
                "answer_id": 52442907,
                "question_id": 52441157,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Try this jq script: \r\n\r\n    &lt;file jq &#39;.array = [ .array[] | .something.NEW_PROPERTY = .name ]&#39;\r\n\r\nThis is replacing the `array` by another one that is the same as the original one with one more key `NEW_PROPERTY`.",
                "title": "JQ add properties to nested object in nested array"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1537539601,
                "creation_date": 1537539601,
                "answer_id": 52445703,
                "question_id": 52441157,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could simply use the filter:\r\n\r\n    .array |= map(.something.NEW_PROPERTY = .name)\r\n\r\nor if `map`&#39;s not your thing (or if you want to save typing one character):\r\n\r\n    .array[] |= (.something.NEW_PROPERTY = .name)\r\n",
                "title": "JQ add properties to nested object in nested array"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 5,
        "last_activity_date": 1537539601,
        "creation_date": 1537523796,
        "question_id": 52441157,
        "body_markdown": "I have the following json:\r\n\r\n    {\r\n      &quot;first&quot;: {\r\n        &quot;second&quot; : &quot;A&quot;\r\n      },\r\n      &quot;array&quot;: [\r\n        {\r\n          &quot;name&quot; : &quot;AAA&quot;,\r\n          &quot;something&quot;: {\r\n            &quot;hola&quot;: &quot;hi&quot;\r\n          }\r\n        },\r\n        {\r\n          &quot;name&quot; : &quot;BBB&quot;,\r\n          &quot;something&quot;: {\r\n            &quot;hola&quot;: &quot;hi&quot;\r\n          }\r\n        }\r\n      ]\r\n    }\r\n\r\nI would like to trasform it adding a property to the `something` object, using the value from the `name` property of the parent, like:\r\n\r\nI have the following json:\r\n\r\n    {\r\n      &quot;first&quot;: {\r\n        &quot;second&quot; : &quot;A&quot;\r\n      },\r\n      &quot;array&quot;: [\r\n        {\r\n          &quot;name&quot; : &quot;AAA&quot;,\r\n          &quot;something&quot;: {\r\n            &quot;hola&quot;: &quot;hi&quot;,\r\n            &quot;NEW_PROPERTY&quot;: &quot;AAA&quot;\r\n          }\r\n        },\r\n        {\r\n          &quot;name&quot; : &quot;BBB&quot;,\r\n          &quot;something&quot;: {\r\n            &quot;hola&quot;: &quot;hi&quot;,\r\n            &quot;NEW_PROPERTY&quot;: &quot;BBB&quot;\r\n          }\r\n        }\r\n      ]\r\n    }\r\n\r\nWhich jq expression can do this?",
        "link": "https://stackoverflow.com/questions/52441157/jq-add-properties-to-nested-object-in-nested-array",
        "title": "JQ add properties to nested object in nested array"
    },
    {
        "tags": [
            "json",
            "merge",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1537545727,
                "last_edit_date": 1537545727,
                "creation_date": 1537542995,
                "answer_id": 52446722,
                "question_id": 52446068,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The following adopts a straightforward approach to the point of being a bit pedestrian:\r\n\r\n    jq -s -f merge.jq 1.json 2.json\r\n\r\nassuming the file `merge.jq` contains:\r\n\r\n    .[1][0] as $two\r\n    | .[0]\r\n    | reduce range(0; length) as $i (.;\r\n        .[$i].baz = $two[$i] )\r\n\r\n## Variation \r\n\r\nIf your jq supports the --argfile option, you can avoid the overhead of &quot;slurping&quot; by running:\r\n\r\n    jq --argfile two 2.json -f merge.jq 1.json\r\n\r\nassuming `merge.jq` contains:\r\n\r\n    reduce range(0; length) as $i (.; \r\n      .[$i].baz = $two[0][$i] )\r\n  ",
                "title": "How to copy data from one json to another using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1537546781,
        "creation_date": 1537540771,
        "last_edit_date": 1537546781,
        "question_id": 52446068,
        "body_markdown": "I have two json inputs and I want [jq][1] to build a new json copying the elements from the 2nd array to the **corresponding position** in the 1st:\r\n\r\n1st json:\r\n\r\n    [\r\n       {&quot;foo&quot;: &quot;foo1&quot;, &quot;bar&quot;: &quot;bar1&quot;},\r\n       {&quot;foo&quot;: &quot;foo2&quot;, &quot;bar&quot;: &quot;bar2&quot;},\r\n       {&quot;foo&quot;: &quot;foo3&quot;, &quot;bar&quot;: &quot;bar3&quot;}\r\n    ]\r\n\r\n2nd json:\r\n\r\n    [[\r\n       &quot;baz1&quot;,\r\n       &quot;baz2&quot;,\r\n       &quot;baz3&quot;\r\n    ]]\r\n\r\nexpected result:\r\n\r\n    [\r\n       {&quot;foo&quot;: &quot;foo1&quot;, &quot;bar&quot;: &quot;bar1&quot;, &quot;baz&quot;: &quot;baz1&quot;},\r\n       {&quot;foo&quot;: &quot;foo2&quot;, &quot;bar&quot;: &quot;bar2&quot;, &quot;baz&quot;: &quot;baz2&quot;},\r\n       {&quot;foo&quot;: &quot;foo3&quot;, &quot;bar&quot;: &quot;bar3&quot;, &quot;baz&quot;: &quot;baz3&quot;}\r\n    ]\r\n\r\nI&#39;ve tried this command line but it doesn&#39;t seems to work\r\n\r\n    jq -n --argfile o1 &quot;1st.json&quot; --argfile o2 &quot;2nd.json&quot; &quot;[$o1 []  | .baz= $o2[][]]&quot;\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/manual",
        "link": "https://stackoverflow.com/questions/52446068/how-to-copy-data-from-one-json-to-another-using-jq",
        "title": "How to copy data from one json to another using jq"
    }
]