[
    {
        "tags": [
            "json",
            "linux",
            "awk",
            "sed",
            "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": 2,
                "creation_date": 1600694572,
                "post_id": 63993045,
                "comment_id": 113159572,
                "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"
                },
                "reply_to_user": {
                    "account_id": 1852014,
                    "reputation": 24882,
                    "user_id": 1678362,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/8ba023d18099cde022b9e4394d5714c0?s=256&d=identicon&r=PG",
                    "display_name": "Aaron",
                    "link": "https://stackoverflow.com/users/1678362/aaron"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1600695337,
                "post_id": 63993045,
                "comment_id": 113160022,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8413147,
                    "reputation": 1511,
                    "user_id": 6314389,
                    "user_type": "registered",
                    "accept_rate": 81,
                    "profile_image": "https://www.gravatar.com/avatar/c3cde44cc47ec7447ae3c9908d14196a?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Auto-learner",
                    "link": "https://stackoverflow.com/users/6314389/auto-learner"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1600695466,
                "post_id": 63993045,
                "comment_id": 113160086,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1600695840,
                "last_edit_date": 1600695840,
                "creation_date": 1600695464,
                "answer_id": 63993462,
                "question_id": 63993045,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The `jq` command you&#39;ve posted [should work just fine](https://jqplay.org/s/TJpYM4bu41), but it doesn&#39;t update the file, it just outputs the updated result. You can store that output and overwrite the original file with it as follows :\r\n\r\n    jq &#39;.refreshInterval.default = 40000&#39; plugin.json &gt; jq_output\r\n    mv jq_output plugin.json\r\n\r\nCareful not to try to simplify it into `jq &#39;.refreshInterval.default = 40000&#39; plugin.json &gt; plugin.json` as the redirection will be processed first and erase the content of the file before `jq` can read it. If you want to avoid the use of a temporary file you could use an utility such as `sponge` from the `moreutils` package which allows in-place edition.",
                "title": "SED/AWK how to replace a value if a parent key matches in json file"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1600763379,
        "creation_date": 1600694068,
        "last_edit_date": 1600763379,
        "question_id": 63993045,
        "body_markdown": "I&#39;m trying to replace the default value if the parent is refreshinterval.I have tried using jq and sed but unable to get my expected output. Can someone help to get the expected answer.\r\n\r\n    { &quot;doubleClickDiff&quot;: {\r\n            &quot;type&quot;: &quot;boolean&quot;,\r\n            &quot;title&quot;: &quot;Show diff on double click&quot;,\r\n            &quot;description&quot;: &quot;If true, doubling clicking a file in the list of changed files will open a diff.&quot;,\r\n            &quot;default&quot;: false\r\n          },\r\n          &quot;historyCount&quot;: {\r\n            &quot;type&quot;: &quot;integer&quot;,\r\n            &quot;title&quot;: &quot;History count&quot;,\r\n            &quot;description&quot;: &quot;Number of (most recent) commits shown in the history log&quot;,\r\n            &quot;default&quot;: 25\r\n          },\r\n          &quot;refreshInterval&quot;: {\r\n            &quot;type&quot;: &quot;integer&quot;,\r\n            &quot;title&quot;: &quot;Refresh interval&quot;,\r\n            &quot;description&quot;: &quot;Number of milliseconds between polling the file system for changes.&quot;,\r\n            &quot;default&quot;: 10000\r\n          },\r\n          &quot;simpleStaging&quot;: {\r\n            &quot;type&quot;: &quot;boolean&quot;,\r\n            &quot;title&quot;: &quot;Simple staging flag&quot;,\r\n            &quot;description&quot;: &quot;If true, use a simplified concept of staging. Only files with changes are shown (instead of showing staged/changed/untracked), and all files with changes will be automatically staged&quot;,\r\n            &quot;default&quot;: false\r\n          }}\r\n\r\nmy output should replace default value only if key is refreshInterval \r\n\r\n    &quot;refreshInterval&quot;: {\r\n            &quot;type&quot;: &quot;integer&quot;,\r\n            &quot;title&quot;: &quot;Refresh interval&quot;,\r\n            &quot;description&quot;: &quot;Number of milliseconds between polling the file system for changes.&quot;,\r\n            &quot;default&quot;: 40000\r\n          },\r\n\r\n\r\n\r\n    jq &#39;.&quot;refreshInterval&quot;.&quot;default&quot;=40000&#39; plugin.json\r\n\r\n    sed -i &#39;s/\\&quot;default\\&quot;:.*/\\&quot;default\\&quot;: &#39;40000&#39;/g&#39; &quot;demo.json&quot;\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/63993045/sed-awk-how-to-replace-a-value-if-a-parent-key-matches-in-json-file",
        "title": "SED/AWK how to replace a value if a parent key matches in json file"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1206451,
                    "reputation": 171716,
                    "user_id": 1175966,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/8d3d9dfbd040f9cbc1a6b82f0da2b345?s=256&d=identicon&r=PG",
                    "display_name": "charlietfl",
                    "link": "https://stackoverflow.com/users/1175966/charlietfl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1600735560,
                "post_id": 64001535,
                "comment_id": 113175104,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 8,
                "is_accepted": true,
                "score": 8,
                "last_activity_date": 1600741763,
                "last_edit_date": 1600741763,
                "creation_date": 1600737960,
                "answer_id": 64001862,
                "question_id": 64001535,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; Am I far off?\r\n\r\nIf you use `test/1` instead of `contains`, and make corresponding adjustments, no: \r\n```\r\n.interface[]\r\n| select(.description | test (&quot;VLL|2002089|otherstuff&quot; ) | not )\r\n```\r\n\r\nThe argument of test is interpreted as a regex. There are of course alternatives, but if using a regex is appropriate, then `test` would be suitable.\r\n\r\n## Blacklist of strings\r\n\r\nIf you have a blacklist of strings and want to use string equality as the criterion, consider:\r\n```\r\n[&quot;VLL&quot;,&quot;2002089&quot;,&quot;otherstuff&quot;] as $blacklist\r\n| .interface[]\r\n| select(.description | IN($blacklist[]) | not)\r\n```\r\n",
                "title": "Jq using contain with multiple match conditions"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1600753172,
        "creation_date": 1600734723,
        "last_edit_date": 1600753172,
        "question_id": 64001535,
        "body_markdown": "I have json file with multiple object Id&#39;s and I need a query that excludes different ids based on naming conventions. These are essentially OR&#39;s. I thought I had it with this query but they are still appearing in the output. \r\n\r\nIf I run the query with them separately I can get it to work, but I need to add a large list.  \r\n\r\nWorks\r\n```\r\ncat file.json | jq &#39;.interface[] | select(.description | contains (&quot;VLL&quot;) | not )&#39;\r\n```\r\n\r\nNot working\r\n```\r\ncat file.json | jq &#39;.interface[] | select(.description | contains (&quot;VLL&quot;|&quot;2002089&quot;|&quot;otherstuff&quot; ) | not )&#39;\r\n```\r\n\r\nIve tried a few different ways with commas and quoting but no luck. \r\n\r\nAm I far off?\r\n\r\nI also plan to run this in bash script if that help(probably makes worse) \r\n\r\nThanks",
        "link": "https://stackoverflow.com/questions/64001535/jq-using-contain-with-multiple-match-conditions",
        "title": "Jq using contain with multiple match conditions"
    },
    {
        "tags": [
            "json",
            "select",
            "key",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1600794872,
                "last_edit_date": 1600794872,
                "creation_date": 1600794554,
                "answer_id": 64014547,
                "question_id": 64014015,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using your approach, you could write:\r\n```\r\n.[] |= with_entries(\r\n   if (.key == &quot;1&quot; or .key == &quot;2&quot;) \r\n   then .value |= del(.bar) \r\n   else .value |= del(.foo)\r\n   end)\r\n```\r\n\r\n`with_entries` makes it easy to access each &quot;key&quot; and corresponding &quot;value&quot;.\r\n\r\nYour attempt failed because `.[][]` reaches down too deeply into the data, as you can see by running `jq &#39;.[][]&#39;`.  If you do, you&#39;ll see why your attempt ends up deleting the `foo` keys unconditionally, the point being that .key is only defined for you in the context of `with_entries` (though `to_entries` can be used to achieve the same effect).  ",
                "title": "Delete different nested object if parent meets condition"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1600813842,
        "creation_date": 1600792429,
        "last_edit_date": 1600813842,
        "question_id": 64014015,
        "body_markdown": "I want to delete different sub-objects from a json file (whilst maintaining the original structure) depending on whether the parent object&#39;s key meets a given condition.\r\n\r\nSay I have:\r\n\r\n```\r\n{\r\n  &quot;A&quot;: {\r\n    &quot;1&quot;: {\r\n      &quot;bar&quot;: 1,\r\n      &quot;foo&quot;: 0\r\n    }\r\n  },\r\n  &quot;B&quot;: {\r\n    &quot;2&quot;: {\r\n      &quot;not_here&quot;: 0,\r\n      &quot;foo&quot;: 0\r\n    },\r\n    &quot;3&quot;: {\r\n      &quot;bar&quot;: 0,\r\n      &quot;foo&quot;: 1\r\n    }\r\n  },\r\n  &quot;C&quot;: {\r\n    &quot;4&quot;: {\r\n      &quot;bar&quot;: 0,\r\n      &quot;foo&quot;: 1\r\n    }\r\n  }\r\n}\r\n```\r\n\r\nAnd for all nested objects with keys in [&quot;1&quot;, &quot;2&quot;], I want to delete the `bar` object, and otherwise I want to delete the `foo` object, so the output expected being:\r\n\r\n```\r\n{\r\n  &quot;A&quot;: {\r\n    &quot;1&quot;: {\r\n      &quot;foo&quot;: 0\r\n    }\r\n  },\r\n  &quot;B&quot;: {\r\n    &quot;2&quot;: {\r\n      &quot;not_here&quot;: 0,\r\n      &quot;foo&quot;: 0\r\n    },\r\n    &quot;3&quot;: {\r\n      &quot;bar&quot;: 0\r\n    }\r\n  },\r\n  &quot;C&quot;: {\r\n    &quot;4&quot;: {\r\n      &quot;bar&quot;: 0\r\n    }\r\n  }\r\n}\r\n```\r\n\r\nI would&#39;ve thought this would work:\r\n\r\n```\r\n.[][] |= (if .key == (&quot;1&quot;, &quot;2&quot;) then del(.bar) else del(.foo) end)\r\n```\r\n\r\nBut there&#39;s something wrong with my conditional I think as it just deletes `foo` everywhere.",
        "link": "https://stackoverflow.com/questions/64014015/delete-different-nested-object-if-parent-meets-condition",
        "title": "Delete different nested object if parent meets condition"
    },
    {
        "tags": [
            "json",
            "amazon-web-services",
            "select",
            "jq",
            "aws-cli"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1600800944,
                "last_edit_date": 1600800944,
                "creation_date": 1600796331,
                "answer_id": 64015011,
                "question_id": 64014481,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; What am I doing wrong?\r\n\r\nYour use of `select` is not quite right.  Instead, it seems you want:\r\n```\r\n[ .InstanceId, \r\n  .State.Name,\r\n  .LaunchTime, \r\n  (.Tags[] | select(.Key==&quot;Name&quot;).Value) ] \r\n| @tsv\r\n```",
                "title": "Is it possible to use select as an element in a jq list?"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1600816036,
                "creation_date": 1600816036,
                "answer_id": 64018821,
                "question_id": 64014481,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "There is **no need to use `jq`** to extract values from AWS CLI output.\r\n\r\nYou can instead use `--query`, which follows [JMESPATH](https://jmespath.org/examples.html) syntax.\r\n\r\nHere&#39;s an example:\r\n\r\n    aws ec2 describe-instances --query &quot;Reservations[].Instances[].[InstanceId,State.Name,LaunchTime,Tags[?Key==&#39;Name&#39;].Value|[0]]&quot;\r\n\r\nThe output format can be specified by `--output`, such as `json`, `text`, `table` or (for AWS CLI v2) `yaml`.",
                "title": "Is it possible to use select as an element in a jq list?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1600853631,
        "creation_date": 1600794333,
        "last_edit_date": 1600853631,
        "question_id": 64014481,
        "body_markdown": "I&#39;m trying to parse the instance id, state, launch time and name using jq from the following partial output:\r\n\r\n    {\r\n      &quot;AmiLaunchIndex&quot;: 0,\r\n      &quot;ImageId&quot;: &quot;ami-07c1483ef8c3dfece&quot;,\r\n      &quot;InstanceId&quot;: &quot;i-0309XXXXXf6d500c&quot;,\r\n      &quot;InstanceType&quot;: &quot;m5.2xlarge&quot;,\r\n      &quot;KeyName&quot;: &quot;k8s-prod-ap-southeast-1&quot;,\r\n      &quot;LaunchTime&quot;: &quot;2019-01-27T12:23:55+00:00&quot;,\r\n      &quot;Monitoring&quot;: {\r\n        &quot;State&quot;: &quot;enabled&quot;\r\n      },\r\n      &quot;Placement&quot;: {\r\n        &quot;AvailabilityZone&quot;: &quot;ap-southeast-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-X-X-X-X.ap-southeast-1.compute.internal&quot;,\r\n      &quot;PrivateIpAddress&quot;: &quot;X.X.X.X&quot;,\r\n      &quot;ProductCodes&quot;: [],\r\n      &quot;PublicDnsName&quot;: &quot;&quot;,\r\n      &quot;State&quot;: {\r\n        &quot;Code&quot;: 16,\r\n        &quot;Name&quot;: &quot;running&quot;\r\n      },\r\n      &quot;SourceDestCheck&quot;: true,\r\n      &quot;Tags&quot;: [\r\n        {\r\n          &quot;Key&quot;: &quot;Environment&quot;,\r\n          &quot;Value&quot;: &quot;dev&quot;\r\n        },\r\n        {\r\n          &quot;Key&quot;: &quot;Project&quot;,\r\n          &quot;Value&quot;: &quot;someproject&quot;\r\n        },\r\n        {\r\n          &quot;Key&quot;: &quot;Name&quot;,\r\n          &quot;Value&quot;: &quot;k8s-prod-ap-southeast-1-mongodb&quot;\r\n        },\r\n        {\r\n          &quot;Key&quot;: &quot;aws:autoscaling:groupName&quot;,\r\n          &quot;Value&quot;: &quot;k8s-prod-ap-southeast-1-mongodb-moved-marmoset-20190127122348196400000006&quot;\r\n        },\r\n        {\r\n          &quot;Key&quot;: &quot;extra_tag1&quot;,\r\n          &quot;Value&quot;: &quot;extra_value1&quot;\r\n        },\r\n        {\r\n          &quot;Key&quot;: &quot;extra_tag2&quot;,\r\n          &quot;Value&quot;: &quot;extra_value2&quot;\r\n        }\r\n      ],\r\n      .\r\n      .\r\n      .\r\n    }\r\n\r\nWithout the instance name which is represented as a tag (.Tags[].Name), running this:\r\n\r\n    aws ec2 describe-instances --filters &quot;Name=instance.group-id,Values=${group_id}&quot; --profile ${profile} --region ${region} --output json | jq -r &#39;.Reservations[].Instances[] | [ .InstanceId, .State.Name, .LaunchTime ] | @tsv&#39;\r\nyields the following output:\r\n\r\n    i-01eb8b857e00e61d6\trunning\t2019-01-27T12:23:55+00:00\r\n    i-0b013248c2a238598\trunning\t2019-01-27T12:23:55+00:00\r\n    i-03094d164ff6d500c\trunning\t2019-01-27T12:23:55+00:00\r\n\r\nBut when I try to display the instance name as well the command fails:\r\n\r\n    ✗ aws ec2 describe-instances --filters &quot;Name=instance.group-id,Values=${group_id}&quot; --profile ${profile} --region ${region} --output json | jq -r &#39;.Reservations[].Instances[] | [ .InstanceId, .State.Name, .LaunchTime, select(.Tags[].Key==&quot;Name&quot; | .Value) ] | @tsv&#39;\r\n    jq: error (at &lt;stdin&gt;:448): Cannot index boolean with string &quot;Value&quot;\r\n\r\nWhat am I doing wrong?\r\n",
        "link": "https://stackoverflow.com/questions/64014481/is-it-possible-to-use-select-as-an-element-in-a-jq-list",
        "title": "Is it possible to use select as an element in a jq list?"
    },
    {
        "tags": [
            "json",
            "if-statement",
            "search",
            "replace",
            "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": 1600871545,
                "post_id": 64029410,
                "comment_id": 113226220,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8420642,
                    "reputation": 577,
                    "user_id": 6319555,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/c980bfdff56e5504ecc6b23d3227f384?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Invisible999",
                    "link": "https://stackoverflow.com/users/6319555/invisible999"
                },
                "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": 1600872628,
                "post_id": 64029410,
                "comment_id": 113226823,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1600875854,
                "creation_date": 1600875854,
                "answer_id": 64031627,
                "question_id": 64029410,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Yes this can be done with `jq` in a single shot. All you need to do is use the `--argfile` option on the `consumption.json` and apply the condition on the `numberOfVisits` field \r\n\r\n\r\n    jq --argfile visits consumption.json &#39;\r\n        ( $visits | .Body | map( .Metrics[] | select(.numberOfVisits == 0)) | length ) as $data |\r\n        if $data != 2 then\r\n            with_entries( select(.value == 9223372036854776000).value = -1 ) |\r\n              ( .visitsAnnualQuota, .visitsQuota ) |= -1\r\n        elif $data == 2 then\r\n            ( .visitsAnnualQuota, .visitsQuota ) |= 0\r\n        else\r\n            .\r\n        end&#39; license.json\r\n\r\nThe above approach calculates the number of occurrences of `.numberOfVisits` with value 0 and stores in `$data` variable. Then depending on the value in the variable, we apply the filter expressions to modify the fields as required.",
                "title": "jq - combining multiple if conditions when keys/values are in different files"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1601876757,
        "creation_date": 1600868767,
        "last_edit_date": 1601876757,
        "question_id": 64029410,
        "body_markdown": "I have two keys in the ``license.json`` JSON file - ``&quot;visitsAnnualQuota&quot;`` and ``&quot;visitsQuota&quot;`` at the very bottom:\r\n```\r\n{\r\n    &quot;customMetricsLimit&quot;: 9223372036854776000,\r\n    &quot;customMetricsOverageLimit&quot;: 9223372036854776000,\r\n    &quot;UnitsAnnualQuota&quot;: 9223372036854776000,\r\n    &quot;UnitsQuota&quot;: 9223372036854776000,\r\n    &quot;expirationTime&quot;: 1652572799000,\r\n    &quot;infrastructureSupportedTechnologies&quot;: {\r\n        &quot;maxInfrastructureOnlyAgents&quot;: 9223372036854776000,\r\n        &quot;networkAgent&quot;: true,\r\n        &quot;pluginAgent&quot;: true\r\n    },\r\n    &quot;logAnalyticsIngressQuota&quot;: 9223372036854776000,\r\n    &quot;logAnalyticsIngressQuotaAnnually&quot;: 9223372036854776000,\r\n    &quot;maxAgents&quot;: 2147483647,\r\n    &quot;maxHostUnitsQuota&quot;: -1,\r\n    &quot;maxPaasAgents&quot;: 2147483647,\r\n    &quot;maxWebChecks&quot;: 9223372036854776000,\r\n    &quot;maxWebChecksAnnual&quot;: 9223372036854776000,\r\n    &quot;replayStorageDomQuotaInMb&quot;: 9223372036854776000,\r\n    &quot;replayStorageDomRetention&quot;: 86400000,\r\n    &quot;retentionCode&quot;: 864000000,\r\n    &quot;retentionService&quot;: 1209600000,\r\n    &quot;retentionWebcheck&quot;: 864000000,\r\n    &quot;symbolicationFileStorageQuota&quot;: 1024,\r\n    &quot;syntheticEnabled&quot;: true,\r\n    &quot;useHostUnitWeighting&quot;: false,\r\n    &quot;visitsAnnualQuota&quot;: 120000,\r\n    &quot;visitsQuota&quot;: 10000\r\n}\r\n```\r\nI need to set them to value 0 *if* the value of one particular key - ``.numberOfVisits`` from a *different* `JSON` file - ``consumption.json`` equals to zero. Here is the fragment of the ``consumption.json`` file\r\n```\r\n{\r\n    &quot;Header&quot;: {\r\n        &quot;Tenant&quot;: &quot;Tenant-1&quot;\r\n    },\r\n    &quot;Body&quot;: [\r\n        {\r\n            &quot;Metrics&quot;: [\r\n                {\r\n                    &quot;timeframe&quot;: &quot;Week&quot;,\r\n                    &quot;numberOfVisits&quot;: 0\r\n                },\r\n                {\r\n                    &quot;timeframe&quot;: &quot;Month&quot;,\r\n                    &quot;numberOfVisits&quot;: 0\r\n                },\r\n                {\r\n                    &quot;timeframe&quot;: &quot;Year&quot;,\r\n                    &quot;numberOfVisits&quot;: 247648006\r\n                }\r\n            ],\r\n            &quot;tags&quot;: [\r\n                {\r\n                    &quot;context&quot;: &quot;ENVIRONMENT&quot;,\r\n                    &quot;key&quot;: &quot;srch&quot;\r\n                }\r\n            ],\r\n            &quot;webServerName&quot;: &quot;localhost&quot;\r\n        }\r\n    ]\r\n}\r\n```\r\n\r\nIf the ``.numberOfVisits`` from ``consumption.json`` does *not* equal to zero, when ``timeframe=&quot;Week&quot;`` or when ``timeframe=&quot;Month&quot;`` in the same block, then the above two keys need to set to -1 *and* all other keys in the ``license.json`` file which have the value equal to 9223372036854776000 need to have that value replaced to -1.\r\n\r\nWhat I am doing right now is to have a bash script, read the value of ``.numberOfVisits`` to a shell variable, and then have a case block for the variable equals or not to zero and for each condition have `jq` called with the appropriate filters.\r\n\r\nMy question - can all the above logic combined into a single `jq` call?",
        "link": "https://stackoverflow.com/questions/64029410/jq-combining-multiple-if-conditions-when-keys-values-are-in-different-files",
        "title": "jq - combining multiple if conditions when keys/values are in different files"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 13789219,
                    "reputation": 53538,
                    "user_id": 9952196,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/cd1a3f93172eb89e221c98e35e6e22b3?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Shawn",
                    "link": "https://stackoverflow.com/users/9952196/shawn"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1600881848,
                "post_id": 64033057,
                "comment_id": 113231399,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1143565,
                    "reputation": 535973,
                    "user_id": 1126841,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa05233b2357f8d11c22ef4cfc7bb85c?s=256&d=identicon&r=PG",
                    "display_name": "chepner",
                    "link": "https://stackoverflow.com/users/1126841/chepner"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1600886873,
                "post_id": 64033057,
                "comment_id": 113233690,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1600887626,
                "creation_date": 1600887626,
                "answer_id": 64034645,
                "question_id": 64033057,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "There is nothing wrong with your jq program, which can be seen by running:\r\n\r\n    jq &#39;.properties.foo += [ { &quot;id&quot;: &quot;&lt;id3&gt;&quot;, &quot;bar3&quot;: [ { &quot;baz3&quot;: &quot;*&quot;} ] } ]&#39; &lt;&lt;&lt; &quot;$json3&quot;\r\n\r\nIt looks like the problem is with your invocation but since it&#39;s not clear what $json1 is, I&#39;ll just guess that the above is sufficient for you to resolve the issue.\r\n\r\n",
                "title": "Creating a new element in an json object using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1600887626,
        "creation_date": 1600881212,
        "last_edit_date": 1600886189,
        "question_id": 64033057,
        "body_markdown": "Is there a way to create a new element in an existing json object using jq? Example below:\r\n\r\nLet&#39;s say I have this json object and would like to add a new element to foo:\r\n\r\n    json=&#39;{\r\n      &quot;id&quot;: &quot;&lt;id&gt;&gt;&quot;,\r\n      &quot;name&quot;: &quot;&lt;name&gt;&quot;,\r\n      &quot;properties&quot;: {\r\n        &quot;State&quot;: &quot;&lt;state&gt;&quot;,\r\n        &quot;requests&quot;: [],\r\n        &quot;foo&quot;: [\r\n          {\r\n            &quot;id&quot;: &quot;&lt;id1&gt;&quot;,\r\n            &quot;bar1&quot;: [\r\n              {\r\n                &quot;baz1&quot;: &quot;*&quot;\r\n              }\r\n            ]\r\n          },\r\n          {\r\n            &quot;id&quot;: &quot;&lt;id2&gt;&quot;,\r\n            &quot;bar2&quot;: [\r\n              {\r\n                &quot;baz2&quot;: &quot;*&quot;\r\n              }\r\n            ]\r\n          }\r\n        ]\r\n      }\r\n    }&#39;\r\n\r\nThis command works to do that: \r\n\r\n    json2=$($json1 | jq &#39;.properties.foo += [ { &quot;id&quot;: &quot;&lt;id3&gt;&quot;, &quot;bar3&quot;: [ { &quot;baz3&quot;: &quot;*&quot;} ] } ]&#39;)\r\n\r\nHowever, running that same command without a preexisting foo element fails (example array below): \r\n\r\n    json3=&#39;{\r\n      &quot;id&quot;: &quot;&lt;id&gt;&gt;&quot;,\r\n      &quot;name&quot;: &quot;&lt;name&gt;&quot;,\r\n      &quot;properties&quot;: {\r\n        &quot;State&quot;: &quot;&lt;state&gt;&quot;,\r\n        &quot;requests&quot;: []\r\n      }\r\n    }&#39;\r\n\r\nIs there a way in jq to create that element in the json object if one already does not exist? \r\n\r\nThanks!\r\n\r\n",
        "link": "https://stackoverflow.com/questions/64033057/creating-a-new-element-in-an-json-object-using-jq",
        "title": "Creating a new element in an json object using jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1732983,
                    "reputation": 24986,
                    "user_id": 1586174,
                    "user_type": "registered",
                    "accept_rate": 80,
                    "profile_image": "https://www.gravatar.com/avatar/4aa4d9e7b30a8bddace165e4c33abd85?s=256&d=identicon&r=PG",
                    "display_name": "Taplar",
                    "link": "https://stackoverflow.com/users/1586174/taplar"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1600882203,
                "post_id": 64033257,
                "comment_id": 113231572,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3907290,
                    "reputation": 728,
                    "user_id": 3233647,
                    "user_type": "registered",
                    "profile_image": "https://graph.facebook.com/100001608808941/picture?type=large",
                    "display_name": "S&#233;lim Achour",
                    "link": "https://stackoverflow.com/users/3233647/s%c3%a9lim-achour"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1600882309,
                "post_id": 64033257,
                "comment_id": 113231622,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "reply_to_user": {
                    "account_id": 3907290,
                    "reputation": 728,
                    "user_id": 3233647,
                    "user_type": "registered",
                    "profile_image": "https://graph.facebook.com/100001608808941/picture?type=large",
                    "display_name": "S&#233;lim Achour",
                    "link": "https://stackoverflow.com/users/3233647/s%c3%a9lim-achour"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1600955773,
                "post_id": 64033257,
                "comment_id": 113257966,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1600891774,
                "creation_date": 1600891774,
                "answer_id": 64035542,
                "question_id": 64033257,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Allowing for some minor discrepancies in the Q, the following variant of your jq program seems to do what you&#39;re trying to achieve:\r\n\r\n```\r\ngroup_by(.labels.env)\r\n| .[]\r\n| .[0].labels.env as $key\r\n| { ($key) : { projects: . } }\r\n```",
                "title": "Converting array to objects within an object"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1600891774,
        "creation_date": 1600881958,
        "last_edit_date": 1600882181,
        "question_id": 64033257,
        "body_markdown": "I have been battling with this for sometime, ive looked a few articles in regards to this topic. I can&#39;t seem to get exactly what I&#39;m aiming for. I have this original json data that I would like to transform a bit. \r\n\r\nGroup the objects based on the label.env (for now only using one env), then inserting those objects  from the original json into an object named projects. \r\n\r\n\r\norginial_json\r\n\r\n```\r\n{\r\n  &quot;createTime&quot;: &quot;2020-06-25T14:16:45.720Z&quot;,\r\n  &quot;labels&quot;: {\r\n    &quot;cb_domain&quot;: &quot;cloud-services&quot;,\r\n    &quot;cb_product&quot;: &quot;infra&quot;,\r\n    &quot;env&quot;: &quot;prod&quot;,\r\n    &quot;owner&quot;: &quot;cloud-server&quot;\r\n  },\r\n  &quot;lifecycleState&quot;: &quot;ACTIVE&quot;,\r\n  &quot;name&quot;: &quot;projectname&quot;,\r\n  &quot;parent&quot;: {\r\n    &quot;id&quot;: &quot;123456577&quot;,\r\n    &quot;type&quot;: &quot;folder&quot;\r\n  },\r\n  &quot;projectId&quot;: &quot;projectname-324234&quot;,\r\n  &quot;projectNumber&quot;: &quot;962363417856&quot;\r\n}\r\n{\r\n  &quot;createTime&quot;: &quot;2020-06-24T19:45:42.851Z&quot;,\r\n  &quot;labels&quot;: {\r\n    &quot;cb_domain&quot;: &quot;cloud-services&quot;,\r\n    &quot;cb_product&quot;: &quot;ad&quot;,\r\n    &quot;env&quot;: &quot;prod&quot;,\r\n    &quot;owner&quot;: &quot;cloud-server&quot;\r\n  },\r\n  &quot;lifecycleState&quot;: &quot;ACTIVE&quot;,\r\n  &quot;name&quot;: &quot;projectname2&quot;,\r\n  &quot;parent&quot;: {\r\n    &quot;id&quot;: &quot;4352564765437&quot;,\r\n    &quot;type&quot;: &quot;folder&quot;\r\n  },\r\n  &quot;projectId&quot;: &quot;projectname2-4567&quot;,\r\n  &quot;projectNumber&quot;: &quot;3243456324&quot;\r\n}\r\n```\r\nIm using `jq -s &#39;group_by(.labels.env) | .[] | { (.[0].labels.env) : { projects: .[] | . } }&#39;` \r\nto nest the original json data into objects grouped by env\\projects, which works but seems to duplicate it instead of putting each object within projects. \r\n\r\n```\r\n{\r\n  &quot;prod&quot;: {\r\n    &quot;projects&quot;: {\r\n      &quot;createTime&quot;: &quot;2020-06-25T14:16:45.720Z&quot;,\r\n      &quot;labels&quot;: {\r\n        &quot;cb_domain&quot;: &quot;cloud-services&quot;,\r\n        &quot;cb_product&quot;: &quot;infra&quot;,\r\n        &quot;env&quot;: &quot;prod&quot;,\r\n        &quot;owner&quot;: &quot;cloud-server&quot;\r\n      },\r\n      &quot;lifecycleState&quot;: &quot;ACTIVE&quot;,\r\n      &quot;name&quot;: &quot;projectname&quot;,\r\n      &quot;parent&quot;: {\r\n        &quot;id&quot;: &quot;770593713153&quot;,\r\n        &quot;type&quot;: &quot;folder&quot;\r\n      },\r\n      &quot;projectId&quot;: &quot;projectname-324234&quot;,\r\n      &quot;projectNumber&quot;: &quot;962363417856&quot;\r\n    }\r\n  }\r\n}\r\n{\r\n  &quot;prod&quot;: {\r\n    &quot;projects&quot;: {\r\n      &quot;createTime&quot;: &quot;2020-06-24T19:45:42.851Z&quot;,\r\n      &quot;labels&quot;: {\r\n        &quot;cb_domain&quot;: &quot;cloud-services&quot;,\r\n        &quot;cb_product&quot;: &quot;ad&quot;,\r\n        &quot;env&quot;: &quot;prod&quot;,\r\n        &quot;owner&quot;: &quot;cloud-server&quot;\r\n      },\r\n      &quot;lifecycleState&quot;: &quot;ACTIVE&quot;,\r\n      &quot;name&quot;: &quot;projectname2&quot;,\r\n      &quot;parent&quot;: {\r\n        &quot;id&quot;: &quot;4352564765437&quot;,\r\n        &quot;type&quot;: &quot;folder&quot;\r\n      },\r\n      &quot;projectId&quot;: &quot;projectname2-4567&quot;,\r\n      &quot;projectNumber&quot;: &quot;3243456324&quot;\r\n    }\r\n  }\r\n}\r\n\r\n```\r\n\r\nWhat I&#39;m aiming for is \r\n\r\n```\r\n{\r\n  &quot;prod&quot;: {\r\n    &quot;projects&quot;: {\r\n      &quot;createTime&quot;: &quot;2020-06-25T14:16:45.720Z&quot;,\r\n      &quot;labels&quot;: {\r\n        &quot;cb_domain&quot;: &quot;cloud-services&quot;,\r\n        &quot;cb_product&quot;: &quot;infra&quot;,\r\n        &quot;env&quot;: &quot;prod&quot;,\r\n        &quot;owner&quot;: &quot;cloud-server&quot;\r\n      },\r\n      &quot;lifecycleState&quot;: &quot;ACTIVE&quot;,\r\n      &quot;name&quot;: &quot;projectname&quot;,\r\n      &quot;parent&quot;: {\r\n        &quot;id&quot;: &quot;770593713153&quot;,\r\n        &quot;type&quot;: &quot;folder&quot;\r\n      },\r\n      &quot;projectId&quot;: &quot;projectname-324234&quot;,\r\n      &quot;projectNumber&quot;: &quot;962363417856&quot;\r\n    },\r\n    {\r\n      &quot;createTime&quot;: &quot;2020-06-24T19:45:42.851Z&quot;,\r\n      &quot;labels&quot;: {\r\n        &quot;cb_domain&quot;: &quot;cloud-services&quot;,\r\n        &quot;cb_product&quot;: &quot;ad&quot;,\r\n        &quot;env&quot;: &quot;prod&quot;,\r\n        &quot;owner&quot;: &quot;cloud-server&quot;\r\n      },\r\n      &quot;lifecycleState&quot;: &quot;ACTIVE&quot;,\r\n      &quot;name&quot;: &quot;projectname2&quot;,\r\n      &quot;parent&quot;: {\r\n        &quot;id&quot;: &quot;4352564765437&quot;,\r\n        &quot;type&quot;: &quot;folder&quot;\r\n      },\r\n      &quot;projectId&quot;: &quot;projectname2-4567&quot;,\r\n      &quot;projectNumber&quot;: &quot;3243456324&quot;\r\n    }\r\n  }\r\n}\r\n\r\n\r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/64033257/converting-array-to-objects-within-an-object",
        "title": "Converting array to objects within an object"
    },
    {
        "tags": [
            "bash",
            "shell",
            "jq",
            "datadog"
        ],
        "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": 1600886393,
                "post_id": 64033996,
                "comment_id": 113233495,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5783064,
                    "reputation": 529,
                    "user_id": 4563137,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/ukEtO.png?s=256",
                    "display_name": "Blobafet",
                    "link": "https://stackoverflow.com/users/4563137/blobafet"
                },
                "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": 1600903765,
                "post_id": 64033996,
                "comment_id": 113239590,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1600886608,
                "creation_date": 1600886608,
                "answer_id": 64034394,
                "question_id": 64033996,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The shell variable `$response` holds a JSON value, not a filename, ergo:\r\n\r\n    resultId=$(jq &#39;.results[].result_id&#39; &lt;&lt;&lt; &quot;$response&quot;)\r\n",
                "title": "How do I extract a Value from a Key in an Array from a json object using jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1600886608,
        "creation_date": 1600884933,
        "question_id": 64033996,
        "body_markdown": "Im writing a bash script that needs to make two calls, the second call needs a value from the json response of the first call. \r\nHowever I am getting an Error when I attempt to retrieve this value.\r\n\r\n&gt; jq: error: Could not open file ............. Invalid argument\r\n\r\nI have checked my jq query in a browser and it works fine.\r\nHere is an example of my script. \r\n\r\n\r\n    api_key=&quot;key1&quot;\r\n    app_key=&quot;key2&quot;\r\n    \r\n    response=$(curl -X POST \\\r\n    -H &#39;Content-Type: application/json&#39; \\\r\n    -H &quot;DD-API-KEY: ${api_key}&quot; \\\r\n    -H &quot;DD-APPLICATION-KEY: ${app_key}&quot; \\\r\n    -d &#39;{\r\n        &quot;tests&quot;: [\r\n            {\r\n                &quot;public_id&quot;: &quot;abc-123-xyz&quot;,\r\n                &quot;locations&quot;: [&quot;aws:eu-west-2&quot;]\r\n             \r\n            }\r\n        ]\r\n    }&#39; &quot;https://URL&quot;)\r\n    \r\n    resultId=$(jq &#39;.results[].result_id&#39; $response)\r\n    \r\n    curl -G \\\r\n        &quot;https://URL&quot; \\\r\n        -H &quot;DD-API-KEY: ${api_key}&quot; \\\r\n        -H &quot;DD-APPLICATION-KEY: ${app_key}&quot; \\\r\n        -d &quot;result_ids=[$resultId]&quot;\r\n\r\nand this is an example of the json response\r\n\r\n    {\r\n        &quot;results&quot;: [\r\n            {\r\n                &quot;result_id&quot;: &quot;1234&quot;,\r\n                &quot;public_id&quot;: &quot;abc-123-xyz&quot;,\r\n                &quot;location&quot;: 1\r\n            }\r\n        ],\r\n        &quot;triggered_check_ids&quot;: [\r\n            &quot;abc-123-xyz&quot;\r\n        ],\r\n        &quot;locations&quot;: [\r\n            {\r\n                &quot;is_active&quot;: boolean,\r\n                &quot;region&quot;: &quot;Somewhere&quot;,\r\n                &quot;display_name&quot;: &quot;A1&quot;,\r\n                &quot;id&quot;: 1,\r\n                &quot;name&quot;: &quot;A1&quot;\r\n            },\r\n            {\r\n                &quot;is_active&quot;: boolean,\r\n                &quot;region&quot;: &quot;Somewhere else&quot;,\r\n                &quot;display_name&quot;: &quot;B2&quot;,\r\n                &quot;id&quot;: 2,\r\n                &quot;name&quot;: &quot;B2&quot;\r\n            }\r\n        ]\r\n    }",
        "link": "https://stackoverflow.com/questions/64033996/how-do-i-extract-a-value-from-a-key-in-an-array-from-a-json-object-using-jq",
        "title": "How do I extract a Value from a Key in an Array from a json object using jq?"
    },
    {
        "tags": [
            "json",
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 308303,
                    "reputation": 37458,
                    "user_id": 620097,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/820980fd43f2607a815c1f3dbfe152cc?s=256&d=identicon&r=PG",
                    "display_name": "shellter",
                    "link": "https://stackoverflow.com/users/620097/shellter"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1600905983,
                "post_id": 64037572,
                "comment_id": 113239999,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 10015983,
                    "reputation": 144648,
                    "user_id": 9072753,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/EPmGy.jpg?s=256",
                    "display_name": "KamilCuk",
                    "link": "https://stackoverflow.com/users/9072753/kamilcuk"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1600931386,
                "post_id": 64037572,
                "comment_id": 113245892,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1602465462,
                "last_edit_date": 1602465462,
                "creation_date": 1600971363,
                "answer_id": 64052147,
                "question_id": 64037572,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "## Notes\r\n\r\nYour data have an obvious pitfall, the use of two different fields (`StartDate` and `StartTime`) instead of ONE field, the &quot;datetime&quot;, which is standard and well-known across programming languages and data types. If you want to compare dates, then you have to compare combinations of these fields.\r\n\r\nFurthermore, if you have to consider more things about these dates, like timezones or daylight saving periods, this structure becomes more frustrating for no reason.\r\n\r\nAnother note: Here it seems that you use JSON but you treat it as text file, with one record per line, JSON isn&#39;t necessarily printed like this, or could have characters in places where they will break a simple text parsing based on column positions or pattern matching.\r\n\r\n&lt;hr&gt;\r\n\r\n## Using jq\r\n\r\nIn general, to filter your json and get only those with a field value inside a range:\r\n\r\n    jq &#39;select(.StartDate &gt; &quot;2000-09-22&quot; and .StartDate &lt; &quot;2020-09-24&quot;)&#39; file.json\r\n\r\nYou can pass bash variables to the above like this:\r\n\r\n```bash\r\n#!/bin/bash\r\nstart_date=&quot;2020-09-22&quot;\r\nend_date=&quot;2020-09-24&quot;\r\n    \r\njq -c --arg s &quot;$start_date&quot; \\\r\n      --arg e &quot;$end_date&quot;   \\\r\n      &#39;select(.StartDate &gt; $s and .StartDate &lt; $e)&#39; file.json\r\n```\r\n\r\nI have also added `-c` to print records one per line, because I think you really want this. Now, you can add any variables, any conditions for StartDate, StartTime, and get what you want.\r\n\r\n&lt;hr&gt;\r\n\r\n## Concatenate date and time\r\n\r\nAlso, here is a simple way to concatenate `{Start|End}{Date|Time}` of your JSON into easily sortable datetime fields.\r\n\r\n```bash\r\njq -c &#39;.StartDate = &quot;\\(.StartDate)_\\(.StartTime)&quot; \r\n      | .EndDate = &quot;\\(.EndDate)_\\(.EndTime)&quot;\r\n      | del(.StartTime, .EndTime)&#39; file.json\r\n```\r\nSo you will not need to add different conditions for date or time. Output:\r\n\r\n```json\r\n{&quot;Utility&quot;:&quot;DBUpdate&quot;,&quot;StartDate&quot;:&quot;2020-09-21_14:41:12&quot;,&quot;Server&quot;:&quot;eaidev&quot;,&quot;Userid&quot;:&quot;sx50067&quot;,&quot;TrueExit&quot;:&quot;No&quot;,&quot;WaitInterval&quot;:30,&quot;Cluster&quot;:&quot;1&quot;,&quot;Source&quot;:&quot;MANNING1&quot;,&quot;Target&quot;:&quot;MANNING2&quot;,&quot;ClusterListCt&quot;:5,&quot;ListCt&quot;:55,&quot;RequestServer&quot;:&quot;MANNING3&quot;,&quot;Reply&quot;:&quot;JOT4&quot;,&quot;ISC(Source)&quot;:0,&quot;EndDate&quot;:&quot;2020-09-21_14:41:21&quot;,&quot;ExitCode&quot;:0}\r\n{&quot;Utility&quot;:&quot;DBUpdate&quot;,&quot;StartDate&quot;:&quot;2020-09-22_14:41:12&quot;,&quot;Server&quot;:&quot;eaidev&quot;,&quot;Userid&quot;:&quot;sx50067&quot;,&quot;TrueExit&quot;:&quot;No&quot;,&quot;WaitInterval&quot;:30,&quot;Cluster&quot;:&quot;1&quot;,&quot;Source&quot;:&quot;MANNING1&quot;,&quot;Target&quot;:&quot;MANNING2&quot;,&quot;ClusterListCt&quot;:5,&quot;ListCt&quot;:55,&quot;RequestServer&quot;:&quot;MANNING3&quot;,&quot;Reply&quot;:&quot;JOT4&quot;,&quot;ISC(Source)&quot;:0,&quot;EndDate&quot;:&quot;2020-09-22_14:41:21&quot;,&quot;ExitCode&quot;:0}\r\n{&quot;Utility&quot;:&quot;DBUpdate&quot;,&quot;StartDate&quot;:&quot;2020-09-23_14:41:12&quot;,&quot;Server&quot;:&quot;eaidev&quot;,&quot;Userid&quot;:&quot;sx50067&quot;,&quot;TrueExit&quot;:&quot;No&quot;,&quot;WaitInterval&quot;:30,&quot;Cluster&quot;:&quot;1&quot;,&quot;Source&quot;:&quot;MANNING1&quot;,&quot;Target&quot;:&quot;MANNING2&quot;,&quot;ClusterListCt&quot;:5,&quot;ListCt&quot;:55,&quot;RequestServer&quot;:&quot;MANNING3&quot;,&quot;Reply&quot;:&quot;JOT4&quot;,&quot;ISC(Source)&quot;:0,&quot;EndDate&quot;:&quot;2020-09-23_14:41:29&quot;,&quot;ExitCode&quot;:0}\r\n{&quot;Utility&quot;:&quot;DBUpdate&quot;,&quot;StartDate&quot;:&quot;2020-09-23_14:42:12&quot;,&quot;Server&quot;:&quot;eaidev&quot;,&quot;Userid&quot;:&quot;sx50067&quot;,&quot;TrueExit&quot;:&quot;No&quot;,&quot;WaitInterval&quot;:30,&quot;Cluster&quot;:&quot;1&quot;,&quot;Source&quot;:&quot;MANNING1&quot;,&quot;Target&quot;:&quot;MANNING2&quot;,&quot;ClusterListCt&quot;:5,&quot;ListCt&quot;:55,&quot;RequestServer&quot;:&quot;MANNING3&quot;,&quot;Reply&quot;:&quot;JOT4&quot;,&quot;ISC(Source)&quot;:0,&quot;EndDate&quot;:&quot;2020-09-23_14:43:21&quot;,&quot;ExitCode&quot;:0}\r\n```",
                "title": "Capture all the logs between two time stamps of a json format log"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1602465560,
        "creation_date": 1600903503,
        "last_edit_date": 1602465560,
        "question_id": 64037572,
        "body_markdown": "I have a large JSON format log file that has fields `StartDate`, `StartTime`, and each log entry ends with `EndDate` and `EndTime`.\r\n\r\nMy sample Input Log file entry with 4 lines are below. My log file consists of entries for days of data.\r\n\r\n    { &quot;Utility&quot;:&quot;DBUpdate&quot;, &quot;StartDate&quot;:&quot;2020-09-21&quot;, &quot;StartTime&quot;:&quot;14:41:12&quot;, &quot;Server&quot;:&quot;eaidev&quot;, &quot;Userid&quot;:&quot;sx50067&quot;, &quot;TrueExit&quot;:&quot;No&quot;, &quot;WaitInterval&quot;:30, &quot;Cluster&quot;:&quot;1&quot;, &quot;Source&quot;:&quot;MANNING1&quot;, &quot;Target&quot;:&quot;MANNING2&quot;, &quot;ClusterListCt&quot;:5, &quot;ListCt&quot;:55, &quot;RequestServer&quot;:&quot;MANNING3&quot;, &quot;Reply&quot;:&quot;JOT4&quot;, &quot;ISC(Source)&quot;:0, &quot;EndDate&quot;:&quot;2020-09-21&quot;, &quot;EndTime&quot;:&quot;14:41:21&quot;, &quot;ExitCode&quot;:0 }\r\n    { &quot;Utility&quot;:&quot;DBUpdate&quot;, &quot;StartDate&quot;:&quot;2020-09-22&quot;, &quot;StartTime&quot;:&quot;14:41:12&quot;, &quot;Server&quot;:&quot;eaidev&quot;, &quot;Userid&quot;:&quot;sx50067&quot;, &quot;TrueExit&quot;:&quot;No&quot;, &quot;WaitInterval&quot;:30, &quot;Cluster&quot;:&quot;1&quot;, &quot;Source&quot;:&quot;MANNING1&quot;, &quot;Target&quot;:&quot;MANNING2&quot;, &quot;ClusterListCt&quot;:5, &quot;ListCt&quot;:55, &quot;RequestServer&quot;:&quot;MANNING3&quot;, &quot;Reply&quot;:&quot;JOT4&quot;, &quot;ISC(Source)&quot;:0, &quot;EndDate&quot;:&quot;2020-09-22&quot;, &quot;EndTime&quot;:&quot;14:41:21&quot;, &quot;ExitCode&quot;:0 }\r\n    { &quot;Utility&quot;:&quot;DBUpdate&quot;, &quot;StartDate&quot;:&quot;2020-09-23&quot;, &quot;StartTime&quot;:&quot;14:41:12&quot;, &quot;Server&quot;:&quot;eaidev&quot;, &quot;Userid&quot;:&quot;sx50067&quot;, &quot;TrueExit&quot;:&quot;No&quot;, &quot;WaitInterval&quot;:30, &quot;Cluster&quot;:&quot;1&quot;, &quot;Source&quot;:&quot;MANNING1&quot;, &quot;Target&quot;:&quot;MANNING2&quot;, &quot;ClusterListCt&quot;:5, &quot;ListCt&quot;:55, &quot;RequestServer&quot;:&quot;MANNING3&quot;, &quot;Reply&quot;:&quot;JOT4&quot;, &quot;ISC(Source)&quot;:0, &quot;EndDate&quot;:&quot;2020-09-23&quot;, &quot;EndTime&quot;:&quot;14:41:29&quot;, &quot;ExitCode&quot;:0 }\r\n    { &quot;Utility&quot;:&quot;DBUpdate&quot;, &quot;StartDate&quot;:&quot;2020-09-23&quot;, &quot;StartTime&quot;:&quot;14:42:12&quot;, &quot;Server&quot;:&quot;eaidev&quot;, &quot;Userid&quot;:&quot;sx50067&quot;, &quot;TrueExit&quot;:&quot;No&quot;, &quot;WaitInterval&quot;:30, &quot;Cluster&quot;:&quot;1&quot;, &quot;Source&quot;:&quot;MANNING1&quot;, &quot;Target&quot;:&quot;MANNING2&quot;, &quot;ClusterListCt&quot;:5, &quot;ListCt&quot;:55, &quot;RequestServer&quot;:&quot;MANNING3&quot;, &quot;Reply&quot;:&quot;JOT4&quot;, &quot;ISC(Source)&quot;:0, &quot;EndDate&quot;:&quot;2020-09-23&quot;, &quot;EndTime&quot;:&quot;14:43:21&quot;, &quot;ExitCode&quot;:0 }\r\n\r\nIn a separate script, I run a job and I capture Start Date and Time and I also capture my End date and End Time into a Temp file like below.\r\n\r\n    2020-09-23 14:41:12\r\n    2020-09-23 14:43:21\r\n\r\nI am using variables like the below in my script to capture these times.\r\n\r\n    DATETIME=$(date &#39;+%Y-%m-%d %T&#39;)\r\n    DATE=$(echo &quot;${END_DATETIME}&quot; | cut -f1 -d&#39; &#39;)\r\n    TIME=$(echo &quot;${END_DATETIME}&quot; | cut -f2 -d&#39; &#39;)\r\n\r\nUsing my input file data which has a start and end date times of my program, I want to capture all the logfile lines in between my Start Time and End Time and write it to a file.\r\n\r\nI expect my new log file to be like this:\r\n\r\n    { &quot;Utility&quot;:&quot;DBUpdate&quot;, &quot;StartDate&quot;:&quot;2020-09-23&quot;, &quot;StartTime&quot;:&quot;14:41:12&quot;, &quot;Server&quot;:&quot;eaidev&quot;, &quot;Userid&quot;:&quot;sx50067&quot;, &quot;TrueExit&quot;:&quot;No&quot;, &quot;WaitInterval&quot;:30, &quot;Cluster&quot;:&quot;1&quot;, &quot;Source&quot;:&quot;MANNING1&quot;, &quot;Target&quot;:&quot;MANNING2&quot;, &quot;ClusterListCt&quot;:5, &quot;ListCt&quot;:55, &quot;RequestServer&quot;:&quot;MANNING3&quot;, &quot;Reply&quot;:&quot;JOT4&quot;, &quot;ISC(Source)&quot;:0, &quot;EndDate&quot;:&quot;2020-09-23&quot;, &quot;EndTime&quot;:&quot;14:41:29&quot;, &quot;ExitCode&quot;:0 }\r\n    { &quot;Utility&quot;:&quot;DBUpdate&quot;, &quot;StartDate&quot;:&quot;2020-09-23&quot;, &quot;StartTime&quot;:&quot;14:42:12&quot;, &quot;Server&quot;:&quot;eaidev&quot;, &quot;Userid&quot;:&quot;sx50067&quot;, &quot;TrueExit&quot;:&quot;No&quot;, &quot;WaitInterval&quot;:30, &quot;Cluster&quot;:&quot;1&quot;, &quot;Source&quot;:&quot;MANNING1&quot;, &quot;Target&quot;:&quot;MANNING2&quot;, &quot;ClusterListCt&quot;:5, &quot;ListCt&quot;:55, &quot;RequestServer&quot;:&quot;MANNING3&quot;, &quot;Reply&quot;:&quot;JOT4&quot;, &quot;ISC(Source)&quot;:0, &quot;EndDate&quot;:&quot;2020-09-23&quot;, &quot;EndTime&quot;:&quot;14:43:21&quot;, &quot;ExitCode&quot;:0 }\r\n\r\n\r\n\r\nI am able to capture logs based on date but when it comes to time, I am getting more than what I want. Can you please suggest?",
        "link": "https://stackoverflow.com/questions/64037572/capture-all-the-logs-between-two-time-stamps-of-a-json-format-log",
        "title": "Capture all the logs between two time stamps of a json format log"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1600937167,
                "creation_date": 1600937167,
                "answer_id": 64042745,
                "question_id": 64042640,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`map(select(.id == &quot;second&quot;))` expects an array of objects, however `.[]` takes them out of the array so everything after that must be able to work on single item.\r\n\r\nIn your jqplay example your filter is `.[] | select(.id == &quot;second&quot;)` and is working fine.\r\n\r\nIt should be obvious now how to fix your issue ;)\r\n\r\n",
                "title": "jq (map(select))Cannot index string with string &quot;ID&quot; exit status 5"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1600937191,
        "creation_date": 1600936771,
        "last_edit_date": 1600937191,
        "question_id": 64042640,
        "body_markdown": "data:\r\n\r\n    [{&quot;id&quot;: &quot;first&quot;, &quot;val&quot;: 1}, {&quot;id&quot;: &quot;second&quot;, &quot;val&quot;: 2}, {&quot;id&quot;: &quot;second&quot;, &quot;val&quot;: 3}]\r\n\r\nquery:\r\n\r\n    .[] | map(select(.id == &quot;second&quot;))\r\n\r\nexpected:\r\n\r\n    {&quot;id&quot;: &quot;second&quot;, &quot;val&quot;: 2}, {&quot;id&quot;: &quot;second&quot;, &quot;val&quot;: 3}\r\n\r\nresult:\r\n\r\n    Cannot index string with string &quot;id&quot;\r\n\r\nhttps://jqplay.org/jq?q=.%5B%5D%20%7C%20select(.id%20%3D%3D%20%22second%22)&amp;j=%5B%7B%22id%22%3A%20%22first%22%2C%20%22val%22%3A%201%7D%2C%20%7B%22id%22%3A%20%22second%22%2C%20%22val%22%3A%202%7D%5D\r\n\r\nWhy could be this result?\r\n",
        "link": "https://stackoverflow.com/questions/64042640/jq-mapselectcannot-index-string-with-string-id-exit-status-5",
        "title": "jq (map(select))Cannot index string with string &quot;ID&quot; exit status 5"
    },
    {
        "tags": [
            "json",
            "bash",
            "merge",
            "key",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1601061991,
                "last_edit_date": 1601061991,
                "creation_date": 1600993271,
                "answer_id": 64056101,
                "question_id": 64052172,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If `$.Parameter` object is simple as in your example\r\n\r\n``` bash\r\njq \\\r\n --argjson a &#39;{ &quot;Parameters&quot;: { &quot;a&quot;: &quot;value-of-a&quot;, &quot;b&quot;: &quot;value-of-b&quot; } }&#39; \\\r\n --argjson b &#39;{ &quot;Parameters&quot;: { &quot;a&quot;: &quot;new-value-of-a&quot;, &quot;c&quot;: &quot;value-of-c&quot; } }&#39; \\\r\n -n &#39;\r\n   $a | .Parameters | keys_unsorted as $whitelist \r\n | $b | .Parameters | with_entries( select(.key | IN($whitelist[])) ) as $update\r\n | $a | .Parameters += $update &#39;\r\n\r\n```\r\n\r\nIf you have two files, you could (for example) use `input` twice instead of `--argjson`.",
                "title": "Merge 2 JSON objects with jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1601074815,
                "last_edit_date": 1601074815,
                "creation_date": 1600999407,
                "answer_id": 64056743,
                "question_id": 64052172,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a solution that’s both simple and efficient:\r\n```\r\njq -n &#39;\r\n   input.Parameters as $dict\r\n   | input\r\n   | .Parameters |= reduce keys_unsorted[] as $k (.;\r\n       if ($dict|has($k)) then .[$k] = $dict[$k] else . end)\r\n&#39; v2.json v1.json \r\n```\r\n\r\nIf the two values are shell variables, you can use `--argjson` or simply echo them:\r\n\r\n    echo &quot;$v2&quot; &quot;$v1&quot; | jq -n &#39;...&#39;\r\n\r\nThere are other ways to provide the two values, but in general it’s best to avoid the -s command-line option.",
                "title": "Merge 2 JSON objects with jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1601057694,
                "last_edit_date": 1601057694,
                "creation_date": 1601033463,
                "answer_id": 64063300,
                "question_id": 64052172,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a reduce-free solution that&#39;s conceptually simple and scales well:\r\n```\r\njq -n &#39;\r\n   # Emit the object with key-value pairs of $o2 \r\n   # for keys that appear in both . and $o2\r\n   def commonKeys($o2):\r\n     keys_unsorted as $k1\r\n     | ($o2|keys_unsorted) as $k2\r\n     | [($k1 - ($k1-$k2))[] | {(.): $o2[.]}] | add\r\n   ;\r\n   input.Parameters as $dict\r\n   | input\r\n   | .Parameters |= (. + commonKeys($dict))\r\n\r\n&#39; v2.json v1.json \r\n```",
                "title": "Merge 2 JSON objects with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 5,
        "last_activity_date": 1601074815,
        "creation_date": 1600971462,
        "last_edit_date": 1601025466,
        "question_id": 64052172,
        "body_markdown": "I have 2 json objects in 2 variables V1 and V2.\r\n\r\nV1 is \r\n``` \r\n{\r\n  &quot;Parameters: {\r\n     &quot;a&quot;: &quot;value-of-a&quot;,\r\n     &quot;b&quot;: &quot;value-of-b&quot;\r\n  }\r\n}\r\n```\r\n\r\nV2 is \r\n```\r\n{\r\n  &quot;Parameters&quot;: {\r\n     &quot;a&quot;: &quot;new-value-of-a&quot;,\r\n     &quot;c&quot;: &quot;value-of-c&quot;\r\n  }\r\n}\r\n```\r\n\r\n\r\nI want to override the V1&#39;s values with values from V2. I want to generate a new JSON that looks like this:\r\n\r\n**Expected**\r\n```\r\n{\r\n   &quot;Parameters&quot;: {\r\n      &quot;a&quot;: &quot;new-value-of-a&quot;,\r\n      &quot;b&quot;: &quot;value-of-b&quot;\r\n   }\r\n}\r\n```\r\n\r\nI tried the following:\r\n\r\n```\r\n(\r\necho &#39;{ &quot;Parameters&quot;: { &quot;a&quot;: &quot;value-of-a&quot;, &quot;b&quot;: &quot;value-of-b&quot; } }&#39;\\\r\n&#39;{ &quot;Parameters&quot;: { &quot;a&quot;: &quot;new-value-of-a&quot;, &quot;c&quot;: &quot;value-of-c&quot; } }&#39;\\\r\n| jq --slurp &#39;reduce .[] as $item ({}; . * $item)&#39;\r\n)\r\n\r\n```\r\n\r\nbut this generates\r\n\r\n**Actual**\r\n```\r\n{\r\n   &quot;Parameters&quot;: {\r\n      &quot;a&quot;: &quot;new-value-of-a&quot;,\r\n      &quot;b&quot;: &quot;value-of-b&quot;,\r\n      &quot;c&quot;: &quot;value-of-c&quot;\r\n   }\r\n}\r\n```\r\n\r\nThe problem is that I don&#39;t want the nodes in V2 that don&#39;t exist in V1 to appear in the result. Can anyone help me?",
        "link": "https://stackoverflow.com/questions/64052172/merge-2-json-objects-with-jq",
        "title": "Merge 2 JSON objects with jq"
    },
    {
        "tags": [
            "select",
            "filter",
            "jq",
            "cloudflare"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1601001657,
                "creation_date": 1601001657,
                "answer_id": 64057039,
                "question_id": 64056168,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This produces the expected output in accordance with the criteria as I understand them:\r\n```\r\njq &#39;.[&quot;example.org&quot;]\r\n    | map(select( any(.actions[]; .id == &quot;always_use_https&quot;))\r\n          | .targets[]\r\n          | select(.target == &quot;url&quot;)\r\n          | .constraint.value )\r\n&#39; cloudfare.json\r\n```",
                "title": "selecting and filtering cloudflare pagerules with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1601001657,
        "creation_date": 1600993967,
        "last_edit_date": 1600994422,
        "question_id": 64056168,
        "body_markdown": "I was trying to work out the best way to filter out some pagerules data from Cloudflare, and while I&#39;ve got a solution I&#39;m looking at how ugly it is and thinking &quot;there has to be a simpler way to do this.&quot;\r\n\r\nI&#39;m specifically asking about a better way to achieve the following goal using jq.  I understand there are programming libraries I could use to accomplish the same, but the point of this question is to get a better understanding of how jq is intended to work.\r\n\r\nSay I&#39;ve got a long list of CloudFlare pagerules records, here are a few  entries as a minimal example:\r\n```\r\n{\r\n  &quot;example.org&quot;: [\r\n    {\r\n      &quot;id&quot;: &quot;341&quot;,\r\n      &quot;targets&quot;: [\r\n        {\r\n          &quot;target&quot;: &quot;url&quot;,\r\n          &quot;constraint&quot;: {\r\n            &quot;operator&quot;: &quot;matches&quot;,\r\n            &quot;value&quot;: &quot;http://ng.example.org/*&quot;\r\n          }\r\n        }\r\n      ],\r\n      &quot;actions&quot;: [\r\n        {\r\n          &quot;id&quot;: &quot;always_use_https&quot;\r\n        }\r\n      ],\r\n      &quot;priority&quot;: 12,\r\n      &quot;status&quot;: &quot;active&quot;,\r\n      &quot;created_on&quot;: &quot;2017-11-29T18:07:36.000000Z&quot;,\r\n      &quot;modified_on&quot;: &quot;2020-09-02T16:09:03.000000Z&quot;\r\n    },\r\n    {\r\n      &quot;id&quot;: &quot;406&quot;,\r\n      &quot;targets&quot;: [\r\n        {\r\n          &quot;target&quot;: &quot;url&quot;,\r\n          &quot;constraint&quot;: {\r\n            &quot;operator&quot;: &quot;matches&quot;,\r\n            &quot;value&quot;: &quot;http://nz.example.org/*&quot;\r\n          }\r\n        }\r\n      ],\r\n      &quot;actions&quot;: [\r\n        {\r\n          &quot;id&quot;: &quot;always_use_https&quot;\r\n        }\r\n      ],\r\n      &quot;priority&quot;: 9,\r\n      &quot;status&quot;: &quot;active&quot;,\r\n      &quot;created_on&quot;: &quot;2017-11-29T18:07:55.000000Z&quot;,\r\n      &quot;modified_on&quot;: &quot;2020-09-02T16:09:03.000000Z&quot;\r\n    },\r\n    {\r\n      &quot;id&quot;: &quot;427&quot;,\r\n      &quot;targets&quot;: [\r\n        {\r\n          &quot;target&quot;: &quot;url&quot;,\r\n          &quot;constraint&quot;: {\r\n            &quot;operator&quot;: &quot;matches&quot;,\r\n            &quot;value&quot;: &quot;nz.example.org/*&quot;\r\n          }\r\n        }\r\n      ],\r\n      &quot;actions&quot;: [\r\n        {\r\n          &quot;id&quot;: &quot;ssl&quot;,\r\n          &quot;value&quot;: &quot;flexible&quot;\r\n        }\r\n      ],\r\n      &quot;priority&quot;: 8,\r\n      &quot;status&quot;: &quot;active&quot;,\r\n      &quot;created_on&quot;: &quot;2017-11-29T18:08:00.000000Z&quot;,\r\n      &quot;modified_on&quot;: &quot;2020-09-02T16:09:03.000000Z&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nWhat I want to do is extract the urls nested in the constraint.value fields for the always_use_https actions.  The goal is to extract the values and return them as a json array. What I came up with is this:\r\n\r\n```\r\njq &#39;[                                       \r\n        [\r\n                [\r\n                        [\r\n                                .[] | .[] | select(.actions[].id | contains(&quot;always_use_https&quot;))\r\n                        ] | .[].targets[] | select(.target | contains(&quot;url&quot;))\r\n                ] | .[] | .constraint | select(.operator | contains(&quot;matches&quot;))\r\n        ] | .[].value \r\n]&#39;\r\n```\r\n\r\nAgainst our example this produces:\r\n\r\n```\r\n[\r\n  &quot;http://ng.example.org/*&quot;,\r\n  &quot;http://nz.example.org/*&quot;\r\n]\r\n```\r\n\r\nIs there a more succinct way to achieve this in jq?\r\n",
        "link": "https://stackoverflow.com/questions/64056168/selecting-and-filtering-cloudflare-pagerules-with-jq",
        "title": "selecting and filtering cloudflare pagerules with jq"
    },
    {
        "tags": [
            "python",
            "amazon-web-services",
            "amazon-s3",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1022874,
                    "reputation": 35264,
                    "user_id": 1032785,
                    "user_type": "registered",
                    "accept_rate": 50,
                    "profile_image": "https://www.gravatar.com/avatar/30816b3d787c2bd9d6f036318304f225?s=256&d=identicon&r=PG",
                    "display_name": "jordanm",
                    "link": "https://stackoverflow.com/users/1032785/jordanm"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1601066325,
                "post_id": 64070856,
                "comment_id": 113299565,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 19533528,
                    "reputation": 33,
                    "user_id": 14292776,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b77713c437b7f3a14820ed87008b353d?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Kumar",
                    "link": "https://stackoverflow.com/users/14292776/kumar"
                },
                "reply_to_user": {
                    "account_id": 1022874,
                    "reputation": 35264,
                    "user_id": 1032785,
                    "user_type": "registered",
                    "accept_rate": 50,
                    "profile_image": "https://www.gravatar.com/avatar/30816b3d787c2bd9d6f036318304f225?s=256&d=identicon&r=PG",
                    "display_name": "jordanm",
                    "link": "https://stackoverflow.com/users/1032785/jordanm"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1601066817,
                "post_id": 64070856,
                "comment_id": 113299718,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": -1,
                "last_activity_date": 1601093466,
                "creation_date": 1601093466,
                "answer_id": 64073800,
                "question_id": 64070856,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can do this if you want to execute it from a python script:\r\n\r\n```python\r\nimport os\r\nos.system(&#39;cmd /k &quot;curl https://ip-ranges.amazonaws.com/ip-ranges.json | jq -r \\&#39;.prefixes[] | select(.service==\\&quot;CLOUDFRONT\\&quot;) | \\&quot;set_real_ip_from \\(.ip_prefix);\\&quot; \\&#39; &gt; set_real_ip_from.inc&quot;&#39;)\r\n```",
                "title": "Automate to fetch the CLOUDFRONT IP list from https://ip-ranges.amazonaws.com/ip-ranges.json"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1601093466,
        "creation_date": 1601065084,
        "last_edit_date": 1601089885,
        "question_id": 64070856,
        "body_markdown": "Is there a way to execute the below command in Python script to automate and get the results as expected below in an s3 bucket:\r\n\r\n    curl https://ip-ranges.amazonaws.com/ip-ranges.json |\r\n      jq -r &#39;.prefixes[] | select(.service==&quot;CLOUDFRONT&quot;) | &quot;set_real_ip_from \\(.ip_prefix);&quot;\r\n      &#39; &gt; set_real_ip_from.inc\r\n\r\nOutput of the command:\r\n\r\n    set_real_ip_from 34.216.51.0/25;\r\n    set_real_ip_from 34.223.12.224/27;\r\n    set_real_ip_from 34.223.80.192/26;\r\n    set_real_ip_from 34.226.14.0/24;\r\n    set_real_ip_from 35.158.136.0/24;\r\n    set_real_ip_from 35.162.63.192/26;\r\n    set_real_ip_from 35.167.191.128/26;\r\n    set_real_ip_from 44.227.178.0/24;\r\n    set_real_ip_from 44.234.108.128/25;\r\n    set_real_ip_from 44.234.90.252/30;\r\n    set_real_ip_from 52.15.127.128/26;\r\n\r\n",
        "link": "https://stackoverflow.com/questions/64070856/automate-to-fetch-the-cloudfront-ip-list-from-https-ip-ranges-amazonaws-com-ip",
        "title": "Automate to fetch the CLOUDFRONT IP list from https://ip-ranges.amazonaws.com/ip-ranges.json"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1601140141,
                "creation_date": 1601140141,
                "answer_id": 64080453,
                "question_id": 64080087,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Maybe this?\r\n\r\n    jq &#39;.[] |= sort_by(.created_at) | sort_by(.[].created_at)&#39;\r\n\r\n\r\n\r\n",
                "title": "Sort an array of objects within an array by most recent timestamp, and then sort the outer array by each array&#39;s first object&#39;s timestamp, using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1601140141,
        "creation_date": 1601137994,
        "question_id": 64080087,
        "body_markdown": "Sort an array of objects within an array by most recent timestamp, and then sort the outer array by each array&#39;s first object&#39;s timestamp, using `jq`.\r\n\r\nThis is an example of the JSON data, at the stage of the `jq` pipeline where I&#39;m stuck.\r\n\r\n    [\r\n      [\r\n        {\r\n          &quot;created_at&quot;: &quot;2020-09-26T14:48:46.000Z&quot;,\r\n          &quot;conversation_id&quot;: &quot;1309867515456237571&quot;,\r\n          &quot;id&quot;: &quot;1309867515456237571&quot;,\r\n          &quot;text&quot;: &quot;example1&quot;\r\n        }\r\n      ],\r\n      [\r\n        {\r\n          &quot;created_at&quot;: &quot;2020-09-26T14:48:47.000Z&quot;,\r\n          &quot;conversation_id&quot;: &quot;1309867518455156736&quot;,\r\n          &quot;id&quot;: &quot;1309867518455156736&quot;,\r\n          &quot;text&quot;: &quot;example2&quot;\r\n        },\r\n        {\r\n          &quot;created_at&quot;: &quot;2020-09-26T14:48:47.000Z&quot;,\r\n          &quot;conversation_id&quot;: &quot;1309867518455156736&quot;,\r\n          &quot;id&quot;: &quot;1309867517846810625&quot;,\r\n          &quot;text&quot;: &quot;example3&quot;\r\n        },\r\n        {\r\n          &quot;created_at&quot;: &quot;2020-09-26T14:48:46.000Z&quot;,\r\n          &quot;conversation_id&quot;: &quot;1309867518455156736&quot;,\r\n          &quot;id&quot;: &quot;1309867516659937284&quot;,\r\n          &quot;text&quot;: &quot;example4&quot;\r\n        }\r\n      ],\r\n      [\r\n        {\r\n          &quot;created_at&quot;: &quot;2020-09-26T14:48:48.000Z&quot;,\r\n          &quot;conversation_id&quot;: &quot;1309867524473999364&quot;,\r\n          &quot;id&quot;: &quot;1309867524473999364&quot;,\r\n          &quot;text&quot;: &quot;example5&quot;\r\n        },\r\n        {\r\n          &quot;created_at&quot;: &quot;2020-09-26T14:48:47.000Z&quot;,\r\n          &quot;conversation_id&quot;: &quot;1309867524473999364&quot;,\r\n          &quot;id&quot;: &quot;1309867520468291586&quot;,\r\n          &quot;text&quot;: &quot;example6&quot;\r\n        },\r\n        {\r\n          &quot;created_at&quot;: &quot;2020-09-26T14:48:47.000Z&quot;,\r\n          &quot;conversation_id&quot;: &quot;1309867524473999364&quot;,\r\n          &quot;id&quot;: &quot;1309867520153845760&quot;,\r\n          &quot;text&quot;: &quot;example7&quot;\r\n        }\r\n      ],\r\n      [\r\n        {\r\n          &quot;created_at&quot;: &quot;2020-09-26T14:48:48.000Z&quot;,\r\n          &quot;conversation_id&quot;: &quot;1309867524750749705&quot;,\r\n          &quot;id&quot;: &quot;1309867524750749705&quot;,\r\n          &quot;text&quot;: &quot;example8&quot;\r\n        }\r\n      ]\r\n    ]\r\n\r\nEverything I&#39;ve tried ends up with an error like this one, \r\n\r\n    jq: error (at &lt;stdin&gt;:8): Cannot index string with string &quot;created_at&quot;\r\n\r\n\r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/64080087/sort-an-array-of-objects-within-an-array-by-most-recent-timestamp-and-then-sort",
        "title": "Sort an array of objects within an array by most recent timestamp, and then sort the outer array by each array&#39;s first object&#39;s timestamp, using jq"
    },
    {
        "tags": [
            "json",
            "jq",
            "aws-cli",
            "depagination"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1601219990,
                "last_edit_date": 1601219990,
                "creation_date": 1601159022,
                "answer_id": 64083041,
                "question_id": 64081670,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a solution that&#39;s both simple and efficient. It assumes that `out.*.json` identifies the relevant files in the required order if any.\r\n\r\n    jq -n &#39;{Snapshots: [inputs.Snapshots] | add}&#39; out.*.json\r\n\r\nNote that the -n option is necessary here.",
                "title": "merge aws cli results"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1601259043,
        "creation_date": 1601148077,
        "last_edit_date": 1601259043,
        "question_id": 64081670,
        "body_markdown": "I am trying to figure out how to join results of aws cli paginated output.\r\nSay the query looks like so:\r\n```aws ec2 describe-snapshots --output json --max-items 100 --starting-token ABC-123```\r\nUsing the next token I am generating N files: out.0.json, out.1.json, ...\r\n\r\nEach such file looks like so:\r\n\r\n    {\r\n    &quot;Snapshots&quot;: [\r\n        {\r\n            &quot;Description&quot;: &quot;hvm/ubuntu-vivid-amd64-server-20160119&quot;,\r\n            &quot;Encrypted&quot;: false,\r\n            &quot;OwnerId&quot;: &quot;0123456789&quot;,\r\n            &quot;Progress&quot;: &quot;100%&quot;,\r\n            &quot;SnapshotId&quot;: &quot;snap-0001&quot;,\r\n            &quot;StartTime&quot;: &quot;2016-01-19T19:24:47+00:00&quot;,\r\n            &quot;State&quot;: &quot;completed&quot;,\r\n            &quot;VolumeId&quot;: &quot;vol-0001&quot;,\r\n            &quot;VolumeSize&quot;: 8\r\n        },\r\n        {\r\n            &quot;Description&quot;: &quot;ebs/ubuntu-trusty-i386-server-20151007&quot;,\r\n            &quot;Encrypted&quot;: false,\r\n            &quot;OwnerId&quot;: &quot;0123456789&quot;,\r\n            &quot;Progress&quot;: &quot;100%&quot;,\r\n            &quot;SnapshotId&quot;: &quot;snap-1234&quot;,\r\n            &quot;StartTime&quot;: &quot;2015-10-07T23:09:20+00:00&quot;,\r\n            &quot;State&quot;: &quot;completed&quot;,\r\n            &quot;VolumeId&quot;: &quot;vol-1235&quot;,\r\n            &quot;VolumeSize&quot;: 8\r\n        },\r\n        {\r\n            &quot;Description&quot;: &quot;hvm-io1/ubuntu-precise-amd64-server-20150512&quot;,\r\n            &quot;Encrypted&quot;: false,\r\n            &quot;OwnerId&quot;: &quot;0123456789&quot;,\r\n            &quot;Progress&quot;: &quot;100%&quot;,\r\n            &quot;SnapshotId&quot;: &quot;snap-1235&quot;,\r\n            &quot;StartTime&quot;: &quot;2015-05-13T02:17:25+00:00&quot;,\r\n            &quot;State&quot;: &quot;completed&quot;,\r\n            &quot;VolumeId&quot;: &quot;vol-1235&quot;,\r\n            &quot;VolumeSize&quot;: 8\r\n        },\r\n        .......\r\n\r\nHow do I merge the list of snapshots from all files into one? I tried jq with merge, but nothing seems to work ",
        "link": "https://stackoverflow.com/questions/64081670/merge-aws-cli-results",
        "title": "merge aws cli results"
    },
    {
        "tags": [
            "arrays",
            "bash",
            "indexing",
            "jq",
            "content-length"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 10015983,
                    "reputation": 144648,
                    "user_id": 9072753,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/EPmGy.jpg?s=256",
                    "display_name": "KamilCuk",
                    "link": "https://stackoverflow.com/users/9072753/kamilcuk"
                },
                "edited": false,
                "score": 4,
                "creation_date": 1601238159,
                "post_id": 64092857,
                "comment_id": 113337428,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 16866054,
                    "reputation": 678,
                    "user_id": 12195738,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/bb8c0eefb4c0dec068d194f2af23eeb1?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Rfroes87",
                    "link": "https://stackoverflow.com/users/12195738/rfroes87"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1601238292,
                "post_id": 64092857,
                "comment_id": 113337465,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 6,
                "is_accepted": true,
                "score": 6,
                "last_activity_date": 1603398224,
                "last_edit_date": 1603398224,
                "creation_date": 1601238646,
                "answer_id": 64093036,
                "question_id": 64092857,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; why it is happening?\r\n\r\nBecause it reads one line. From [bash manual here document](https://www.gnu.org/software/bash/manual/bash.html):\r\n\r\n&gt;    [n]&lt;&lt;&lt; word\r\n\r\n&gt; [...] The result is supplied as a single string, __with a newline appended__, to the command on its standard input (or file descriptor n if n is specified). \r\n\r\nBecause there is a newline, `readarray` reads one empty line. You may do:\r\n\r\n    readarray -t b &lt; &lt;(printf &quot;%s&quot; &quot;$emptystring&quot;)\r\n\r\nNotes:\r\n\r\n- `echo &quot;$var&quot;` is not preferred. Do `printf &quot;%s&quot; &quot;$var&quot;` when in posix shell, do `&lt;&lt;&lt;&quot;$var&quot;` when in bash (and you do not care about the extra newline).\r\n- `&lt;&lt;&lt;&quot;$(...)&quot;` always looks strange - the `&lt;&lt;&lt;` has to allocate a subshell anyway. Do `&lt; &lt;(...)`.\r\n- You want to do: `readarray -t URL_names &lt; &lt;(&lt;&lt;&lt;&quot;$URL_list_json&quot; jq -r &#39;.[].Body.monitors[].name&#39;)`\r\n- If you want to check if the array is empty, check that in `jq`. [I see ex.](https://github.com/stedolan/jq/issues/1272) `jq --exit-status &#39;.[].Body.monitors[].name&#39;` and just check the exit status.",
                "title": "Problem with bash readarray -t array assignment when jq outputs an empty string"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 9,
        "last_activity_date": 1603398224,
        "creation_date": 1601237344,
        "question_id": 64092857,
        "body_markdown": "First - a very simple code:\r\n```\r\n#!/bin/bash\r\n\r\na_string=&quot;string&quot;\r\nreadarray -t a &lt;&lt;&lt;&quot;$a_string&quot;\r\necho &quot;${a[@]}&quot;\r\necho &quot;${#a[@]}&quot;\r\n\r\n# read empty string into array\r\nemptystring=&quot;&quot;\r\nreadarray -t b &lt;&lt;&lt;&quot;$emptystring&quot;\r\necho &quot;${b[@]}&quot;\r\necho &quot;${#b[@]}&quot;\r\n\r\n# and now - empty array\r\nc=()\r\necho &quot;${c[@]}&quot;\r\necho &quot;${#c[@]}&quot;\r\n```\r\n\r\nAnd the output\r\n```\r\nstring\r\n1\r\n\r\n1\r\n\r\n0\r\n```\r\nSo reading an empty string into bash array with ``readarray -t`` shows array length as 1. And only truly empty array&#39;s length is 0.\r\n\r\nMy question - why it is happening? \r\n\r\nAs my case - here is a fragment from my script - execute an API call, get JSON, and apply jq filter:\r\n```\r\nURL_list_json=$(curl -s --request GET &quot;$curl_request&quot; --header &quot;Authorization: Bearer ${token}&quot;)\r\nreadarray -t URL_names &lt;&lt;&lt;&quot;$(echo &quot;$URL_list_json&quot; | jq -r &#39;.[].Body.monitors[].name&#39;)&quot;\r\n```\r\nHere is an example of JSON which results an empty array from the jq call:\r\n```\r\n[\r\n    {\r\n        &quot;Header&quot;: {\r\n            &quot;Region&quot;: &quot;dc1&quot;,\r\n            &quot;Tenant&quot;: &quot;tenant1&quot;,\r\n            &quot;Stage&quot;: &quot;test&quot;\r\n        },\r\n        &quot;Body&quot;: {\r\n            &quot;monitors&quot;: []\r\n        }\r\n    }\r\n]\r\n```\r\nand here is JSON with populated content returning a non-empty array from jq call:\r\n```\r\n[\r\n    {\r\n        &quot;Header&quot;: {\r\n            &quot;Region&quot;: &quot;dc2&quot;,\r\n            &quot;Tenant&quot;: &quot;tenant2&quot;,\r\n            &quot;Stage&quot;: &quot;qa&quot;\r\n        },\r\n        &quot;Body&quot;: {\r\n            &quot;monitors&quot;: [\r\n                {\r\n                    &quot;enabled&quot;: true,\r\n                    &quot;entityId&quot;: &quot;TEST-674BA97E74FC74AA&quot;,\r\n                    &quot;name&quot;: &quot;production.example.com&quot;\r\n                },\r\n                {\r\n                    &quot;enabled&quot;: false,\r\n                    &quot;entityId&quot;: &quot;TEST-3E2D23438A973D1E&quot;,\r\n                    &quot;name&quot;: &quot;test.example.com&quot;\r\n                }\r\n            ]\r\n        }\r\n    }\r\n]\r\n\r\n```\r\n\r\nI need to check if ``URL_names`` array is empty or not. If not empty, then iterate over contents. If empty - means that jq did not return any results - white to log and move on.\r\n\r\nIf I use ``if ((${#URL_names[@]}))`` as a means to check if the array is empty or not, it will return 1 even if the array has just an empty string from the jq call, so this logic fails.\r\n\r\nWhat are alternative approaches to deal with the case like above? \r\n\r\nI can assign the output of the jq filter to a string and then use **if** statement to check if the string is empty and if non-empty then assign the string to an array, but this introduces additional elements. With this approach, I can skip using arrays entirely - I was hoping to use only arrays for this task.\r\n\r\nThanks",
        "link": "https://stackoverflow.com/questions/64092857/problem-with-bash-readarray-t-array-assignment-when-jq-outputs-an-empty-string",
        "title": "Problem with bash readarray -t array assignment when jq outputs an empty string"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1601241729,
                "post_id": 64093421,
                "comment_id": 113338287,
                "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": 1601241745,
                "post_id": 64093421,
                "comment_id": 113338294,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1601241809,
                "creation_date": 1601241809,
                "answer_id": 64093463,
                "question_id": 64093421,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You need to surround `something|something` with quotes in order to escape the pipe character:\r\n\r\n    .properties.&quot;something|something&quot;\r\n\r\n**[jqplay snippet](https://jqplay.org/s/moPXSMjSQz)**",
                "title": "JQ extract error for key containing pipe character"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1601242093,
        "creation_date": 1601241471,
        "last_edit_date": 1601241892,
        "question_id": 64093421,
        "body_markdown": "I am trying to extract the value for something|something key in my below JSON but getting a compile error\r\n\r\n      {\r\n        &quot;properties&quot;: {\r\n          &quot;Anything&quot;: &quot;ABCD&quot;,\r\n          &quot;something|something&quot;: &quot;unknown&quot;\r\n        }\r\n      }\r\n\r\n\r\nThe filter `.properties | .something|something` is giving me below error when I try it in [Jqplay.org][1].\r\n\r\n&gt; jq: error: something/0 is not defined at &lt;top-level&gt;, line 1:\r\n&gt; .properties | .something|something                         \r\njq: 1 compile error\r\nexit status 3\r\n\r\n\r\n\r\n  [1]: https://jqplay.org/",
        "link": "https://stackoverflow.com/questions/64093421/jq-extract-error-for-key-containing-pipe-character",
        "title": "JQ extract error for key containing pipe character"
    },
    {
        "tags": [
            "json",
            "join",
            "merge",
            "jq",
            "concatenation"
        ],
        "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": 1601367022,
                "post_id": 64114407,
                "comment_id": 113378075,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1601365446,
                "last_edit_date": 1601365446,
                "creation_date": 1601363815,
                "answer_id": 64114654,
                "question_id": 64114407,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It looks like you have a collection of bits of information about users. You can&#39;t just flatten them down by merging everything that has the same `id`, they need to be separate.\r\n\r\nYou have &quot;user info&quot; (full name and email) and &quot;team info&quot;. You need to group by the id, then by the type, then distribute the &quot;user info&quot;.\r\n\r\nHere&#39;s one approach you could take.\r\n\r\n```sh\r\n# partition the data by &quot;user/team type&quot;\r\nreduce .[] as $i ({}; if &quot;fullName&quot; | in($i) then .user += [$i] else .team += [$i] end)\r\n\r\n  # create a lookup of &quot;user&quot; data\r\n  | (.user | INDEX(.id)) as $user\r\n\r\n  # group the &quot;team&quot; objects by team\r\n  | .team | group_by(.team)\r\n\r\n  # merge corresponding &quot;user info&quot; with all team objects\r\n  | map(map(. + $user[.id]))\r\n```\r\n\r\n```json\r\n[\r\n  [\r\n    {\r\n      &quot;id&quot;: &quot;user1&quot;,\r\n      &quot;team&quot;: &quot;Team_A&quot;,\r\n      &quot;role&quot;: &quot;TEAM_MEMBER&quot;,\r\n      &quot;fullName&quot;: &quot;User One&quot;,\r\n      &quot;email&quot;: &quot;user.one@my.mail.com&quot;\r\n    }\r\n  ],\r\n  [\r\n    {\r\n      &quot;id&quot;: &quot;user1&quot;,\r\n      &quot;team&quot;: &quot;Team_B&quot;,\r\n      &quot;role&quot;: &quot;TEAM_ADMIN&quot;,\r\n      &quot;fullName&quot;: &quot;User One&quot;,\r\n      &quot;email&quot;: &quot;user.one@my.mail.com&quot;\r\n    },\r\n    {\r\n      &quot;id&quot;: &quot;user2&quot;,\r\n      &quot;team&quot;: &quot;Team_B&quot;,\r\n      &quot;role&quot;: &quot;TEAM_ADMIN&quot;,\r\n      &quot;fullName&quot;: &quot;User Two&quot;,\r\n      &quot;email&quot;: &quot;user.two@my.mail.com&quot;\r\n    }\r\n  ]\r\n]\r\n```\r\n\r\n[jqplay](https://jqplay.org/s/Ogypt_HqMc)\r\n\r\n&lt;hr&gt;\r\n\r\nHere&#39;s another more concise solution, assuming there will only be one &quot;user info&quot; per id.\r\n\r\n```sh\r\n# group by id\r\ngroup_by(.id) | map(\r\n    # for each group, partition by &quot;type&quot;\r\n    group_by(.fullName)\r\n\r\n      # create combinations of all the info and team objects and merge them\r\n      | combinations | add\r\n)\r\n```\r\n\r\n[jqplay](https://jqplay.org/s/0A4VFQmgDs)",
                "title": "jq - create new object based on existing objects"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1601371486,
                "last_edit_date": 1601371486,
                "creation_date": 1601366913,
                "answer_id": 64115424,
                "question_id": 64114407,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This solution uses a variant of @JeffMercado&#39;s approach based on `combinations`, but only uses `group_by` once (which means that for large datasets, it should be more efficient, since `group_by` is a relatively expensive operation).  \r\n\r\nThe proposed solution here produces an array of the JSON objects you indicate you want, but if you want a stream of the JSON objects, simply omit the outer square brackets.\r\n\r\n```\r\n[group_by(.id)[]\r\n | [map(select(has(&quot;team&quot;)|not)), map(select(has(&quot;team&quot;)))]\r\n | combinations\r\n | add]\r\n```\r\n \r\n### More efficiently ...\r\nTo avoid using `group_by` or `select` at all, we could use the following generic variant of `group_by`:\r\n\r\n```\r\ndef aggregate_by(s; f):\r\n  reduce s as $x (null; .[$x|f] += [$x]);\r\n```\r\nThe solution can now be written as follows:\r\n```\r\n[ aggregate_by(.[]; .id)[]\r\n  | aggregate_by(.[]; .team == null | tostring)\r\n  | [.[]]\r\n  | combinations\r\n  | add ]\r\n``` ",
                "title": "jq - create new object based on existing objects"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1601371486,
        "creation_date": 1601362685,
        "last_edit_date": 1601366704,
        "question_id": 64114407,
        "body_markdown": "\r\nThis is my very first post, so please forgive me if it is not perfect.\r\n\r\nI have json like below. It consists of two parts. The first part contains information about user (id, fullname and email) and the second part contains informations to which team user belongs. (id, team, role) \r\nWhat I want to get an object which contains: id, fullName, emaila, team and role. I can do it but only when user belongs to one team. If user belongs to more than one team - I can&#39;t handle it.\r\n\r\nBelow my json:\r\n\r\n```\r\n[\r\n  {\r\n    &quot;id&quot;: &quot;user1&quot;,\r\n    &quot;fullName&quot;: &quot;User One&quot;,\r\n    &quot;email&quot;: &quot;user.one@my.mail.com&quot;\r\n  },\r\n  {\r\n    &quot;id&quot;: &quot;user2&quot;,\r\n    &quot;fullName&quot;: &quot;User Two&quot;,\r\n    &quot;email&quot;: &quot;user.two@my.mail.com&quot;\r\n  },\r\n  {\r\n    &quot;id&quot;: &quot;user1&quot;,\r\n    &quot;team&quot;: &quot;Team_A&quot;,\r\n    &quot;role&quot;: &quot;TEAM_MEMBER&quot;\r\n  },\r\n  {\r\n    &quot;id&quot;: &quot;user1&quot;,\r\n    &quot;team&quot;: &quot;Team_B&quot;,\r\n    &quot;role&quot;: &quot;TEAM_ADMIN&quot;\r\n  },\r\n  {\r\n    &quot;id&quot;: &quot;user2&quot;,\r\n    &quot;team&quot;: &quot;Team_B&quot;,\r\n    &quot;role&quot;: &quot;TEAM_ADMIN&quot;\r\n  }\r\n]\r\n```\r\n\r\nWhen I use: `group_by(.id)[] | add`\r\nI get:\r\n\r\n```\r\n{\r\n  &quot;id&quot;: &quot;user1&quot;,\r\n  &quot;fullName&quot;: &quot;User One&quot;,\r\n  &quot;email&quot;: &quot;user.one@my.mail.com&quot;,\r\n  &quot;team&quot;: &quot;Team_B&quot;,\r\n  &quot;role&quot;: &quot;TEAM_ADMIN&quot;\r\n},\r\n{\r\n  &quot;id&quot;: &quot;user2&quot;,\r\n  &quot;fullName&quot;: &quot;User Two&quot;,\r\n  &quot;email&quot;: &quot;user.two@my.mail.com&quot;,\r\n  &quot;team&quot;: &quot;Team_B&quot;,\r\n  &quot;role&quot;: &quot;TEAM_ADMIN&quot;\r\n}\r\n```\r\n\r\nand it is almost what I want to achieve. My goal is:\r\n\r\n```\r\n{\r\n  &quot;id&quot;: &quot;user1&quot;,\r\n  &quot;fullName&quot;: &quot;User One&quot;,\r\n  &quot;email&quot;: &quot;user.one@my.mail.com&quot;,\r\n  &quot;team&quot;: &quot;Team_A,\r\n  &quot;role&quot;: &quot;TEAM_MEMBER&quot;\r\n},\r\n{\r\n  &quot;id&quot;: &quot;user1&quot;,\r\n  &quot;fullName&quot;: &quot;User One&quot;,\r\n  &quot;email&quot;: &quot;user.one@my.mail.com&quot;,\r\n  &quot;team&quot;: &quot;Team_B&quot;,\r\n  &quot;role&quot;: &quot;TEAM_ADMIN&quot;\r\n},\r\n{\r\n  &quot;id&quot;: &quot;user2&quot;,\r\n  &quot;fullName&quot;: &quot;User Two&quot;,\r\n  &quot;email&quot;: &quot;user.two@my.mail.com&quot;,\r\n  &quot;team&quot;: &quot;Team_B&quot;,\r\n  &quot;role&quot;: &quot;TEAM_ADMIN&quot;\r\n}\r\n```\r\nI tried `reduce` also, but with no success.\r\nI have made many attempts, but none of them gave the desired effect.\r\n\r\nHow is it possible using `jq`?\r\n\r\nThanks in advance,\r\n\r\nkrzyhon",
        "link": "https://stackoverflow.com/questions/64114407/jq-create-new-object-based-on-existing-objects",
        "title": "jq - create new object based on existing objects"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1601465133,
                "creation_date": 1601465133,
                "answer_id": 64136600,
                "question_id": 64136304,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "One way would be to use the `join` function by empty string on the created objects. Note that the object you are creating needs to converted to string type for it to work. Use the filter below with the `--raw-output/-r` mode\r\n\r\n    .stations.station[] + { lastUpdate: .stations.&quot;@lastUpdate&quot; } | \r\n    [ .id + &quot;&#167;&quot;, tostring ] | \r\n    join(&quot;&quot;)\r\n\r\n&lt;sup&gt;[jqplay demo](https://jqplay.org/s/4As0sJGyBd)&lt;/sup&gt;",
                "title": "Combine output of jq onto single line per record output"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1601465133,
        "creation_date": 1601464169,
        "question_id": 64136304,
        "body_markdown": "I currently have output from `jq` that looks like this: \r\n\r\n```\r\n1&#167;\r\n{&quot;id&quot;:&quot;1&quot;,&quot;name&quot;:&quot;River Street , Clerkenwell&quot;,&quot;lastUpdate&quot;:&quot;1601461560941&quot;}\r\n2&#167;\r\n{&quot;id&quot;:&quot;2&quot;,&quot;name&quot;:&quot;Phillimore Gardens, Kensington&quot;,&quot;lastUpdate&quot;:&quot;1601461560941&quot;}\r\n```\r\n\r\nand I would like it join the output lines per record, i.e.: \r\n\r\n```\r\n1&#167;{&quot;id&quot;:&quot;1&quot;,&quot;name&quot;:&quot;River Street , Clerkenwell&quot;,&quot;lastUpdate&quot;:&quot;1601461560941&quot;}\r\n2&#167;{&quot;id&quot;:&quot;2&quot;,&quot;name&quot;:&quot;Phillimore Gardens, Kensington&quot;,&quot;lastUpdate&quot;:&quot;1601461560941&quot;}\r\n```\r\n\r\n**Here is the sample input and current filter: https://jqplay.org/s/qBfGyriA5B**\r\n\r\nIf I use `-j` then I get everything on the same line, which is not what I want\r\n\r\n```\r\n1&#167;{&quot;id&quot;:&quot;1&quot;,&quot;name&quot;:&quot;River Street , Clerkenwell&quot;,&quot;lastUpdate&quot;:&quot;1601461560941&quot;}2&#167;{&quot;id&quot;:&quot;2&quot;,&quot;name&quot;:&quot;Phillimore Gardens, Kensington&quot;,&quot;lastUpdate&quot;:&quot;1601461560941&quot;}\r\n```\r\n",
        "link": "https://stackoverflow.com/questions/64136304/combine-output-of-jq-onto-single-line-per-record-output",
        "title": "Combine output of jq onto single line per record output"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 80364,
                    "reputation": 92551,
                    "user_id": 227299,
                    "user_type": "registered",
                    "accept_rate": 72,
                    "profile_image": "https://www.gravatar.com/avatar/6483c2f0fcf64b578c55ca0df7e01096?s=256&d=identicon&r=PG",
                    "display_name": "Ruan Mendes",
                    "link": "https://stackoverflow.com/users/227299/ruan-mendes"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1601481604,
                "post_id": 64140869,
                "comment_id": 113423728,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 80364,
                    "reputation": 92551,
                    "user_id": 227299,
                    "user_type": "registered",
                    "accept_rate": 72,
                    "profile_image": "https://www.gravatar.com/avatar/6483c2f0fcf64b578c55ca0df7e01096?s=256&d=identicon&r=PG",
                    "display_name": "Ruan Mendes",
                    "link": "https://stackoverflow.com/users/227299/ruan-mendes"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1601481696,
                "post_id": 64140869,
                "comment_id": 113423782,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8720942,
                    "reputation": 43,
                    "user_id": 6524131,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/a2efa6390f27ae252e4ad68272e0a6c1?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "kirovtome",
                    "link": "https://stackoverflow.com/users/6524131/kirovtome"
                },
                "reply_to_user": {
                    "account_id": 80364,
                    "reputation": 92551,
                    "user_id": 227299,
                    "user_type": "registered",
                    "accept_rate": 72,
                    "profile_image": "https://www.gravatar.com/avatar/6483c2f0fcf64b578c55ca0df7e01096?s=256&d=identicon&r=PG",
                    "display_name": "Ruan Mendes",
                    "link": "https://stackoverflow.com/users/227299/ruan-mendes"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1605104447,
                "post_id": 64140869,
                "comment_id": 114549791,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1601481828,
                "last_edit_date": 1601481828,
                "creation_date": 1601481347,
                "answer_id": 64141336,
                "question_id": 64140869,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "There is probably a better way, but this works:\r\n\r\n    cat response.json | jq -r &#39;to_entries| map([.key, .value]) | map([join(&quot;=&quot;)]) | flatten | .[]&#39;\r\n\r\nor\r\n\r\n\r\n    cat response.json | jq -r &#39;to_entries | map([.key, .value]) | .[] | join(&quot;=&quot;)&#39;",
                "title": "JSON to plain text using jq"
            },
            {
                "up_vote_count": 6,
                "is_accepted": true,
                "score": 6,
                "last_activity_date": 1601481759,
                "creation_date": 1601481759,
                "answer_id": 64141445,
                "question_id": 64140869,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```bash\r\njq &#39;to_entries[] | &quot;\\(.key)=\\(.value)&quot;&#39;\r\n```\r\n\r\nshould do it",
                "title": "JSON to plain text using jq"
            },
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1601483922,
                "creation_date": 1601483922,
                "answer_id": 64142027,
                "question_id": 64140869,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Another way to join the values is to use [string concatenation](https://stedolan.github.io/jq/manual/#Addition:+):\r\n\r\n```\r\njq -r &#39;to_entries[] | .key + &quot;=&quot; + .value&#39;\r\n```",
                "title": "JSON to plain text using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 4,
        "last_activity_date": 1601483922,
        "creation_date": 1601479708,
        "question_id": 64140869,
        "body_markdown": "Let&#39;s say i got the following json response:\r\n```\r\n{\r\n  &quot;author&quot;: &quot;tomek&quot;,\r\n  &quot;title&quot;: &quot;helloworld&quot;,\r\n  &quot;test&quot;: &quot;sampletextonetwothree&quot;\r\n}\r\n```\r\n\r\nIs it possible to display something like this: (using jq)\r\n```\r\nauthor=tomek\r\ntitle=helloworld\r\ntest=sampletextonetwothree\r\n```",
        "link": "https://stackoverflow.com/questions/64140869/json-to-plain-text-using-jq",
        "title": "JSON to plain text using jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1601484312,
                "creation_date": 1601484312,
                "answer_id": 64142141,
                "question_id": 64141379,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Your path expression is wrong, the fields `resourceName` and `etag` are present in the top level path inside array of `connections`, and the `value` field is inside the `emailAddresses` array.\r\n\r\nSince you are forming an object, wrap the fields over `{..}`\r\n\r\n    .connections[] | { resourceName, etag } + ( .emailAddresses[] | { value } )\r\n\r\nIf you are looking for the first object alone, do `.connections[0]` or as in above for all the objects.",
                "title": "How to display multiple fields value with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1601490896,
        "creation_date": 1601481496,
        "last_edit_date": 1601484622,
        "question_id": 64141379,
        "body_markdown": "I have this JSON :\r\n\r\n    {\r\n      &quot;connections&quot;: [\r\n        {\r\n          &quot;resourceName&quot;: &quot;user_1&quot;,\r\n          &quot;etag&quot;: &quot;etag_value_1&quot;,\r\n          &quot;emailAddresses&quot;: [\r\n            {\r\n              &quot;metadata&quot;: {\r\n                &quot;primary&quot;: true,\r\n                &quot;source&quot;: {\r\n                  &quot;type&quot;: &quot;CONTACT&quot;,\r\n                  &quot;id&quot;: &quot;id_1&quot;\r\n                }\r\n              },\r\n              &quot;value&quot;: &quot;email_1&quot;,\r\n              &quot;type&quot;: &quot;home&quot;\r\n            }\r\n          ]\r\n        },\r\n        {\r\n          &quot;resourceName&quot;: &quot;user_2&quot;,\r\n          &quot;etag&quot;: &quot;etag_value_2&quot;,\r\n          &quot;emailAddresses&quot;: [\r\n            {\r\n              &quot;metadata&quot;: {\r\n                &quot;primary&quot;: true,\r\n                &quot;source&quot;: {\r\n                  &quot;type&quot;: &quot;CONTACT&quot;,\r\n                  &quot;id&quot;: &quot;id_2&quot;\r\n                }\r\n              },\r\n              &quot;value&quot;: &quot;email_2&quot;,\r\n              &quot;type&quot;: &quot;home&quot;\r\n            }\r\n          ]\r\n        }\r\n      ]\r\n    }\r\n\r\nAnd I would like to display something like this :\r\n\r\n    {\r\n      &quot;resourceName&quot;: &quot;user_1&quot;,\r\n      &quot;etag&quot;: &quot;etag_value_1&quot;,\r\n      &quot;value&quot;: &quot;email_1&quot;\r\n    }\r\n\r\nI&#39;m playing with something like this but does not work :\r\n\r\n    jq &#39;.connections[].emailAddresses[] | {.resourceName, .etag, .value}&#39; test.json\r\n\r\nHow can I do that with JQ binary?\r\n\r\n",
        "link": "https://stackoverflow.com/questions/64141379/how-to-display-multiple-fields-value-with-jq",
        "title": "How to display multiple fields value with jq"
    },
    {
        "tags": [
            "json",
            "bash",
            "parsing",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1601486340,
                "post_id": 64142411,
                "comment_id": 113425892,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1601486129,
                "creation_date": 1601486129,
                "answer_id": 64142614,
                "question_id": 64142411,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can get the value directly from jq:\r\n\r\n```console\r\n$ jq &#39;[.stats.cluster[][&quot;3xx&quot;]] | add / length&#39; &lt;&lt;&lt; &quot;$data&quot;\r\n11\r\n```",
                "title": "Perform average of values of a particular field inside a JSON using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1601486734,
        "creation_date": 1601485339,
        "last_edit_date": 1601486734,
        "question_id": 64142411,
        "body_markdown": "I have the following JSON data. \r\n\r\n    {\r\n       &quot;meta&quot;:{\r\n          &quot;earliest_ts&quot;:1601425980,\r\n          &quot;latest_ts&quot;:1601482740,\r\n          &quot;interval&quot;:&quot;minutes&quot;,\r\n          &quot;level&quot;:&quot;cluster&quot;,\r\n          &quot;entity_id&quot;:&quot;xxxxx-xxxxx-xxxxx-xxxxx-xxxxx&quot;,\r\n          &quot;stat_labels&quot;:[\r\n             &quot;status_code_classes_per_workspace_total&quot;\r\n          ],\r\n          &quot;entity_type&quot;:&quot;workspace&quot;,\r\n          &quot;start_ts&quot;:&quot;1601425980&quot;\r\n       },\r\n       &quot;stats&quot;:{\r\n          &quot;cluster&quot;:{\r\n             &quot;1601431620&quot;:{\r\n                &quot;3xx&quot;:2,\r\n                &quot;4xx&quot;:87,\r\n                &quot;5xx&quot;:31,\r\n                &quot;2xx&quot;:352\r\n             },\r\n             &quot;1601472780&quot;:{\r\n                &quot;3xx&quot;:14,\r\n                &quot;4xx&quot;:296,\r\n                &quot;5xx&quot;:2,\r\n                &quot;2xx&quot;:3811\r\n             },\r\n             &quot;1601479140&quot;:{\r\n                &quot;3xx&quot;:17,\r\n                &quot;4xx&quot;:397,\r\n                &quot;5xx&quot;:19,\r\n                &quot;2xx&quot;:4399\r\n             }\r\n          }\r\n       }\r\n    }\r\n\r\nI try to do the average of all the `&quot;3xx&quot;` fields.\r\n\r\nUsing `jq`, I manage to get the key for each of my cluster :\r\n\r\n    echo $data | jq -r &#39;.stats.cluster|keys&#39; | while read key; do \r\n      echo $key\r\n    done\r\n\r\nOutput :\r\n\r\n    [\r\n    &quot;1601431620&quot;,\r\n    &quot;1601472780&quot;,\r\n    &quot;1601479140&quot;\r\n    ]\r\n\r\nBut when I try to go further I can&#39;t manage to further and to retrieve the data from each field.\r\nI got some insperation from [this][1].\r\n\r\nThe code below doesn&#39;t work, but you get the idea :\r\n\r\n     # total var will be used to calculate the average\r\n     total=$(echo $data | jq &quot;.stats.cluster&quot; | jq length)\r\n\r\n     # for each cluster ...\r\n     echo $data | jq &#39;.stats.cluster|keys&#39; | while read key; do\r\n        # ... we retrieve the value &quot;3xx&quot;\r\n        i=$($data | jq &#39;.stats.cluster.$key.&quot;3xx&quot;&#39;)\r\n        # ... that we add into a sum var\r\n        sum=$(( sum + i ))\r\n     done\r\n     \r\n     # we calculate the average\r\n     avg=$(( $sum / $total ))\r\n     echo &quot;The average is $avg&quot;\r\n\r\nI can&#39;t path directly to the data in jq like `jq &#39;.stats.cluster.&quot;1601431620&quot;.&quot;3xx&quot;` because the cluster are so many and change all the time.\r\n\r\nThe desired output with my example above would be `11` as `(2 + 14 + 17) / 3`, those number all coming from the `3xx`&#39;s items field.\r\n\r\n\r\n  [1]: https://stackoverflow.com/questions/34529156/iterate-through-dictionaries-jq-shell",
        "link": "https://stackoverflow.com/questions/64142411/perform-average-of-values-of-a-particular-field-inside-a-json-using-jq",
        "title": "Perform average of values of a particular field inside a JSON using jq"
    },
    {
        "tags": [
            "json",
            "bash",
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 4663062,
                    "reputation": 89888,
                    "user_id": 3776858,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Cagbk.jpg?s=256",
                    "display_name": "Cyrus",
                    "link": "https://stackoverflow.com/users/3776858/cyrus"
                },
                "edited": false,
                "score": 3,
                "creation_date": 1601495117,
                "post_id": 64144681,
                "comment_id": 113429547,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3263490,
                    "reputation": 3191,
                    "user_id": 2748513,
                    "user_type": "registered",
                    "accept_rate": 75,
                    "profile_image": "https://www.gravatar.com/avatar/cff3bd0806c4f90cbcf6bf26e36a0e6d?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "rodee",
                    "link": "https://stackoverflow.com/users/2748513/rodee"
                },
                "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": 1601495512,
                "post_id": 64144681,
                "comment_id": 113429689,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1601499503,
                "creation_date": 1601499503,
                "answer_id": 64145659,
                "question_id": 64144681,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a solution using `walk`. If for some reason you want a more targeted solution (for example, one that does not use `walk`), it should be easy to modify it accordingly.\r\n```\r\nwalk( if type==&quot;object&quot; and .task and (.task|startswith(&quot;tbd-&quot;)) and\r\n         any(.[]; type==&quot;object&quot; and has(&quot;german&quot;))\r\n      then .task|=sub(&quot;tbd-&quot;; &quot;premium-&quot;)\r\n      else . end )\r\n```\r\n",
                "title": "Updating key of json based on another key name using jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1601577375,
                "last_edit_date": 1601577375,
                "creation_date": 1601576949,
                "answer_id": 64161251,
                "question_id": 64144681,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you don&#39;t have jq 1.6 , which has walk/1 , do prepend the def walk :\r\n```\r\njq &#39;\r\n# Apply f to composite entities recursively, and to atoms\r\n    def walk(f):\r\n    . as $in\r\n    | if type == &quot;object&quot; then\r\n        reduce keys[] as $key\r\n            ( {}; . + { ($key):  ($in[$key] | walk(f)) } ) | f\r\n    elif type == &quot;array&quot; then map( walk(f) ) | f\r\n    else f\r\n    end;\r\n  walk( if type==&quot;object&quot; and .task and (.task|startswith(&quot;tbd-&quot;)) and any(.[]; type==&quot;object&quot; and has(&quot;german&quot;)) then .task|=sub(&quot;tbd-&quot;; &quot;premium-&quot;) else . end )\r\n&#39; filename\r\n```\r\nsource: https://github.com/stedolan/jq/issues/963#issuecomment-152783116",
                "title": "Updating key of json based on another key name using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1601577375,
        "creation_date": 1601495005,
        "last_edit_date": 1601569703,
        "question_id": 64144681,
        "body_markdown": "I have below json file, need to replace `tbd-` with `premium-` in task&#39;s value if and only if made is `german` and task&#39;s value starts with `tbd-`\r\n\r\n\r\n\r\n```\r\n{\r\n    &quot;vehicle&quot;: {\r\n        &quot;maintenance&quot;: [\r\n            {\r\n                &quot;parts&quot;: &quot;wheel&quot;,\r\n                &quot;size&quot;: [&quot;one&quot;, &quot;two&quot;]\r\n            },\r\n            {\r\n                &quot;task&quot;: &quot;tbd-service-oil&quot;,\r\n                &quot;car&quot;: {\r\n                    &quot;german&quot;: {\r\n                        &quot;audi&quot;: [&quot;Synthetic&quot;]\r\n                    }\r\n                },\r\n                &quot;some&quot;: [&quot;other&quot;]\r\n            },\r\n            {\r\n                &quot;task&quot;: &quot;service-oil&quot;,\r\n                &quot;honda&quot;: {\r\n                    &quot;japan&quot;: {\r\n                        &quot;oil&quot;: [&quot;regular&quot;]\r\n                    }\r\n                }\r\n            }\r\n        ],\r\n        &quot;repair&quot;: [\r\n            {\r\n                &quot;parts&quot;: &quot;wheel&quot;,\r\n                &quot;size&quot;: [&quot;one&quot;, &quot;two&quot;]\r\n            },\r\n            {\r\n                &quot;task&quot;: &quot;tbd-engine-repair&quot;,\r\n                &quot;car&quot;: {\r\n                    &quot;german&quot;: {\r\n                        &quot;engine&quot;: [&quot;6-cyl&quot;]\r\n                    }\r\n                }\r\n            },\r\n            {\r\n                &quot;task&quot;: &quot;engine-repair&quot;,\r\n                &quot;car&quot;: {\r\n                    &quot;german&quot;: {\r\n                        &quot;engine&quot;: [&quot;4-cyl&quot;]\r\n                    }\r\n                }\r\n            }\r\n        ]\r\n        \r\n    }\r\n}\r\n```\r\n\r\nneed to update above json file to:\r\n\r\n```\r\n{\r\n    &quot;vehicle&quot;: {\r\n        &quot;maintenance&quot;: [\r\n            {\r\n                &quot;parts&quot;: &quot;wheel&quot;,\r\n                &quot;size&quot;: [&quot;one&quot;, &quot;two&quot;]\r\n            },\r\n            {\r\n                &quot;task&quot;: &quot;premium-service-oil&quot;, ## update this b&#39;cos there is &quot;german&quot; under &quot;car&quot; and task&#39;s value had prefix &quot;tbd-&quot;\r\n                &quot;car&quot;: {\r\n                    &quot;german&quot;: {\r\n                        &quot;audi&quot;: [&quot;Synthetic&quot;]\r\n                    }\r\n                },\r\n                &quot;some&quot;: [&quot;other&quot;]\r\n            },\r\n            {\r\n                &quot;task&quot;: &quot;service-oil&quot;,\r\n                &quot;honda&quot;: {\r\n                    &quot;japan&quot;: {\r\n                        &quot;oil&quot;: [&quot;regular&quot;]\r\n                    }\r\n                }\r\n            }\r\n        ],\r\n        &quot;repair&quot;: [\r\n            {\r\n                &quot;parts&quot;: &quot;wheel&quot;,\r\n                &quot;size&quot;: [&quot;one&quot;, &quot;two&quot;]\r\n            },\r\n            {\r\n                &quot;task&quot;: &quot;premium-engine-repair&quot;, ## update this b&#39;cos there is &quot;german&quot; under &quot;car&quot; and task&#39;s value had prefix &quot;tbd-&quot;\r\n                &quot;car&quot;: {\r\n                    &quot;german&quot;: {\r\n                        &quot;engine&quot;: [&quot;6-cyl&quot;]\r\n                    }\r\n                }\r\n            },\r\n            {\r\n                &quot;task&quot;: &quot;engine-repair&quot;, ### no need to update this as it don&#39;t have &quot;tbd-&quot; as prefix\r\n                &quot;car&quot;: {\r\n                    &quot;german&quot;: {\r\n                        &quot;engine&quot;: [&quot;4-cyl&quot;]\r\n                    }\r\n                }\r\n            }\r\n        ]\r\n        \r\n    }\r\n}\r\n```\r\n\r\nso far, I tried to get all the keys with `german` as keyname, I am not successful though\r\n\r\n```\r\njq -c &#39;to_entries[] | select (.key.maintenance.car == &quot;german&quot;) | [.key]&#39; json\r\njq: error (at json:50): Cannot index string with string &quot;maintenance&quot;\r\n```\r\n\r\nI could query the `parts` matching `wheel`, using similar command\r\n\r\n```\r\n$ jq -c &#39;to_entries[] | select (.value.maintenance[0].parts == &quot;wheel&quot;) | [.key]&#39;  json\r\n[&quot;vehicle&quot;]\r\n```\r\n\r\n\r\nUPDATE:\r\n\r\nI am okay to skip checking if key has `tbd-`, I can go update all the key names irrespective of prefix.",
        "link": "https://stackoverflow.com/questions/64144681/updating-key-of-json-based-on-another-key-name-using-jq",
        "title": "Updating key of json based on another key name using jq"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq",
            "accumulate"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1601503329,
                "creation_date": 1601503329,
                "answer_id": 64146365,
                "question_id": 64146079,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use the whole object instead of just a field as the current element in _foreach_.\r\n\r\n``` bash\r\njq &#39;[foreach .[] as $row ({nbrMembers: 0, nbrWallets: 0}; {nbrMembers: ($row.nbrMembers + .nbrMembers), nbrWallets:  ($row.nbrWallets + .nbrWallets)  }; . as $x | $row | .nbrMembers = $x.nbrMembers | .nbrWallets = $x.nbrWallets) ]&#39; test.json\r\n```",
                "title": "Multiple statements with JQ: Cumulate multiple fields"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1601504964,
                "last_edit_date": 1601504964,
                "creation_date": 1601504649,
                "answer_id": 64146568,
                "question_id": 64146079,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It&#39;s a little bit shorter version. We can use ```$row * .``` to merge the result)\r\n\r\n```bash\r\n\r\njq &#39;[foreach .[] as $row (\r\n      {nbrMembers: 0, nbrWallets: 0};\r\n      { \r\n        nbrMembers: ($row.nbrMembers + .nbrMembers), \r\n        nbrWallets: ($row.nbrWallets + .nbrWallets)\r\n      }; \r\n     $row * .  \r\n    )]&#39; test.json\r\n```\r\n\r\n",
                "title": "Multiple statements with JQ: Cumulate multiple fields"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1601541908,
                "creation_date": 1601541908,
                "answer_id": 64151865,
                "question_id": 64146079,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Succinctly:\r\n```\r\njq &#39;[ foreach .[] as $row (null;\r\n          .nbrMembers += $row.nbrMembers\r\n        | .nbrWallets += $row.nbrWallets;\r\n        $row + . ) ]\r\n&#39; test.json\r\n```",
                "title": "Multiple statements with JQ: Cumulate multiple fields"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1601571891,
        "creation_date": 1601501725,
        "last_edit_date": 1601571891,
        "question_id": 64146079,
        "body_markdown": "This is my data for this example:\r\n\r\n    [\r\n      {\r\n        &quot;date&quot;: &quot;25-09-20&quot;,\r\n        &quot;nbrMembers&quot;: 1,\r\n        &quot;nbrWallets&quot;: 4\r\n      },\r\n      {\r\n        &quot;date&quot;: &quot;26-09-20&quot;,\r\n        &quot;nbrMembers&quot;: 3,\r\n        &quot;nbrWallets&quot;: 1\r\n      },\r\n      {\r\n        &quot;date&quot;: &quot;27-09-20&quot;,\r\n        &quot;nbrMembers&quot;: 0,\r\n        &quot;nbrWallets&quot;: 2\r\n      },\r\n      {\r\n        &quot;date&quot;: &quot;28-09-20&quot;,\r\n        &quot;nbrMembers&quot;: 7,\r\n        &quot;nbrWallets&quot;: 3\r\n      }\r\n    ]\r\n\r\nI need to transform the json with cumulate fields.\r\nThis is the expected result:\r\n\r\n    [\r\n      {\r\n        &quot;date&quot;: &quot;25-09-20&quot;,\r\n        &quot;nbrMembers&quot;: 1,\r\n        &quot;nbrWallets&quot;: 4\r\n      },\r\n      {\r\n        &quot;date&quot;: &quot;26-09-20&quot;,\r\n        &quot;nbrMembers&quot;: 4,\r\n        &quot;nbrWallets&quot;: 5\r\n      },\r\n      {\r\n        &quot;date&quot;: &quot;27-09-20&quot;,\r\n        &quot;nbrMembers&quot;: 4,\r\n        &quot;nbrWallets&quot;: 7\r\n      },\r\n      {\r\n        &quot;date&quot;: &quot;28-09-20&quot;,\r\n        &quot;nbrMembers&quot;: 11,\r\n        &quot;nbrWallets&quot;: 10\r\n      }\r\n    ]\r\n\r\nThis is what i&#39;m doing to cumulate just one field:\r\n\r\n    jq &#39;foreach .[] as $row (0; . + $row.nbrMembers ; . as $x | $row | (.nbrMembers = $x))&#39; test.json\r\n\r\nI just don&#39;t know how to do this with multiples fields ?\r\n\r\n",
        "link": "https://stackoverflow.com/questions/64146079/multiple-statements-with-jq-cumulate-multiple-fields",
        "title": "Multiple statements with JQ: Cumulate multiple fields"
    },
    {
        "tags": [
            "regex",
            "jq",
            "pcre",
            "regex-lookarounds",
            "negative-lookbehind"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1601506934,
                "creation_date": 1601506934,
                "answer_id": 64146907,
                "question_id": 64146690,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If your current library version is limited to fixed-width lookbehind patterns, you can&#39;t do much about it.\r\n\r\nIn your case, since you are using negative lookbehinds, you can do without alternation, just split the lookbehind into two:\r\n\r\n    (?&lt;!foo )(?&lt;!bars )baz(?! foo| bars)\r\n    ^^^^^^^^^^^^^^^^^^^\r\n\r\nThen, you do not have to care how many chars each lookbehind has to check.",
                "title": "jq 1.6/oniguruma 5.9.6 throws &quot;Regex failure: invalid pattern in look-behind&quot; error"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1601574307,
        "creation_date": 1601505443,
        "last_edit_date": 1601574307,
        "question_id": 64146690,
        "body_markdown": "## Problem\r\n\r\nI&#39;m trying to use a `jq v1.6` filter that has a regex, which contains a negative look-behind and negative look-ahead expressions, but they are failing with `Regex failure: invalid pattern in look-behind`, even though the spec seems like it would be a valid expression.\r\n\r\nThe command I&#39;m using is \r\n\r\n```\r\n$ jq -n &#39;(&quot;baz&quot;, &quot;foo baz&quot;, &quot;bla baz&quot;, &quot;baz bars&quot;) | test(&quot;(?&lt;!foo |bars )baz(?! foo| bars)&quot;)&#39;\r\njq: error (at &lt;unknown&gt;): Regex failure: invalid pattern in look-behind\r\n```\r\n\r\nIt seems like `jq 1.6` is using the Onigurama library version 5.9.6 (https://github.com/stedolan/jq/commit/61edf3fa93f6177ef099b1b0cb2b49813a35c546#diff-ea6712465e6d2ae84a07da73f4ad6e25, this seems the right script version because `jq 1.6` was released on Nov 2018, and the next commit for `compile-ios.sh` is until Dec 2019).\r\n\r\nNow, Oniguruma 5.9.6 closest documentation I could find is from 5.9.1 (in https://github.com/kkos/oniguruma/commit/65a9b1aa03c9bc2dc01b074295b9603232cb3b78# you can search for `negative look-behind`, line 221 of `doc/RE` file.\r\n\r\n&gt; (?&lt;!subexp) negative look-behind\r\n&gt;\r\n&gt;    Subexp of look-behind must be fixed character length.\r\n&gt;    But different character length is allowed in top level\r\n&gt;    alternatives only.\r\n&gt;    ex. (?&lt;=a|bc) is OK. (?&lt;=aaa(?:b|cd)) is not allowed.\r\n&gt;\r\n&gt;    In negative-look-behind, captured group isn&#39;t allowed, \r\n&gt;    but shy group(?:) is allowed.\r\n\r\nSo it seems like my expression should work. \r\n\r\nAfter testing a few things, I found out that this works:\r\n\r\n```\r\njq -n &#39;(&quot;baz&quot;, &quot;foo baz&quot;, &quot;bla baz&quot;, &quot;baz bars&quot;) | test(&quot;(?&lt;!foo|bar)baz(?! foo| bars)&quot;)&#39;\r\n```\r\n\r\nThe only difference is that the look-behind expression alternatives are fixed width, but the docs clearly state that top level alternatives are allowed to have variable width.\r\n\r\n## Conclusion\r\n\r\nIt seems that for some reason, this particular version of `jq` does not support variable-width alternatives in a (negative) look-behind expression, even though the spec says nothing about this.\r\n\r\n## Note\r\n\r\nI suspect something is going on with the particular `jq` build I installed, because if I try to run the regex example in https://stedolan.github.io/jq/manual/#RegularexpressionsPCRE in also get an error:\r\n\r\n```\r\n$ jq -n &#39;(&quot;test&quot;, &quot;TEst&quot;, &quot;teST&quot;, &quot;TEST&quot;) | test( &quot;(?i)te(?-i)st&quot; )&#39;\r\njq: error (at &lt;unknown&gt;): Regex failure: invalid group name &lt;&gt;\r\n```\r\n\r\nDoes anyone have any idea what could be wrong?",
        "link": "https://stackoverflow.com/questions/64146690/jq-1-6-oniguruma-5-9-6-throws-regex-failure-invalid-pattern-in-look-behind-er",
        "title": "jq 1.6/oniguruma 5.9.6 throws &quot;Regex failure: invalid pattern in look-behind&quot; error"
    },
    {
        "tags": [
            "json",
            "bash",
            "shell",
            "scripting",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 84644,
                    "reputation": 69771,
                    "user_id": 236465,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/IoAkG.jpg?s=256",
                    "display_name": "Diego Torres Milano",
                    "link": "https://stackoverflow.com/users/236465/diego-torres-milano"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1601527497,
                "post_id": 64149031,
                "comment_id": 113437148,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1601538812,
                "creation_date": 1601538812,
                "answer_id": 64151165,
                "question_id": 64149031,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It&#39;s basic jq syntax:\r\n\r\n\r\n    $ ID=$(cat data.json | jq .Item.ID.S -r)\r\n    $ no=$(cat data.json | jq .Item.no.N -r)\r\n    $ echo $ID $no\r\n    4869949 2\r\n\r\nI&#39;d suggest you read something like https://shapeshed.com/jq-json/ to get more familiar though.",
                "title": "Looping through a json file and retrieving the values into bash variables"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1601540843,
                "creation_date": 1601540843,
                "answer_id": 64151613,
                "question_id": 64149031,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The following may not be exactly what you&#39;re after but does show how you can avoid calling jq more than once, and how the command can partly be constructed by jq.  In other words, assuming the templates for `--key-condition-expression` and `--expression-attribute-values` are fixed, you should be able to adapt the following to your needs:\r\n\r\nAssuming a bash or bash-like shell, and that data.json holds:\r\n\r\n```\r\n{&quot;Item&quot;: {&quot;ID&quot;: {&quot;S&quot;: &quot;4869949&quot;},&quot;no&quot;:{&quot;N&quot;: &quot;2&quot;}}}\r\n```\r\n\r\nwe could write:\r\n\r\n```\r\nID=ID\r\nno=no\r\n\r\n&lt; data.json jq --arg ID &quot;$ID&quot; --arg no &quot;$no&quot; -cr &#39;\r\n  .Item\r\n  | .ID.S as $v1\r\n  | .no.N as $v2\r\n  | $v1, $v2, {($v1): {&quot;S&quot;: $ID}, ($v2): {&quot;N&quot;: $no}}\r\n&#39; | while read -r v1\r\ndo\t  \r\n  read -r v2\r\n  read -r query\r\n\r\n  echo query --table-name validation \\\r\n  --key-condition-expression &quot;\\&quot;ID = $v1 AND no = $v2\\&quot;&quot; \\\r\n  --expression-attribute-values &quot;&#39;&quot;&quot;$query&quot;&quot;&#39;&quot; \\\r\n  --region us-east-1\r\ndone\r\n```\r\n\r\n### jq as a template engine\r\n\r\nIf the template with :v1 and :v2 in the Q are variable, then you could adapt the above by using jq as a template engine, a topic which is covered in the jq Cookbook:  https://github.com/stedolan/jq/wiki/Cookbook#using-jq-as-a-template-engine",
                "title": "Looping through a json file and retrieving the values into bash variables"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1601573695,
        "creation_date": 1601526135,
        "last_edit_date": 1601573695,
        "question_id": 64149031,
        "body_markdown": "I have a json file which has the below data \r\n```\r\n{&quot;Item&quot;: {&quot;ID&quot;: {&quot;S&quot;: &quot;4869949&quot;},&quot;no&quot;:{&quot;N&quot;: &quot;2&quot;}}}\r\n````\r\nI need to retrieve the S value from ID and N value from no and put them into a query as parameters.. the query looks like this:\r\n\r\n    query --table-name validation \\\r\n      --key-condition-expression &quot;ID = :v1 AND no = :v2&quot; \\\r\n      --expression-attribute-values &#39;{&quot;:v1&quot;: {&quot;S&quot;: &quot;${ID}&quot;},&quot;:v2&quot;: {&quot;N&quot;: &quot;${no}&quot;}}&#39; \\\r\n      --region us-east-1\r\n\r\nI have tried using jq but couldn&#39;t figure out how to read a json file and retrieve the values as parameters. This is the first time I am using jq. Can someone help with it?",
        "link": "https://stackoverflow.com/questions/64149031/looping-through-a-json-file-and-retrieving-the-values-into-bash-variables",
        "title": "Looping through a json file and retrieving the values into bash variables"
    },
    {
        "tags": [
            "json",
            "linux",
            "merge",
            "jq",
            "large-files"
        ],
        "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": 1601554168,
                "post_id": 64154303,
                "comment_id": 113447349,
                "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": 1601554367,
                "post_id": 64154303,
                "comment_id": 113447453,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1601574054,
                "last_edit_date": 1601574054,
                "creation_date": 1601569236,
                "answer_id": 64159437,
                "question_id": 64154303,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using -s is here both unnecessary and asking for trouble. You could try using `inputs` with the -n option instead.  Also I suspect you should be using `+` rather than `*`. That should also require less computer resources:\r\n\r\n    jq -n &#39;reduce inputs as $item (null; . + $item)&#39;\r\n\r\nThe real question, though, is whether you **really** need to produce a single JSON entity, rather than a stream of JSON entities.\r\n\r\n## Relevance of jq&#39;s streaming parser\r\n\r\njq&#39;s streaming parser (the one invoked with the `--stream` command-line option) is primarily targeted to reading very large JSON inputs, and is thus almost certainly irrelevant with respect to the problem being described.  On the other hand, it might be relevant when it comes to reading the generated file.  \r\n\r\nFor the record, the other primary use of the streaming parser is handling inputs which include JSON objects with duplicated keys.  The regular jq parser uses a &quot;right-most&quot; semantics for such objects.\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n",
                "title": "Troubles merging many large json files to even larger file"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1601630833,
        "creation_date": 1601551123,
        "last_edit_date": 1601630833,
        "question_id": 64154303,
        "body_markdown": "I have to merge ~1000 large json files (1M .. 500M) into a single file (~80GB) on Ubuntu 18.\r\nAccording to [this SO question][1], I use **jq** with \r\n\r\n     jq -s &#39;reduce .[] as $item ({}; . * $item)&#39; ~/ml/train-*.json &gt; train.json\r\n\r\nwhich works quite nice for less smaller files.\r\n\r\nThe machine where merging happens is a 32 core server with 128 GB RAM. Alas, the task ends with a \r\n\r\n    Killed\r\nstatement, but in terms of memory, the resources should be sufficient. Can somebody please give me some advice how to manage this task? Thnx \r\n\r\n\r\n  [1]: https://stackoverflow.com/questions/19529688/how-to-merge-2-json-objects-from-2-files-using-jq",
        "link": "https://stackoverflow.com/questions/64154303/troubles-merging-many-large-json-files-to-even-larger-file",
        "title": "Troubles merging many large json files to even larger file"
    },
    {
        "tags": [
            "json",
            "shell",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1601665142,
                "creation_date": 1601665142,
                "answer_id": 64176916,
                "question_id": 64176625,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Your command expands to this (see it for yourself with `set -x`):\r\n\r\n```\r\njq -c &#39;.[]&#39; &#39;[&#39; &#39;&quot;demo3&quot;,&#39; &#39;&quot;demo&quot;,&#39; &#39;&quot;demo2&quot;,&#39; &#39;&quot;NetworkWatcherRG&quot;&#39; &#39;]&#39;\r\n```\r\n\r\nThe command substitution is replaced with the command output, but jq doesn&#39;t expect a JSON body as a parameter – either files containing JSON, or a stream in standard input. Since all the parameters (`[`, `&quot;demo3&quot;` etc.) are *not* filenames, you see the errors you do.\r\n\r\nYou could have Bash make it look like it&#39;s a file with process substitution:\r\n\r\n```sh\r\njq -c &#39;.[]&#39; &lt;(az group list)\r\n```\r\n\r\nor, more portably, use pipes:\r\n\r\n```sh\r\naz group list | jq -c &#39;.[]&#39;\r\n```\r\n\r\n---\r\n\r\nNotice that quoting wouldn&#39;t help here either: if you ran\r\n\r\n```sh\r\njq -c &#39;.[] &quot;$(az group list)&quot;\r\n```\r\n\r\nit would expand to\r\n\r\n```sh\r\njq -c &#39;.[]&#39; &#39;[\r\n  &quot;demo3&quot;,\r\n  &quot;demo&quot;,\r\n  &quot;demo2&quot;,\r\n  &quot;NetworkWatcherRG&quot;\r\n]&#39;\r\n```\r\n\r\nand jq would try to open a file with the name\r\n\r\n```none\r\n[\r\n  &quot;demo3&quot;,\r\n  &quot;demo&quot;,\r\n  &quot;demo2&quot;,\r\n  &quot;NetworkWatcherRG&quot;\r\n]\r\n```\r\n\r\nwhich does not exist.\r\n",
                "title": "How to az group list using ubuntu bash foreach json array name value"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1601666049,
        "creation_date": 1601663503,
        "last_edit_date": 1601666049,
        "question_id": 64176625,
        "body_markdown": "azure cli `az group list` return data like  \r\n```json\r\n[\r\n  &quot;demo3&quot;,\r\n  &quot;demo&quot;,\r\n  &quot;demo2&quot;,\r\n  &quot;NetworkWatcherRG&quot;\r\n]\r\n```\r\n\r\nI&#39;d like to foreach it&#39;s value on ubuntu bash then printing below result  \r\n```\r\ndemo3\r\ndemo\r\ndemo2\r\nNetworkWatcherRG\r\n```\r\n\r\nWhat I&#39;ve tried :  \r\nI tried below script\r\n```\r\njq -c &#39;.[]&#39; $(az group list) | while read i; do echo $i ;done \r\n```\r\n\r\nbut get image&#39;s error\r\n![image](https://user-images.githubusercontent.com/12729184/94957579-8d247080-0520-11eb-9239-a93245f707e4.png)\r\n",
        "link": "https://stackoverflow.com/questions/64176625/how-to-az-group-list-using-ubuntu-bash-foreach-json-array-name-value",
        "title": "How to az group list using ubuntu bash foreach json array name value"
    },
    {
        "tags": [
            "json",
            "amazon-web-services",
            "jq",
            "aws-cli",
            "key-value"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 58377,
                    "reputation": 271975,
                    "user_id": 174777,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/6PnNW.jpg?s=256",
                    "display_name": "John Rotenstein",
                    "link": "https://stackoverflow.com/users/174777/john-rotenstein"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1601712555,
                "post_id": 64180396,
                "comment_id": 113495661,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6929182,
                    "reputation": 1051,
                    "user_id": 5319217,
                    "user_type": "registered",
                    "accept_rate": 48,
                    "profile_image": "https://www.gravatar.com/avatar/426d5e922fc8bc507a9658cbadd58825?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "fledgling",
                    "link": "https://stackoverflow.com/users/5319217/fledgling"
                },
                "reply_to_user": {
                    "account_id": 58377,
                    "reputation": 271975,
                    "user_id": 174777,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/6PnNW.jpg?s=256",
                    "display_name": "John Rotenstein",
                    "link": "https://stackoverflow.com/users/174777/john-rotenstein"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1601726992,
                "post_id": 64180396,
                "comment_id": 113498810,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1601699930,
                "creation_date": 1601699930,
                "answer_id": 64180774,
                "question_id": 64180396,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "A jq solution:\r\n\r\n    map( {(.OutputKey) : .OutputValue} ) | add\r\n\r\n",
                "title": "Convert aws cli JSON output"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1601711695,
        "creation_date": 1601695283,
        "last_edit_date": 1601711695,
        "question_id": 64180396,
        "body_markdown": "The below aws cli command returns the following\r\n\r\n    aws cloudformation describe-stacks --stack-name home-automation-service --region us-east-1 --query &quot;Stacks[0].Outputs[*].{OutputKey:OutputKey,OutputValue:OutputValue}&quot;  --output json\r\n\r\n\r\n    [\r\n        {\r\n            &quot;OutputKey&quot;: &quot;URLPath&quot;,\r\n            &quot;OutputValue&quot;: &quot;https://home-automation-service.jakeworld.com&quot;\r\n        },\r\n        {\r\n            &quot;OutputKey&quot;: &quot;Port&quot;,\r\n            &quot;OutputValue&quot;: &quot;8080&quot;\r\n        }    \r\n    ]\r\n\r\nI want to convert the json to resemble the following \r\n\r\n        {\r\n            &quot;URLPath&quot;: &quot;https://home-automation-service.jakeworld.com&quot;,\r\n            &quot;Port&quot;: &quot;8080&quot;\r\n        }\r\n\r\nCan this be done using the `--query` parameter in the aws cli? If not, appreciate help using any other way of doing it?\r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/64180396/convert-aws-cli-json-output",
        "title": "Convert aws cli JSON output"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1601704666,
                "last_edit_date": 1601704666,
                "creation_date": 1601704058,
                "answer_id": 64181148,
                "question_id": 64180906,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using `reduce` here is probably easier than using `foreach`:\r\n```\r\nreduce .[] as $x (null;\r\n    if . == null then [$x]\r\n    elif .[-1].value == $x.value then .\r\n    else . + [$x] end)\r\n```\r\n\r\n### Solution using `foreach`\r\nFor reference, here&#39;s a solution using `foreach`.  The key idea is to use foreach&#39;s state variable to store the &quot;local variables&quot; that you might use in a different language.\r\n```\r\n[ foreach .[] as $x ({};\r\n    if .prev == $x.value then .emit = null\r\n    else {prev: $x.value, emit: $x}\r\n    end;\r\n    select(.emit).emit ) ]\r\n```",
                "title": "Select object only if it have different element from previous one with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1601707968,
        "creation_date": 1601701302,
        "last_edit_date": 1601707968,
        "question_id": 64180906,
        "body_markdown": "The goal is to print the object only if a value of it is different from the previous object.\r\n\r\nImagine this json:\r\n\r\n    [\r\n       {\r\n          &quot;date&quot;: &quot;10-03-20&quot;,\r\n          &quot;value&quot;: 3\r\n       },   \r\n       {\r\n          &quot;date&quot;: &quot;11-03-20&quot;,\r\n          &quot;value&quot;: 3\r\n       },   \r\n       {\r\n          &quot;date&quot;: &quot;12-03-20&quot;,\r\n          &quot;value&quot;: 3\r\n       },   \r\n       {\r\n          &quot;date&quot;: &quot;13-03-20&quot;,\r\n          &quot;value&quot;: 8\r\n       },   \r\n       {\r\n          &quot;date&quot;: &quot;14-03-20&quot;,\r\n          &quot;value&quot;: 8\r\n       },   \r\n       {\r\n          &quot;date&quot;: &quot;15-03-20&quot;,\r\n          &quot;value&quot;: 5\r\n       }\r\n    ]\r\n\r\nThe expected output should be:\r\n\r\n    [\r\n       {\r\n          &quot;date&quot;: &quot;10-03-20&quot;,\r\n          &quot;value&quot;: 3\r\n       }, \r\n       {\r\n          &quot;date&quot;: &quot;13-03-20&quot;,\r\n          &quot;value&quot;: 8\r\n       },  \r\n       {\r\n          &quot;date&quot;: &quot;15-03-20&quot;,\r\n          &quot;value&quot;: 5\r\n       }\r\n    ]\r\n\r\nOnly print object if `value` is different of the previous object.\r\n\r\nThis what I start to do with jq:\r\n\r\n    [foreach .[] as $row (null;\r\n        select($row.value != $lastValue) | $row.value\r\n        $lastValue = $row.value\r\n        )]\r\n\r\nOf course this doesn&#39;t work, I can&#39;t use variable with jq like this, i don&#39;t know if this is the good way to do.",
        "link": "https://stackoverflow.com/questions/64180906/select-object-only-if-it-have-different-element-from-previous-one-with-jq",
        "title": "Select object only if it have different element from previous one with jq"
    },
    {
        "tags": [
            "json",
            "jq",
            "edit"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1601702610,
                "post_id": 64180946,
                "comment_id": 113493859,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 10493511,
                    "reputation": 145,
                    "user_id": 7734535,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/a03ea1e26a3efd4fb16deb926489de1b?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "modernNeo",
                    "link": "https://stackoverflow.com/users/7734535/modernneo"
                },
                "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": 1601710781,
                "post_id": 64180946,
                "comment_id": 113495344,
                "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": 1601712199,
                "post_id": 64180946,
                "comment_id": 113495586,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 10493511,
                    "reputation": 145,
                    "user_id": 7734535,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/a03ea1e26a3efd4fb16deb926489de1b?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "modernNeo",
                    "link": "https://stackoverflow.com/users/7734535/modernneo"
                },
                "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": 1601713422,
                "post_id": 64180946,
                "comment_id": 113495872,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1601861704,
                "last_edit_date": 1601861704,
                "creation_date": 1601703704,
                "answer_id": 64181110,
                "question_id": 64180946,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Assuming the input is valid JSON and that valid JSON is acceptable as output,\r\nthe following jq program will perform the required transformations:\r\n\r\n```\r\nmap( reduce (&quot;sfuid&quot;, &quot;sfu_email_alias&quot;, &quot;github_username&quot;, &quot;gmail&quot;) as $k (.;\r\n         if .fields[$k] then .fields[$k] = $k else . end)\r\n       | if .fields.phone_number then .fields.phone_number = 0 else . end )\r\n```\r\n\r\nUsing `reduce` here is of course in support of &quot;DRY&quot;.  If `reduce` is unfamiliar to you, you can think of it as a kind of `for` loop.\r\n\r\n### DRY-er\r\n```\r\ndef update($PATH; VALUE):\r\n  . as $in\r\n  | if ($PATH | select(IN($in|paths)) // null) \r\n    then setpath($PATH;VALUE) else . end;\r\n\r\nmap( reduce (&quot;sfuid&quot;, &quot;sfu_email_alias&quot;, &quot;github_username&quot;, &quot;gmail&quot;) as $k (.;\r\n         update( [&quot;fields&quot;, $k]; $k )\r\n       | update( [&quot;fields&quot;, &quot;phone_number&quot;]; 0) ))\r\n\r\n\r\n```",
                "title": "how to replace a value in a json file with jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1601861704,
        "creation_date": 1601702001,
        "last_edit_date": 1601713379,
        "question_id": 64180946,
        "body_markdown": "I have a json that has the following structure\r\n\r\n    [{\r\n        &quot;model&quot;: &quot;about.term&quot;,\r\n        &quot;pk&quot;: 20202,\r\n        &quot;fields&quot;: {\r\n            &quot;term&quot;: &quot;Summer&quot;,\r\n            &quot;year&quot;: 2020\r\n        }\r\n    },\r\n    {\r\n        &quot;model&quot;: &quot;about.term&quot;,\r\n        &quot;pk&quot;: 20203,\r\n        &quot;fields&quot;: {\r\n            &quot;term&quot;: &quot;Fall&quot;,\r\n            &quot;year&quot;: 2020\r\n        }\r\n    },\r\n    {\r\n        &quot;model&quot;: &quot;about.officer&quot;,\r\n        &quot;pk&quot;: 1,\r\n        &quot;fields&quot;: {\r\n            &quot;position&quot;: &quot;President&quot;,\r\n            &quot;term_position_number&quot;: 0,\r\n            &quot;name&quot;: &quot;Person 1&quot;,\r\n            &quot;start_date&quot;: &quot;1984-01-01T00:00:00&quot;,\r\n            &quot;sfuid&quot;: &quot;&quot;,\r\n            &quot;sfu_email_alias&quot;: &quot;&quot;,\r\n            &quot;phone_number&quot;: 11111111111,\r\n            &quot;github_username&quot;: &quot;&quot;,\r\n            &quot;gmail&quot;: &quot;&quot;,\r\n            &quot;course1&quot;: &quot;&quot;,\r\n            &quot;course2&quot;: &quot;&quot;,\r\n            &quot;language1&quot;: &quot;&quot;,\r\n            &quot;language2&quot;: &quot;&quot;,\r\n            &quot;bio&quot;: &quot;&quot;,\r\n            &quot;image&quot;: &quot;about_static/exec-photos/stockPhoto.jpg&quot;,\r\n            &quot;elected_term&quot;: 19841,\r\n            &quot;sfu_officer_mailing_list_email&quot;: &quot;NONE&quot;\r\n        }\r\n    },\r\n    {\r\n        &quot;model&quot;: &quot;about.officer&quot;,\r\n        &quot;pk&quot;: 2,\r\n        &quot;fields&quot;: {\r\n            &quot;position&quot;: &quot;Vice President&quot;,\r\n            &quot;term_position_number&quot;: 1,\r\n            &quot;name&quot;: &quot;Person 2&quot;,\r\n            &quot;start_date&quot;: &quot;1984-01-01T00:00:00&quot;,\r\n            &quot;sfuid&quot;: &quot;&quot;,\r\n            &quot;sfu_email_alias&quot;: &quot;&quot;,\r\n            &quot;phone_number&quot;: 2222222222222,\r\n            &quot;github_username&quot;: &quot;&quot;,\r\n            &quot;gmail&quot;: &quot;&quot;,\r\n            &quot;course1&quot;: &quot;&quot;,\r\n            &quot;course2&quot;: &quot;&quot;,\r\n            &quot;language1&quot;: &quot;&quot;,\r\n            &quot;language2&quot;: &quot;&quot;,\r\n            &quot;bio&quot;: &quot;&quot;,\r\n            &quot;image&quot;: &quot;about_static/exec-photos/stockPhoto.jpg&quot;,\r\n            &quot;elected_term&quot;: 19841,\r\n            &quot;sfu_officer_mailing_list_email&quot;: &quot;NONE&quot;\r\n        }\r\n    },\r\n    {\r\n        &quot;model&quot;: &quot;about.officer&quot;,\r\n        &quot;pk&quot;: 3,\r\n        &quot;fields&quot;: {\r\n            &quot;position&quot;: &quot;Treasurer&quot;,\r\n            &quot;term_position_number&quot;: 2,\r\n            &quot;name&quot;: &quot;Person 3&quot;,\r\n            &quot;start_date&quot;: &quot;1984-01-01T00:00:00&quot;,\r\n            &quot;sfuid&quot;: &quot;&quot;,\r\n            &quot;sfu_email_alias&quot;: &quot;&quot;,\r\n            &quot;phone_number&quot;: 3333333333,\r\n            &quot;github_username&quot;: &quot;&quot;,\r\n            &quot;gmail&quot;: &quot;&quot;,\r\n            &quot;course1&quot;: &quot;&quot;,\r\n            &quot;course2&quot;: &quot;&quot;,\r\n            &quot;language1&quot;: &quot;&quot;,\r\n            &quot;language2&quot;: &quot;&quot;,\r\n            &quot;bio&quot;: &quot;&quot;,\r\n            &quot;image&quot;: &quot;about_static/exec-photos/stockPhoto.jpg&quot;,\r\n            &quot;elected_term&quot;: 19841,\r\n            &quot;sfu_officer_mailing_list_email&quot;: &quot;NONE&quot;\r\n        }\r\n    },\r\n    {\r\n        &quot;model&quot;: &quot;about.officer&quot;,\r\n        &quot;pk&quot;: 4,\r\n        &quot;fields&quot;: {\r\n            &quot;position&quot;: &quot;Secretary&quot;,\r\n            &quot;term_position_number&quot;: 3,\r\n            &quot;name&quot;: &quot;Person 4&quot;,\r\n            &quot;start_date&quot;: &quot;1984-01-01T00:00:00&quot;,\r\n            &quot;sfuid&quot;: &quot;&quot;,\r\n            &quot;sfu_email_alias&quot;: &quot;&quot;,\r\n            &quot;phone_number&quot;: 444444444444,\r\n            &quot;github_username&quot;: &quot;&quot;,\r\n            &quot;gmail&quot;: &quot;&quot;,\r\n            &quot;course1&quot;: &quot;&quot;,\r\n            &quot;course2&quot;: &quot;&quot;,\r\n            &quot;language1&quot;: &quot;&quot;,\r\n            &quot;language2&quot;: &quot;&quot;,\r\n            &quot;bio&quot;: &quot;&quot;,\r\n            &quot;image&quot;: &quot;about_static/exec-photos/stockPhoto.jpg&quot;,\r\n            &quot;elected_term&quot;: 19841,\r\n            &quot;sfu_officer_mailing_list_email&quot;: &quot;NONE&quot;\r\n        }\r\n    }]\r\n\r\n\r\nhow can I change it with bash `jq` command so that it has the exact same data, structure and indentation but the values for key `sfuid` become `sfuid`, `sfu_email_alias` become `sfu_email_alias`, `phone_number` become `0`, `github_username` become `github_username` and `gmail` become `gmail`.\r\n\r\n\r\nbasically, I want to end up with this file\r\n\r\n    [{\r\n        &quot;model&quot;: &quot;about.term&quot;,\r\n        &quot;pk&quot;: 20202,\r\n        &quot;fields&quot;: {\r\n            &quot;term&quot;: &quot;Summer&quot;,\r\n            &quot;year&quot;: 2020\r\n        }\r\n    },\r\n    {\r\n        &quot;model&quot;: &quot;about.term&quot;,\r\n        &quot;pk&quot;: 20203,\r\n        &quot;fields&quot;: {\r\n            &quot;term&quot;: &quot;Fall&quot;,\r\n            &quot;year&quot;: 2020\r\n        }\r\n    },\r\n    {\r\n        &quot;model&quot;: &quot;about.officer&quot;,\r\n        &quot;pk&quot;: 1,\r\n        &quot;fields&quot;: {\r\n            &quot;position&quot;: &quot;President&quot;,\r\n            &quot;term_position_number&quot;: 0,\r\n            &quot;name&quot;: &quot;Person 1&quot;,\r\n            &quot;start_date&quot;: &quot;1984-01-01T00:00:00&quot;,\r\n            &quot;sfuid&quot;: &quot;sfuid&quot;,\r\n            &quot;sfu_email_alias&quot;: &quot;sfu_email_alias&quot;,\r\n            &quot;phone_number&quot;: 0,\r\n            &quot;github_username&quot;: &quot;github_username&quot;,\r\n            &quot;gmail&quot;: &quot;gmail&quot;,\r\n            &quot;course1&quot;: &quot;&quot;,\r\n            &quot;course2&quot;: &quot;&quot;,\r\n            &quot;language1&quot;: &quot;&quot;,\r\n            &quot;language2&quot;: &quot;&quot;,\r\n            &quot;bio&quot;: &quot;&quot;,\r\n            &quot;image&quot;: &quot;about_static/exec-photos/stockPhoto.jpg&quot;,\r\n            &quot;elected_term&quot;: 19841,\r\n            &quot;sfu_officer_mailing_list_email&quot;: &quot;NONE&quot;\r\n        }\r\n    },\r\n    {\r\n        &quot;model&quot;: &quot;about.officer&quot;,\r\n        &quot;pk&quot;: 2,\r\n        &quot;fields&quot;: {\r\n            &quot;position&quot;: &quot;Vice President&quot;,\r\n            &quot;term_position_number&quot;: 1,\r\n            &quot;name&quot;: &quot;Person 2&quot;,\r\n            &quot;start_date&quot;: &quot;1984-01-01T00:00:00&quot;,\r\n            &quot;sfuid&quot;: &quot;sfuid&quot;,\r\n            &quot;sfu_email_alias&quot;: &quot;sfu_email_alias&quot;,\r\n            &quot;phone_number&quot;: 0,\r\n            &quot;github_username&quot;: &quot;github_username&quot;,\r\n            &quot;gmail&quot;: &quot;gmail&quot;,\r\n            &quot;course1&quot;: &quot;&quot;,\r\n            &quot;course2&quot;: &quot;&quot;,\r\n            &quot;language1&quot;: &quot;&quot;,\r\n            &quot;language2&quot;: &quot;&quot;,\r\n            &quot;bio&quot;: &quot;&quot;,\r\n            &quot;image&quot;: &quot;about_static/exec-photos/stockPhoto.jpg&quot;,\r\n            &quot;elected_term&quot;: 19841,\r\n            &quot;sfu_officer_mailing_list_email&quot;: &quot;NONE&quot;\r\n        }\r\n    },\r\n    {\r\n        &quot;model&quot;: &quot;about.officer&quot;,\r\n        &quot;pk&quot;: 3,\r\n        &quot;fields&quot;: {\r\n            &quot;position&quot;: &quot;Treasurer&quot;,\r\n            &quot;term_position_number&quot;: 2,\r\n            &quot;name&quot;: &quot;Person 3&quot;,\r\n            &quot;start_date&quot;: &quot;1984-01-01T00:00:00&quot;,\r\n            &quot;sfuid&quot;: &quot;sfuid&quot;,\r\n            &quot;sfu_email_alias&quot;: &quot;sfu_email_alias&quot;,\r\n            &quot;phone_number&quot;: 0,\r\n            &quot;github_username&quot;: &quot;github_username&quot;,\r\n            &quot;gmail&quot;: &quot;gmail&quot;,\r\n            &quot;course1&quot;: &quot;&quot;,\r\n            &quot;course2&quot;: &quot;&quot;,\r\n            &quot;language1&quot;: &quot;&quot;,\r\n            &quot;language2&quot;: &quot;&quot;,\r\n            &quot;bio&quot;: &quot;&quot;,\r\n            &quot;image&quot;: &quot;about_static/exec-photos/stockPhoto.jpg&quot;,\r\n            &quot;elected_term&quot;: 19841,\r\n            &quot;sfu_officer_mailing_list_email&quot;: &quot;NONE&quot;\r\n        }\r\n    },\r\n    {\r\n        &quot;model&quot;: &quot;about.officer&quot;,\r\n        &quot;pk&quot;: 4,\r\n        &quot;fields&quot;: {\r\n            &quot;position&quot;: &quot;Secretary&quot;,\r\n            &quot;term_position_number&quot;: 3,\r\n            &quot;name&quot;: &quot;Person 4&quot;,\r\n            &quot;start_date&quot;: &quot;1984-01-01T00:00:00&quot;,\r\n            &quot;sfuid&quot;: &quot;sfuid&quot;,\r\n            &quot;sfu_email_alias&quot;: &quot;sfu_email_alias&quot;,\r\n            &quot;phone_number&quot;: 0,\r\n            &quot;github_username&quot;: &quot;github_username&quot;,\r\n            &quot;gmail&quot;: &quot;gmail&quot;,\r\n            &quot;course1&quot;: &quot;&quot;,\r\n            &quot;course2&quot;: &quot;&quot;,\r\n            &quot;language1&quot;: &quot;&quot;,\r\n            &quot;language2&quot;: &quot;&quot;,\r\n            &quot;bio&quot;: &quot;&quot;,\r\n            &quot;image&quot;: &quot;about_static/exec-photos/stockPhoto.jpg&quot;,\r\n            &quot;elected_term&quot;: 19841,\r\n            &quot;sfu_officer_mailing_list_email&quot;: &quot;NONE&quot;\r\n        }\r\n    }]",
        "link": "https://stackoverflow.com/questions/64180946/how-to-replace-a-value-in-a-json-file-with-jq",
        "title": "how to replace a value in a json file with jq?"
    },
    {
        "tags": [
            "arrays",
            "json",
            "search",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1601731594,
                "creation_date": 1601731594,
                "answer_id": 64184788,
                "question_id": 64183692,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&lt;!-- hope it will help --&gt;\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 jsonArr = [\r\n        {\r\n            &quot;name&quot;: &quot;first&quot;,\r\n            &quot;Arrays&quot;: {\r\n                &quot;dddd0001&quot;: [\r\n                    &quot;A&quot;,\r\n                    &quot;A&quot;,\r\n                    &quot;B&quot;,\r\n                    &quot;B&quot;,\r\n                    &quot;C&quot;,\r\n                    &quot;C&quot;,\r\n                    &quot;C&quot;,\r\n                    &quot;C&quot;,\r\n                    &quot;D&quot;,\r\n                    &quot;E&quot;,\r\n                    &quot;F&quot;\r\n                ]\r\n            }\r\n        },\r\n        {\r\n            &quot;name&quot;: &quot;second&quot;,\r\n            &quot;Arrays&quot;: {\r\n                &quot;dddd0002&quot;: [\r\n                    &quot;AA&quot;,\r\n                    &quot;AA&quot;,\r\n                    &quot;BA&quot;,\r\n                    &quot;BB&quot;,\r\n                    &quot;CC&quot;,\r\n                    &quot;CC&quot;,\r\n                    &quot;CC&quot;,\r\n                    &quot;CC&quot;,\r\n                    &quot;DD&quot;,\r\n                    &quot;DD&quot;,\r\n                    &quot;FF&quot;\r\n                ]\r\n            }\r\n        },\r\n        {\r\n            &quot;name&quot;: &quot;third&quot;,\r\n            &quot;Arrays&quot;: {\r\n                &quot;dddd0003&quot;: [\r\n                    &quot;1&quot;,\r\n                    &quot;1&quot;,\r\n                    &quot;2&quot;,\r\n                    &quot;3&quot;,\r\n                    &quot;3&quot;,\r\n                    &quot;4&quot;,\r\n                    &quot;4&quot;,\r\n                    &quot;4&quot;,\r\n                    &quot;0&quot;,\r\n                    &quot;0&quot;,\r\n                    &quot;0&quot;\r\n                ]\r\n            }\r\n        }\r\n    ]\r\n\r\n\r\n    for(var i=0; i&lt; jsonArr.length; i++)\r\n    {\r\n    var arrtemp =  jsonArr[i][Object.keys(jsonArr[i])[1]];\r\n\r\n    var arrtmp2 = arrtemp[Object.keys(arrtemp)[0]];\r\n\r\n     jsonArr[i][Object.keys(jsonArr[i])[1]] =arrtmp2.filter((v, p) =&gt; arrtmp2.indexOf(v) == p);\r\n     \r\n     console.log(jsonArr[i])\r\n\r\n    }\r\n\r\n&lt;!-- end snippet --&gt;\r\n\r\n",
                "title": "jq - remove duplicate entries within all arrays inside the JSON file"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1601741782,
                "last_edit_date": 1601741782,
                "creation_date": 1601737999,
                "answer_id": 64185715,
                "question_id": 64183692,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "you can use `unique` and `|=`:\r\n\r\n    $ jq &#39;.[].Arrays[] |= unique&#39; file.json\r\n    [\r\n      {\r\n        &quot;name&quot;: &quot;first&quot;,\r\n        &quot;Arrays&quot;: {\r\n          &quot;dddd0001&quot;: [\r\n            &quot;A&quot;,\r\n            &quot;B&quot;,\r\n            &quot;C&quot;,\r\n            &quot;D&quot;,\r\n            &quot;E&quot;,\r\n            &quot;F&quot;\r\n          ]\r\n        }\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;second&quot;,\r\n        &quot;Arrays&quot;: {\r\n          &quot;dddd0002&quot;: [\r\n            &quot;AA&quot;,\r\n            &quot;BA&quot;,\r\n            &quot;BB&quot;,\r\n            &quot;CC&quot;,\r\n            &quot;DD&quot;,\r\n            &quot;FF&quot;\r\n          ]\r\n        }\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;third&quot;,\r\n        &quot;Arrays&quot;: {\r\n          &quot;dddd0003&quot;: [\r\n            &quot;0&quot;,\r\n            &quot;1&quot;,\r\n            &quot;2&quot;,\r\n            &quot;3&quot;,\r\n            &quot;4&quot;\r\n          ]\r\n        }\r\n      }\r\n    ]\r\n    $\r\n\r\nthe only &quot;problem&quot; is that `unique` sorts the elements of the array, so for example contents of `&quot;dddd0003&quot;` array are not in the same order of your expected result. I don&#39;t know if this is could be a problem for you.\r\n\r\nif `&quot;Arrays&quot;` property can also contain &quot;non-array&quot; values, extra care can be taken in order to &quot;filter out&quot; those &quot;non-array&quot; values so that `unique` doesn&#39;t complain.\r\n\r\n`select(type == &quot;array&quot;)` can be used: (output omitted):\r\n\r\n    $ jq &#39;(.[].Arrays[] | select(type == &quot;array&quot;)) |= unique&#39; file.json\r\n    ...\r\n\r\nor `arrays`:\r\n\r\n    $ jq &#39;(.[].Arrays[] | arrays) |= unique&#39; file.json\r\n    ...\r\n\r\nthese last two solutions better reflect your algorithm.",
                "title": "jq - remove duplicate entries within all arrays inside the JSON file"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1601745871,
                "creation_date": 1601745871,
                "answer_id": 64186988,
                "question_id": 64183692,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "    walk( if type == &quot;array&quot; then unique else . end)\r\n\r\nIf the original order should be respected, then you can easily use &quot;def uniques&quot; as defined at https://stackoverflow.com/questions/56626848/how-do-i-get-jq-to-return-unique-results-when-json-has-multiple-identical-entrie",
                "title": "jq - remove duplicate entries within all arrays inside the JSON file"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1601745871,
        "creation_date": 1601724402,
        "question_id": 64183692,
        "body_markdown": "I have the following JSON file. \r\n```\r\n[\r\n    {\r\n        &quot;name&quot;: &quot;first&quot;,\r\n        &quot;Arrays&quot;: {\r\n            &quot;dddd0001&quot;: [\r\n                &quot;A&quot;,\r\n                &quot;A&quot;,\r\n                &quot;B&quot;,\r\n                &quot;B&quot;,\r\n                &quot;C&quot;,\r\n                &quot;C&quot;,\r\n                &quot;C&quot;,\r\n                &quot;C&quot;,\r\n                &quot;D&quot;,\r\n                &quot;E&quot;,\r\n                &quot;F&quot;\r\n            ]\r\n        }\r\n    },\r\n    {\r\n        &quot;name&quot;: &quot;second&quot;,\r\n        &quot;Arrays&quot;: {\r\n            &quot;dddd0002&quot;: [\r\n                &quot;AA&quot;,\r\n                &quot;AA&quot;,\r\n                &quot;BA&quot;,\r\n                &quot;BB&quot;,\r\n                &quot;CC&quot;,\r\n                &quot;CC&quot;,\r\n                &quot;CC&quot;,\r\n                &quot;CC&quot;,\r\n                &quot;DD&quot;,\r\n                &quot;DD&quot;,\r\n                &quot;FF&quot;\r\n            ]\r\n        }\r\n    },\r\n    {\r\n        &quot;name&quot;: &quot;third&quot;,\r\n        &quot;Arrays&quot;: {\r\n            &quot;dddd0003&quot;: [\r\n                &quot;1&quot;,\r\n                &quot;1&quot;,\r\n                &quot;2&quot;,\r\n                &quot;3&quot;,\r\n                &quot;3&quot;,\r\n                &quot;4&quot;,\r\n                &quot;4&quot;,\r\n                &quot;4&quot;,\r\n                &quot;0&quot;,\r\n                &quot;0&quot;,\r\n                &quot;0&quot;\r\n            ]\r\n        }\r\n    }\r\n]\r\n```\r\nI need to remove duplicates inside every array in the JSON file. So the result should look like following\r\n```\r\n[\r\n    {\r\n        &quot;name&quot;: &quot;first&quot;,\r\n        &quot;Arrays&quot;: {\r\n            &quot;dddd0001&quot;: [\r\n                &quot;A&quot;,\r\n                &quot;B&quot;,\r\n                &quot;C&quot;,\r\n                &quot;D&quot;,\r\n                &quot;E&quot;,\r\n                &quot;F&quot;\r\n            ]\r\n        }\r\n    },\r\n    {\r\n        &quot;name&quot;: &quot;second&quot;,\r\n        &quot;Arrays&quot;: {\r\n            &quot;dddd0002&quot;: [\r\n                &quot;AA&quot;,\r\n                &quot;BA&quot;,\r\n                &quot;BB&quot;,\r\n                &quot;CC&quot;,\r\n                &quot;DD&quot;,\r\n                &quot;FF&quot;\r\n            ]\r\n        }\r\n    },\r\n    {\r\n        &quot;name&quot;: &quot;third&quot;,\r\n        &quot;Arrays&quot;: {\r\n            &quot;dddd0003&quot;: [\r\n                &quot;1&quot;,\r\n                &quot;2&quot;,\r\n                &quot;3&quot;,\r\n                &quot;4&quot;,\r\n                &quot;0&quot;\r\n            ]\r\n        }\r\n    }\r\n]\r\n```\r\nArray key names are not known in advance. There might be multiple arrays inside the ``Arrays`` object.\r\nI tried to use ``unique_by`` but it requires the key name.\r\n\r\nThis algorithm - search for every array inside the Arrays object, for every such array apply ``unique`` function, re-assign results back to the array - should be fairly easy to implement, but I am stuck.\r\n\r\nThanks.",
        "link": "https://stackoverflow.com/questions/64183692/jq-remove-duplicate-entries-within-all-arrays-inside-the-json-file",
        "title": "jq - remove duplicate entries within all arrays inside the JSON file"
    },
    {
        "tags": [
            "bash",
            "jq",
            "azure-cli"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2435703,
                    "reputation": 27493,
                    "user_id": 2125671,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/13a492143ab4a2575b5a1f500691193c?s=256&d=identicon&r=PG",
                    "display_name": "Philippe",
                    "link": "https://stackoverflow.com/users/2125671/philippe"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1601756351,
                "post_id": 64184270,
                "comment_id": 113506474,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1601729054,
                "creation_date": 1601729054,
                "answer_id": 64184418,
                "question_id": 64184270,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I don&#39;t know why,but I changed to `for loop` to do it and it&#39;s work\r\n\r\n```bash\r\nsa@DESKTOP-WEI:~$ for rg in $(az group list --query &quot;[?name != &#39;product&#39;].name&quot; | jq -r &#39;.[]&#39;); \\\r\n&gt; do az group delete -n ${rg};\\\r\n&gt; done\r\nAre you sure you want to perform this operation? (y/n):\r\n```\r\n\r\nidea from : \r\n[How to Delete Multiple Azure Resource Groups with Tags, Bash via Azure Cloud Shell, and the Azure CLI | Jon Gallant](https://blog.jongallant.com/2020/05/azure-delete-multiple-resource-groups/)",
                "title": "az group delete -n $v show &quot;ValidationError: Parameter &#39;resource_group_name&#39; must conform to the following pattern&quot;"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1601729054,
        "creation_date": 1601728129,
        "question_id": 64184270,
        "body_markdown": "what trouble I met: \r\n```bash\r\nsa@DESKTOP-WEI:~$ az group list --query &quot;[?name != &#39;product&#39;].name&quot; | jq -c &#39;.[]&#39; | while read g; do     az group delete -n $g --no-wait -y;  don\r\ne\r\nValidationError: Parameter &#39;resource_group_name&#39; must conform to the following pattern: &#39;^[-\\\\w\\\\._\\\\(\\\\)]+$&#39;.\r\n```\r\n\r\nwhat I&#39;ve tried :  \r\n\r\nI tried to print `$g` value,it looks like just normal string  \r\n```bash\r\nsa@DESKTOP-WEI:~$ az group list --query &quot;[?name != &#39;product&#39;].name&quot; | jq -c &#39;.[]&#39; | while read g; do     echo $g; done\r\n&quot;NetworkWatcherRG&quot;\r\n```",
        "link": "https://stackoverflow.com/questions/64184270/az-group-delete-n-v-show-validationerror-parameter-resource-group-name-mus",
        "title": "az group delete -n $v show &quot;ValidationError: Parameter &#39;resource_group_name&#39; must conform to the following pattern&quot;"
    },
    {
        "tags": [
            "arrays",
            "json",
            "select",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1601796796,
                "creation_date": 1601796796,
                "answer_id": 64192155,
                "question_id": 64191907,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This seems to be what you want:\r\n\r\n    jq &#39;.[].Data |= . + { length:.[]|length } &#39; data.json\r\n\r\nOutput:\r\n\r\n    [\r\n      {\r\n        &quot;name&quot;: &quot;California&quot;,\r\n        &quot;Data&quot;: {\r\n          &quot;AB00001&quot;: [\r\n            &quot;Los Angeles&quot;,\r\n            &quot;San Francisco&quot;,\r\n            &quot;Sacramento&quot;,\r\n            &quot;Fresno&quot;,\r\n            &quot;San Jose&quot;,\r\n            &quot;Palo Alto&quot;\r\n          ],\r\n          &quot;length&quot;: 6\r\n        }\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;Oregon&quot;,\r\n        &quot;Data&quot;: {\r\n          &quot;CD00002&quot;: [\r\n            &quot;Portland&quot;,\r\n            &quot;Salem&quot;,\r\n            &quot;Hillsboro&quot;\r\n          ],\r\n          &quot;length&quot;: 3\r\n        }\r\n      },\r\n     # etc.\r\n\r\n\r\n",
                "title": "Jq - calculate length of each array in JSON and update it"
            },
            {
                "up_vote_count": 10,
                "is_accepted": true,
                "score": 10,
                "last_activity_date": 1601827220,
                "last_edit_date": 1601827220,
                "creation_date": 1601797222,
                "answer_id": 64192203,
                "question_id": 64191907,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "A solution to the immediate problem (in which .Data is a single-key object with an array-valued key) could be as simple as:\r\n\r\n    map( .Data.Length = (.Data[]|length) )\r\n\r\nThis can be adapted to the more general problem in steps.  First, consider this generalization:\r\n\r\n    map( .Data |= if length==1 and (.[]|type) == &quot;array&quot; \r\n                  then .Length = (.[]|length) \r\n                  else . end )\r\n### Solution\r\nTo make the actual solution easier to understand, let&#39;s define a helper function:\r\n\r\n```\r\ndef addLength:\r\n   (first(keys_unsorted[] as $k\r\n          | select(.[$k]|type == &quot;object&quot;)\r\n          | .[$k]\r\n\t      | keys_unsorted[] as $l \r\n          | select(.[$l]|type == &quot;array&quot;)\r\n          | [$k,$l]) // null) as $a\r\n   | if $a \r\n     then setpath([$a[0],&quot;Length&quot;]; getpath($a)|length)\r\n     else .\r\n     end;\r\n```\r\nA general solution can now be written using `walk`:\r\n```\r\nwalk(if type == &quot;object&quot; and has(&quot;name&quot;)\r\n     then addLength\r\n     else . end)\r\n```\r\n \r\n",
                "title": "Jq - calculate length of each array in JSON and update it"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 8,
        "last_activity_date": 1601827220,
        "creation_date": 1601794459,
        "question_id": 64191907,
        "body_markdown": "I have the following JSON array\r\n```\r\n[\r\n  {\r\n    &quot;name&quot;: &quot;California&quot;,\r\n    &quot;Data&quot;: {\r\n      &quot;AB00001&quot;: [&quot;Los Angeles&quot;, &quot;San Francisco&quot;, &quot;Sacramento&quot;, &quot;Fresno&quot;, &quot;San Jose&quot;, &quot;Palo Alto&quot;]\r\n    }\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;Oregon&quot;,\r\n    &quot;Data&quot;: {\r\n      &quot;CD00002&quot;: [&quot;Portland&quot;, &quot;Salem&quot;, &quot;Hillsboro&quot;]\r\n    }\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;Washington&quot;,\r\n    &quot;Data&quot;: {\r\n      &quot;EF00003&quot;: [&quot;Seattle&quot;, &quot;Tacoma&quot;, &quot;Spokane&quot;, &quot;Bellevue&quot;]\r\n    }\r\n  }\r\n]\r\n```\r\nWith ``jq &#39;.[].Data[] | length&#39;`` I can get the length of each array, but I need to create ``Length`` key under ``Data`` object and assign to it the length of the array which is in the Data object. The result should look like the following:\r\n\r\n```\r\n[\r\n    {\r\n        &quot;name&quot;: &quot;California&quot;,\r\n        &quot;Data&quot;: {\r\n            &quot;ID00001&quot;: [&quot;Los Angeles&quot;, &quot;San Francisco&quot;, &quot;Sacramento&quot;, &quot;Fresno&quot;, &quot;San Jose&quot;, &quot;Palo Alto&quot;],\r\n            &quot;Length&quot;: 6\r\n        }\r\n    },\r\n    {\r\n        &quot;name&quot;: &quot;Oregon&quot;,\r\n        &quot;Data&quot;: {\r\n            &quot;ID00002&quot;: [&quot;Portland&quot;, &quot;Salem&quot;, &quot;Hillsboro&quot;],\r\n            &quot;Length&quot;: 3\r\n        }\r\n    },\r\n    {\r\n        &quot;name&quot;: &quot;Washington&quot;,\r\n        &quot;Data&quot;: {\r\n            &quot;ID00003&quot;: [&quot;Seattle&quot;, &quot;Tacoma&quot;, &quot;Spokane&quot;, &quot;Bellevue&quot;],\r\n            &quot;Length&quot;: 4\r\n        }\r\n    }\r\n]\r\n```\r\n\r\nThe problem here is that in my example the object name holding the array (``Data`` in my example) and the array name itself (``AB00001/CD00002/EF00003``) are not known in advance. However, the values of the ``name`` key is known. Also, the array might be empty, so in this case, the ``Length`` should be 0.\r\n\r\nSo the algorithm pseudocode should be either of one as I&#39;ve envisioned:\r\n```\r\nfor the whole JSON file, \r\nif the type is an array, \r\nthen assign it to the Length key created in the parent object of that array, \r\nnext\r\n```\r\nor \r\n```\r\nFor the specific value in the name key, select,\r\nif the entry contains an array\r\ncreate Length key in the array&#39;s parent object, \r\nassign the length of the array,\r\nselect the next value of the name key\r\n```\r\nI tried to use with jq&#39;s ``walk`` or ``..`` for the first approach but didn&#39;t work.\r\nWhat are the alternatives?",
        "link": "https://stackoverflow.com/questions/64191907/jq-calculate-length-of-each-array-in-json-and-update-it",
        "title": "Jq - calculate length of each array in JSON and update it"
    },
    {
        "tags": [
            "json",
            "ffmpeg",
            "jq",
            "trim",
            "mkv"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1744586295,
                "last_edit_date": 1744586295,
                "creation_date": 1604691240,
                "answer_id": 64720618,
                "question_id": 64192235,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If I understand correctly, you want to remove the &quot;*Advertisement*&quot;-chapters. This could probably be done entirely with FFprobe, but without the source video I can&#39;t say for sure.  \r\nYou might want to take a look at the XML/HTML/JSON parser and command-line tool [tag:xidel] for this issue.\r\n\r\nFirst of all, you don&#39;t have to save FFprobe&#39;s output to a JSON-file. You can just pipe it to Xidel and select the objects / chapters labeled as &quot;Video&quot;:\r\n```\r\nC:\\&gt;ffprobe -v quiet -print_format json -show_chapters -loglevel error &quot;01x01.mp4&quot; | xidel -se &quot;$json/(chapters)()[tags/title=&#39;Video&#39;]&quot;\r\n{\r\n  &quot;id&quot;: 0,\r\n  &quot;time_base&quot;: &quot;1/1000&quot;,\r\n  &quot;start&quot;: 0,\r\n  &quot;start_time&quot;: &quot;0.000000&quot;,\r\n  &quot;end&quot;: 5590,\r\n  &quot;end_time&quot;: &quot;5.590000&quot;,\r\n  &quot;tags&quot;: {\r\n    &quot;title&quot;: &quot;Video&quot;\r\n  }\r\n}\r\n[...]\r\n{\r\n  &quot;id&quot;: 8,\r\n  &quot;time_base&quot;: &quot;1/1000&quot;,\r\n  &quot;start&quot;: 1477569,\r\n  &quot;start_time&quot;: &quot;1477.569000&quot;,\r\n  &quot;end&quot;: 1529696,\r\n  &quot;end_time&quot;: &quot;1529.696000&quot;,\r\n  &quot;tags&quot;: {\r\n    &quot;title&quot;: &quot;Video&quot;\r\n  }\r\n}\r\n```\r\nTo calculate the duration (in seconds) of the 4 chapters:\r\n```\r\nC:\\&gt;ffprobe [...] | xidel -se &quot;$json/(chapters)()[tags/title=&#39;Video&#39;]/((end - start) div 1000)&quot;\r\n5.59\r\n149.97\r\n351.909\r\n817.738\r\n52.127\r\n```\r\nTo generate the FFmpeg strings / commands with these values and the `start` attribute:\r\n```\r\nC:\\&gt;ffprobe [...] | xidel -se &quot;$json/(chapters)()[tags/title=&#39;Video&#39;]/concat(&#39;ffmpeg -ss &#39;,start div 1000,&#39; -i \\&quot;01x01.mp4\\&quot; -to &#39;,((end - start) div 1000),&#39; -c copy -avoid_negative_ts make_zero \\&quot;01x01-&#39;,position(),&#39;.mp4\\&quot;&#39;)&quot;\r\nC:\\&gt;ffprobe [...] | xidel -se ^&quot;^\r\n  $json/(chapters)()[tags/title=&#39;Video&#39;]/concat(^\r\n    &#39;ffmpeg -ss &#39;,start div 1000,^\r\n    &#39; -i \\&quot;01x01.mp4\\&quot; -to &#39;,((end - start) div 1000),^\r\n    &#39; -c copy -avoid_negative_ts make_zero \\&quot;01x01-&#39;,position(),&#39;.mp4\\&quot;&#39;^\r\n  )\r\n&quot;\r\nffmpeg -ss 0 -i &quot;01x01.mp4&quot; -to 5.59 -c copy -avoid_negative_ts make_zero &quot;01x01-1.mp4&quot;\r\nffmpeg -ss 13.994 -i &quot;01x01.mp4&quot; -to 149.97 -c copy -avoid_negative_ts make_zero &quot;01x01-2.mp4&quot;\r\nffmpeg -ss 195.94 -i &quot;01x01.mp4&quot; -to 351.909 -c copy -avoid_negative_ts make_zero &quot;01x01-3.mp4&quot;\r\nffmpeg -ss 595.85 -i &quot;01x01.mp4&quot; -to 817.738 -c copy -avoid_negative_ts make_zero &quot;01x01-4.mp4&quot;\r\nffmpeg -ss 1477.569 -i &quot;01x01.mp4&quot; -to 52.127 -c copy -avoid_negative_ts make_zero &quot;01x01-5.mp4&quot;\r\n```\r\nTo execute these FFmpeg commands, simply put the entire command in a `FOR`-loop:\r\n```\r\nC:\\&gt;FOR /F &quot;delims=&quot; %A IN (&#39;ffprobe [...] ^| xidel -se &quot;$json/(chapters)()[tags/title=&#39;Video&#39;]/concat(&#39;ffmpeg -ss &#39;,start div 1000,&#39; -i \\&quot;01x01.mp4\\&quot; -to &#39;,((end - start) div 1000),&#39; -c copy -avoid_negative_ts make_zero \\&quot;01x01-&#39;^,position^(^)^,&#39;.mp4\\&quot;&#39;)&quot;&#39;) DO @%A\r\nC:\\&gt;FOR /F &quot;delims=&quot; %A IN (&#39;\r\n  ffprobe [...] ^| xidel -se &quot;\r\n    $json/^(chapters^)^(^)[tags/title^=&#39;Video&#39;]/concat^(\r\n      &#39;ffmpeg -ss &#39;^,start div 1000^,\r\n      &#39; -i \\&quot;01x01.mp4\\&quot; -to &#39;^,^(^(end - start^) div 1000^)^,\r\n      &#39; -c copy -avoid_negative_ts make_zero \\&quot;01x01-&#39;,position(),&#39;.mp4\\&quot;&#39;\r\n    ^)\r\n  &quot;\r\n&#39;) DO @%A\r\n```\r\n_(within a Batch-script use `%%A` of course)_\r\n\r\nTo generate and execute the MKVMerge strings / commands, with the help of the integrated [EXPath File Module](http://www.benibela.de/documentation/internettools/xpath-functions.html#modulefile):\r\n```\r\nC:\\&gt;xidel -se &quot;file:list(.,false(),&#39;01x01-*.mp4&#39;)&quot;\r\n01x01-1.mp4\r\n01x01-2.mp4\r\n01x01-3.mp4\r\n01x01-4.mp4\r\n01x01-5.mp4\r\n\r\nC:\\&gt;xidel -se &quot;file:list(.,false(),&#39;01x01-*.mp4&#39;) ! `\\&quot;{.}\\&quot;`&quot;\r\n&quot;01x01-1.mp4&quot;\r\n&quot;01x01-2.mp4&quot;\r\n&quot;01x01-3.mp4&quot;\r\n&quot;01x01-4.mp4&quot;\r\n&quot;01x01-5.mp4&quot;\r\n\r\nC:\\&gt;xidel -se &quot;&#39;mkvmerge -o \\&quot;01x01-FINAL.mkv\\&quot; &#39;||join(file:list(.,false(),&#39;01x01-*.mp4&#39;) ! `\\&quot;{.}\\&quot;`,&#39; + &#39;)&quot;\r\nmkvmerge -o &quot;01x01-FINAL.mkv&quot; &quot;01x01-1.mp4&quot; + &quot;01x01-2.mp4&quot; + &quot;01x01-3.mp4&quot; + &quot;01x01-4.mp4&quot; + &quot;01x01-5.mp4&quot;\r\n\r\nC:\\&gt;FOR /F &quot;delims=&quot; %A IN (&#39;xidel -se &quot;&#39;mkvmerge -o \\&quot;01x01-FINAL.mkv\\&quot; &#39;||join(file:list(.,false(),&#39;01x01-*.mp4&#39;) ! `\\&quot;{.}\\&quot;`,&#39; + &#39;)&quot;&#39;) DO @%A\r\nC:\\&gt;FOR /F &quot;delims=&quot; %A IN (&#39;\r\n  xidel -se &quot;\r\n    &#39;mkvmerge -o \\&quot;01x01-FINAL.mkv\\&quot; &#39;^|^|\r\n    join^(\r\n      file:list^(.^,false^(^)^,&#39;01x01-*.mp4&#39;^) ! `\\&quot;{.}\\&quot;`^,\r\n      &#39; + &#39;\r\n    ^)\r\n  &quot;\r\n&#39;) DO @%A\r\n```\r\nIf you want to process multiple mp4-files, then you could use the following Batch-script:\r\n```\r\nFOR %%A IN (*.mp4) DO (\r\n  FOR /F &quot;delims=&quot; %%B IN (&#39;\r\n    ffprobe -v quiet -print_format json -show_chapters -loglevel error &quot;%%A&quot; ^|\r\n    xidel -se &quot;\r\n      $json/^(chapters^)^(^)[tags/title^=&#39;Video&#39;]/concat^(\r\n        &#39;ffmpeg -ss &#39;^,start div 1000^,\r\n        &#39; -i \\&quot;%%A\\&quot; -to &#39;^,^(^(end - start^) div 1000^)^,\r\n        &#39; -c copy -avoid_negative_ts make_zero \\&quot;%%~nA-&#39;,position(),&#39;.mp4\\&quot;&#39;\r\n      ^)\r\n    &quot;\r\n  &#39;) DO @%%B\r\n  FOR /F &quot;delims=&quot; %%C IN (&#39;\r\n    xidel -se &quot;\r\n      &#39;mkvmerge -o \\&quot;%%~nA-FINAL.mkv\\&quot; &#39;^|^|\r\n      join^(\r\n        file:list^(.^,false^(^)^,&#39;%%~nA-*.mp4&#39;^) ! `\\&quot;{.}\\&quot;`^,\r\n        &#39; + &#39;\r\n      ^)\r\n    &quot;\r\n  &#39;) DO @%%C\r\n)\r\n```",
                "title": "Is there a way to batch split a file by chapter with ffmpeg and then reassemble with mkvmerge in windows?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1744586295,
        "creation_date": 1601797454,
        "last_edit_date": 1604854747,
        "question_id": 64192235,
        "body_markdown": "So I made a batch script originally with the ability to relatively precision trim a video into chapters without having to run by keyframes, but the code looks horrible and I can&#39;t get it to loop through all mp4 files nor get mkvmerge to append the files after splitting them. Code is below but be gentle it is my first try.\r\n```\r\n@echo off\r\nsetlocal enableDelayedExpansion\r\n\r\nREM CODE BELOW CREATES JSON FILES FOR ALL MP4 FILES WITHIN THE SAME DIRECTORY\r\nffprobe -v quiet -print_format json -show_chapters -loglevel error &quot;01x01.mp4&quot; &gt; &quot;01x01.json&quot;\r\n\r\nREM CODE BELOW SETS VARIABLES FROM EACH SPECIFIC JSON\r\nFOR /F &quot;delims=&quot; %%i in (&#39;jq .chapters[2].start ^&lt; 01x01.json&#39;) DO SET /A start1=%%i\r\nFOR /F &quot;delims=&quot; %%j in (&#39;jq .chapters[2].end ^&lt; 01x01.json&#39;) DO SET /A end1=%%j\r\n\r\nFOR /F &quot;delims=&quot; %%k in (&#39;jq .chapters[4].start ^&lt; 01x01.json&#39;) DO SET /A start2=%%k\r\nFOR /F &quot;delims=&quot; %%l in (&#39;jq .chapters[4].end ^&lt; 01x01.json&#39;) DO SET /A end2=%%l\r\n\r\nFOR /F &quot;delims=&quot; %%m in (&#39;jq .chapters[6].start ^&lt; 01x01.json&#39;) DO SET /A start3=%%m\r\nFOR /F &quot;delims=&quot; %%n in (&#39;jq .chapters[6].end ^&lt; 01x01.json&#39;) DO SET /A end3=%%n\r\n\r\nFOR /F &quot;delims=&quot; %%o in (&#39;jq .chapters[8].start ^&lt; 01x01.json&#39;) DO SET /A start4=%%o\r\nFOR /F &quot;delims=&quot; %%p in (&#39;jq .chapters[8].end ^&lt; 01x01.json&#39;) DO SET /A end4=%%p\r\n\r\nREM SETS THE DURATION OF EACH FILE TO USE PRECISION TIMING FOR START AND STOP TIMES\r\nCALL vbs (%end1%-%start1%)/1000\r\nSET duration1=%val%\r\nCALL vbs (%end2%-%start2%)/1000\r\nSET duration2=%val%\r\nCALL vbs (%end3%-%start3%)/1000\r\nSET duration3=%val%\r\nCALL vbs (%end4%-%start4%)/1000\r\nSET duration4=%val%\r\n\r\nREM SETS THE START TIME IN SECONDS VS MILLISECONDS\r\nCALL vbs (%start1%)/1000\r\nSET start1=%val%\r\nCALL vbs (%start2%)/1000\r\nSET start2=%val%\r\nCALL vbs (%start3%)/1000\r\nSET start3=%val%\r\nCALL vbs (%start4%)/1000\r\nSET start4=%val%\r\n\r\nREM TRIM AND SPLIT ORIGINAL FILE INTO SEPERATE SECTIONS BASED ON CHAPTER MARKERS\r\nffmpeg -ss %START1% -i 01x01.mp4 -ss 0 -c copy -to %DURATION1% -avoid_negative_ts make_zero 01x01-1.mp4\r\nffmpeg -ss %START2% -i 01x01.mp4 -ss 0 -c copy -to %DURATION2% -avoid_negative_ts make_zero 01x01-2.mp4\r\nffmpeg -ss %START3% -i 01x01.mp4 -ss 0 -c copy -to %DURATION3% -avoid_negative_ts make_zero 01x01-3.mp4\r\nffmpeg -ss %START4% -i 01x01.mp4 -ss 0 -c copy -to %DURATION4% -avoid_negative_ts make_zero 01x01-4.mp4\r\n\r\nREM DELETES UNNEEDED JSON AFTER USE\r\ndel /s *.json\r\n\r\nREM APPEND ALL MP4 FILES INTO COHESIVE MKV\r\nfor /d /r %%D in (*) do (\r\n    pushd %%D\r\n    set files=\r\n    for %%F in (*.mp4) do set files=!files! + ^( &quot;%%F&quot; ^)\r\n    if not &quot;!files!&quot;==&quot;&quot; %mkvmerge% -o &quot;01x01-FINAL.mkv&quot; !files:~2!\r\n    popd\r\n)\r\n\r\nREM DELETE UNNEEDED MP4 ORIGINALS AND SPLIT FILES\r\ndel /s *.mp4\r\n```\r\n\r\nI know it is super long and every time I try to use a variable or a loop to run  through all files it can&#39;t read the json file. I&#39;ve been at this all day and I can use the script as is but I have to make a file for each iteration.\r\n\r\nI was also hoping to be able to have it only pull chapters labeled as &quot;video&quot; but I haven&#39;t quite figured that one out yet.\r\n\r\nI&#39;ll add the vbs batch file for the arithmetic section as well as the sample json if it will help.\r\n\r\n```\r\n@echo off\r\n&gt;&quot;%temp%\\VBS.vbs&quot; echo Set fso = CreateObject(&quot;Scripting.FileSystemObject&quot;) : Wscript.echo (%*)\r\nfor /f &quot;delims=&quot; %%a in (&#39;cscript /nologo &quot;%temp%\\VBS.vbs&quot;&#39;) do set &quot;val=%%a&quot;\r\ndel &quot;%temp%\\VBS.vbs&quot;\r\n```\r\n\r\n```\r\n{\r\n    &quot;chapters&quot;: [\r\n        {\r\n            &quot;id&quot;: 0,\r\n            &quot;time_base&quot;: &quot;1/1000&quot;,\r\n            &quot;start&quot;: 0,\r\n            &quot;start_time&quot;: &quot;0.000000&quot;,\r\n            &quot;end&quot;: 5590,\r\n            &quot;end_time&quot;: &quot;5.590000&quot;,\r\n            &quot;tags&quot;: {\r\n                &quot;title&quot;: &quot;Video&quot;\r\n            }\r\n        },\r\n        {\r\n            &quot;id&quot;: 1,\r\n            &quot;time_base&quot;: &quot;1/1000&quot;,\r\n            &quot;start&quot;: 5590,\r\n            &quot;start_time&quot;: &quot;5.590000&quot;,\r\n            &quot;end&quot;: 13994,\r\n            &quot;end_time&quot;: &quot;13.994000&quot;,\r\n            &quot;tags&quot;: {\r\n                &quot;title&quot;: &quot;Advertisement&quot;\r\n            }\r\n        },\r\n        {\r\n            &quot;id&quot;: 2,\r\n            &quot;time_base&quot;: &quot;1/1000&quot;,\r\n            &quot;start&quot;: 13994,\r\n            &quot;start_time&quot;: &quot;13.994000&quot;,\r\n            &quot;end&quot;: 163964,\r\n            &quot;end_time&quot;: &quot;163.964000&quot;,\r\n            &quot;tags&quot;: {\r\n                &quot;title&quot;: &quot;Video&quot;\r\n            }\r\n        },\r\n        {\r\n            &quot;id&quot;: 3,\r\n            &quot;time_base&quot;: &quot;1/1000&quot;,\r\n            &quot;start&quot;: 163964,\r\n            &quot;start_time&quot;: &quot;163.964000&quot;,\r\n            &quot;end&quot;: 195940,\r\n            &quot;end_time&quot;: &quot;195.940000&quot;,\r\n            &quot;tags&quot;: {\r\n                &quot;title&quot;: &quot;Advertisement&quot;\r\n            }\r\n        },\r\n        {\r\n            &quot;id&quot;: 4,\r\n            &quot;time_base&quot;: &quot;1/1000&quot;,\r\n            &quot;start&quot;: 195940,\r\n            &quot;start_time&quot;: &quot;195.940000&quot;,\r\n            &quot;end&quot;: 547849,\r\n            &quot;end_time&quot;: &quot;547.849000&quot;,\r\n            &quot;tags&quot;: {\r\n                &quot;title&quot;: &quot;Video&quot;\r\n            }\r\n        },\r\n        {\r\n            &quot;id&quot;: 5,\r\n            &quot;time_base&quot;: &quot;1/1000&quot;,\r\n            &quot;start&quot;: 547849,\r\n            &quot;start_time&quot;: &quot;547.849000&quot;,\r\n            &quot;end&quot;: 595850,\r\n            &quot;end_time&quot;: &quot;595.850000&quot;,\r\n            &quot;tags&quot;: {\r\n                &quot;title&quot;: &quot;Advertisement&quot;\r\n            }\r\n        },\r\n        {\r\n            &quot;id&quot;: 6,\r\n            &quot;time_base&quot;: &quot;1/1000&quot;,\r\n            &quot;start&quot;: 595850,\r\n            &quot;start_time&quot;: &quot;595.850000&quot;,\r\n            &quot;end&quot;: 1413588,\r\n            &quot;end_time&quot;: &quot;1413.588000&quot;,\r\n            &quot;tags&quot;: {\r\n                &quot;title&quot;: &quot;Video&quot;\r\n            }\r\n        },\r\n        {\r\n            &quot;id&quot;: 7,\r\n            &quot;time_base&quot;: &quot;1/1000&quot;,\r\n            &quot;start&quot;: 1413588,\r\n            &quot;start_time&quot;: &quot;1413.588000&quot;,\r\n            &quot;end&quot;: 1477569,\r\n            &quot;end_time&quot;: &quot;1477.569000&quot;,\r\n            &quot;tags&quot;: {\r\n                &quot;title&quot;: &quot;Advertisement&quot;\r\n            }\r\n        },\r\n        {\r\n            &quot;id&quot;: 8,\r\n            &quot;time_base&quot;: &quot;1/1000&quot;,\r\n            &quot;start&quot;: 1477569,\r\n            &quot;start_time&quot;: &quot;1477.569000&quot;,\r\n            &quot;end&quot;: 1529696,\r\n            &quot;end_time&quot;: &quot;1529.696000&quot;,\r\n            &quot;tags&quot;: {\r\n                &quot;title&quot;: &quot;Video&quot;\r\n            }\r\n        }\r\n    ]\r\n}\r\n```\r\nI also tried using the start_time so I didn&#39;t have to do extra calculations but jq didn&#39;t like that either.\r\n\r\nmkvmerge doesn&#39;t even try to run when I have it in here and I still need to cut 7 seconds off the end and 12 seconds off the front of it once it is all one file again.\r\n\r\nAny help would be appreciated, I know it&#39;s a lot but I seem to have hit a roadblock or just sleep deprived at this point.\r\n\r\n**UPDATE**\r\n\r\nThis works amazing I just need to figure out how to use files with spaces and I&#39;m all set. I guess I could run a batch before hand replacing all spaces with underscores. That would probably work but I would like to not change filenames if I can help it.\r\n\r\n```\r\n@echo off\r\n\r\nfor %%i in (*.mp4) do (\r\nFOR /F &quot;delims=&quot; %%A IN (&#39;ffprobe -v quiet -print_format json -show_chapters -loglevel error &quot;%%i&quot; ^| xidel - -se &quot;$json/(chapters)()[id!=0 and tags/title=&#39;Video&#39;]/concat(&#39;ffmpeg -ss &#39;,start div 1000,&#39; -i %%i -to &#39;,((end - start) div 1000),&#39; -c copy -avoid_negative_ts make_zero %%~ni-&#39;,position(),&#39;.mp4&#39;)&quot;&#39;) DO %%A\r\nFOR /F &quot;delims=&quot; %%A IN (&#39;xidel -s --xquery &quot;concat(&#39;mkvmerge -o &amp;quot;%%~ni-FINAL.mkv&amp;quot; &amp;quot;&#39;,join(file:list(.,false(),&#39;%%~ni-*.mp4&#39;),&#39;&amp;quot; + &amp;quot;&#39;),&#39;&amp;quot;&#39;)&quot;&#39;) DO %%A\r\n)\r\n```",
        "link": "https://stackoverflow.com/questions/64192235/is-there-a-way-to-batch-split-a-file-by-chapter-with-ffmpeg-and-then-reassemble",
        "title": "Is there a way to batch split a file by chapter with ffmpeg and then reassemble with mkvmerge in windows?"
    },
    {
        "tags": [
            "json",
            "comparison",
            "diff",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1686757636,
                "last_edit_date": 1686757636,
                "creation_date": 1601835807,
                "answer_id": 64198329,
                "question_id": 64198097,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "After posting the question, and re-checking the following `jq` command, I released that I am not keeping the combined original and template files in a variable, so the original, unmodified file is assigned to the var ``$x``.\r\n\r\n```\r\njq -n \\\r\n--argfile original original.json \\\r\n--argfile download downloaded.json \\\r\n--argfile template template.json \\\r\n&#39;$original |$original +=$template | \r\n($original | to_entries) as $x | \r\n($download | to_entries) as $y | \r\n$y - $x | from_entries\r\n```\r\n\r\nInstead, the correct `jq` command which produces the result I wanted is the following:\r\n\r\n```\r\njq -n \\\r\n--argfile original original.json \\\r\n--argfile download downloaded.json \\\r\n--argfile template template.json \\\r\n&#39;$original |($original +=$template | to_entries) as $x |\r\n($download | to_entries) as $y | \r\n($y - $x | from_entries) as $new |\r\n($x - $y | from_entries) as $old |\r\n[{&quot;Original&quot;:$old,&quot;Updated&quot;: $new}]&#39;\r\n```\r\n\r\nwhich produces the right output:\r\n\r\n```\r\n[\r\n  {\r\n    &quot;Original&quot;: {\r\n      &quot;davisDataUnitsEnabled&quot;: false,\r\n      &quot;expirationTime&quot;: 1652572799000,\r\n      &quot;hostUnitsQuota&quot;: 2147483647,\r\n      &quot;isRumEnabled&quot;: false\r\n    },\r\n    &quot;Updated&quot;: {\r\n      &quot;davisDataUnitsEnabled&quot;: true,\r\n      &quot;expirationTime&quot;: 0,\r\n      &quot;hostUnitsQuota&quot;: -1,\r\n      &quot;isRumEnabled&quot;: true\r\n    }\r\n  }\r\n]\r\n```",
                "title": "jq - create a new object from the diff in key values of two JSON files"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1686757636,
        "creation_date": 1601834509,
        "last_edit_date": 1601892936,
        "question_id": 64198097,
        "body_markdown": "How do a create a `JSON` object which shows the difference in values of each key if such exist from two different `JSON` files?\r\n\r\nThis will be a long post, but mainly due to the `JSON` files I am using. Please bear with me.\r\n\r\nI have a source file - **original.json**\r\n```\r\n{\r\n  &quot;billLogAnalyticsAsDavisDataUnits&quot;: false,\r\n  &quot;billingProvider&quot;: &quot;INTERNAL&quot;,\r\n  &quot;blockUIDate&quot;: 1652572799000,\r\n  &quot;chatEnabled&quot;: false,\r\n  &quot;customMetricsLimit&quot;: 9223372036854776000,\r\n  &quot;customMetricsOverageLimit&quot;: 9223372036854776000,\r\n  &quot;davisDataUnitsAnnualLimit&quot;: -1,\r\n  &quot;davisDataUnitsEnabled&quot;: false,\r\n  &quot;davisDataUnitsMigrated&quot;: false,\r\n  &quot;davisDataUnitsMonthlyLimit&quot;: -1,\r\n  &quot;demUnitsAnnualQuota&quot;: 0,\r\n  &quot;demUnitsQuota&quot;: 0,\r\n  &quot;expirationCounterEnabled&quot;: true,\r\n  &quot;expirationTime&quot;: 1652572799000,\r\n  &quot;externalApiQuota&quot;: 2147483647,\r\n  &quot;hostUnitsCapping&quot;: {\r\n    &quot;fullstackHostLimit&quot;: 0,\r\n    &quot;hasContainersHostLimit&quot;: 0,\r\n    &quot;hostUnitsCappingEnabled&quot;: false,\r\n    &quot;infrastructureOnlyHostLimit&quot;: 0\r\n  },\r\n  &quot;hostUnitsQuota&quot;: 2147483647,\r\n  &quot;ibmSystemZCICSIMSMonitoring&quot;: false,\r\n  &quot;infrastructureSupportedTechnologies&quot;: {\r\n    &quot;infrastructureOnlySupport&quot;: true,\r\n    &quot;logAgent&quot;: true,\r\n    &quot;maxInfrastructureOnlyAgents&quot;: 9223372036854776000,\r\n    &quot;networkAgent&quot;: true,\r\n    &quot;pluginAgent&quot;: true\r\n  },\r\n  &quot;iotEntityQuota&quot;: 20,\r\n  &quot;iotTsQuota&quot;: 10,\r\n  &quot;isConsumption&quot;: false,\r\n  &quot;isCreditExhausted&quot;: false,\r\n  &quot;isRumEnabled&quot;: false,\r\n  &quot;licenseType&quot;: &quot;PAYING&quot;,\r\n  &quot;logAnalyticsIngressQuota&quot;: 9223372036854776000,\r\n  &quot;logAnalyticsIngressQuotaAnnually&quot;: 9223372036854776000,\r\n  &quot;logAnalyticsStorageEnabled&quot;: false,\r\n  &quot;logAnalyticsStorageQuota&quot;: 0,\r\n  &quot;maxActionsPerMinute&quot;: 3500,\r\n  &quot;maxAgents&quot;: 2147483647,\r\n  &quot;maxHostUnitsQuota&quot;: -1,\r\n  &quot;maxPaasAgents&quot;: 2147483647,\r\n  &quot;maxWebChecks&quot;: 9223372036854776000,\r\n  &quot;maxWebChecksAnnual&quot;: 9223372036854776000,\r\n  &quot;overageCustomMetrics&quot;: true,\r\n  &quot;overageEnabled&quot;: false,\r\n  &quot;replayStorageDomQuotaInMb&quot;: 10000,\r\n  &quot;replayStorageDomRetention&quot;: 86400000,\r\n  &quot;retentionCode&quot;: 864000000,\r\n  &quot;retentionRum&quot;: 864000000,\r\n  &quot;retentionService&quot;: 1209600000,\r\n  &quot;retentionWebcheck&quot;: 864000000,\r\n  &quot;rumAdditionalUserPropertiesEnabled&quot;: true,\r\n  &quot;rumAdditionalUserPropertiesLowerLimit&quot;: 20,\r\n  &quot;sessionReplayEnabled&quot;: false,\r\n  &quot;sessionStorageQuota&quot;: 2147483647,\r\n  &quot;suspensionType&quot;: &quot;NONE&quot;,\r\n  &quot;symbolicationFileStorageQuota&quot;: 1024,\r\n  &quot;syntheticEnabled&quot;: false,\r\n  &quot;useHostUnitWeighting&quot;: false,\r\n  &quot;visitsAnnualQuota&quot;: -1,\r\n  &quot;visitsQuota&quot;: -1\r\n}\r\n```\r\n\r\nI need to replace a number of keys having new values which are stored in the **template.json** file\r\n```\r\n{\r\n    &quot;billLogAnalyticsAsDavisDataUnits&quot;: false,\r\n    &quot;billingProvider&quot;: &quot;INTERNAL&quot;,\r\n    &quot;blockUIDate&quot;: 1652572799000,\r\n    &quot;chatEnabled&quot;: false,\r\n    &quot;demUnitsAnnualQuota&quot;: -1,\r\n    &quot;demUnitsQuota&quot;: -1,\r\n    &quot;isRumEnabled&quot;: false,\r\n    &quot;licenseType&quot;: &quot;PAYING&quot;,\r\n    &quot;logAnalyticsIngressQuota&quot;: -1,\r\n    &quot;logAnalyticsIngressQuotaAnnually&quot;: -1,\r\n    &quot;logAnalyticsStorageEnabled&quot;: false,\r\n    &quot;logAnalyticsStorageQuota&quot;: 0,\r\n    &quot;overageCustomMetrics&quot;: true,\r\n    &quot;overageEnabled&quot;: false,\r\n    &quot;replayStorageDomQuotaInMb&quot;: 10000,\r\n    &quot;replayStorageDomRetention&quot;: 86400000,\r\n    &quot;retentionCode&quot;: 864000000,\r\n    &quot;retentionRum&quot;: 864000000,\r\n    &quot;retentionService&quot;: 1209600000,\r\n    &quot;retentionWebcheck&quot;: 864000000,\r\n    &quot;rumAdditionalUserPropertiesEnabled&quot;: true,\r\n    &quot;rumAdditionalUserPropertiesLowerLimit&quot;: 20,\r\n    &quot;sessionReplayEnabled&quot;: false,\r\n    &quot;sessionStorageQuota&quot;: 102400,\r\n    &quot;suspensionType&quot;: &quot;NONE&quot;,\r\n    &quot;symbolicationFileStorageQuota&quot;: 1024,\r\n    &quot;syntheticEnabled&quot;: true,\r\n    &quot;useHostUnitWeighting&quot;: false,\r\n    &quot;visitsAnnualQuota&quot;: 0,\r\n    &quot;visitsQuota&quot;: -1\r\n}\r\n``` \r\nI am using jq&#39;s following call\r\n\r\n```\r\njq -n --argfile original.json --argfile template template.json &#39;$original |$original +=$template&#39; &gt;updated.json\r\n```\r\nto get the new **updated.json** file with updated values and afterward to submit it to the API server. \r\n\r\nAPI server after processing issues a new file with exactly the same structure. However, some key values might change. Here is the downloaded file from the API server - **downloaded.json**\r\n\r\n```\r\n{\r\n  &quot;billLogAnalyticsAsDavisDataUnits&quot;: false,\r\n  &quot;billingProvider&quot;: &quot;INTERNAL&quot;,\r\n  &quot;blockUIDate&quot;: 1652572799000,\r\n  &quot;chatEnabled&quot;: false,\r\n  &quot;customMetricsLimit&quot;: 9223372036854776000,\r\n  &quot;customMetricsOverageLimit&quot;: 9223372036854776000,\r\n  &quot;davisDataUnitsAnnualLimit&quot;: -1,\r\n  &quot;davisDataUnitsEnabled&quot;: true,\r\n  &quot;davisDataUnitsMigrated&quot;: false,\r\n  &quot;davisDataUnitsMonthlyLimit&quot;: -1,\r\n  &quot;demUnitsAnnualQuota&quot;: -1,\r\n  &quot;demUnitsQuota&quot;: -1,\r\n  &quot;expirationCounterEnabled&quot;: true,\r\n  &quot;expirationTime&quot;: 0,\r\n  &quot;externalApiQuota&quot;: 2147483647,\r\n  &quot;hostUnitsCapping&quot;: {\r\n    &quot;fullstackHostLimit&quot;: 0,\r\n    &quot;hasContainersHostLimit&quot;: 0,\r\n    &quot;hostUnitsCappingEnabled&quot;: false,\r\n    &quot;infrastructureOnlyHostLimit&quot;: 0\r\n  },\r\n  &quot;hostUnitsQuota&quot;: -1,\r\n  &quot;ibmSystemZCICSIMSMonitoring&quot;: false,\r\n  &quot;infrastructureSupportedTechnologies&quot;: {\r\n    &quot;infrastructureOnlySupport&quot;: true,\r\n    &quot;logAgent&quot;: true,\r\n    &quot;maxInfrastructureOnlyAgents&quot;: 9223372036854776000,\r\n    &quot;networkAgent&quot;: true,\r\n    &quot;pluginAgent&quot;: true\r\n  },\r\n  &quot;iotEntityQuota&quot;: 20,\r\n  &quot;iotTsQuota&quot;: 10,\r\n  &quot;isConsumption&quot;: false,\r\n  &quot;isCreditExhausted&quot;: false,\r\n  &quot;isRumEnabled&quot;: true,\r\n  &quot;licenseType&quot;: &quot;PAYING&quot;,\r\n  &quot;logAnalyticsIngressQuota&quot;: -1,\r\n  &quot;logAnalyticsIngressQuotaAnnually&quot;: -1,\r\n  &quot;logAnalyticsStorageEnabled&quot;: false,\r\n  &quot;logAnalyticsStorageQuota&quot;: 0,\r\n  &quot;maxActionsPerMinute&quot;: 3500,\r\n  &quot;maxAgents&quot;: 2147483647,\r\n  &quot;maxHostUnitsQuota&quot;: -1,\r\n  &quot;maxPaasAgents&quot;: 2147483647,\r\n  &quot;maxWebChecks&quot;: 9223372036854776000,\r\n  &quot;maxWebChecksAnnual&quot;: 9223372036854776000,\r\n  &quot;overageCustomMetrics&quot;: true,\r\n  &quot;overageEnabled&quot;: false,\r\n  &quot;replayStorageDomQuotaInMb&quot;: 10000,\r\n  &quot;replayStorageDomRetention&quot;: 86400000,\r\n  &quot;retentionCode&quot;: 864000000,\r\n  &quot;retentionRum&quot;: 864000000,\r\n  &quot;retentionService&quot;: 1209600000,\r\n  &quot;retentionWebcheck&quot;: 864000000,\r\n  &quot;rumAdditionalUserPropertiesEnabled&quot;: true,\r\n  &quot;rumAdditionalUserPropertiesLowerLimit&quot;: 20,\r\n  &quot;sessionReplayEnabled&quot;: false,\r\n  &quot;sessionStorageQuota&quot;: 102400,\r\n  &quot;suspensionType&quot;: &quot;NONE&quot;,\r\n  &quot;symbolicationFileStorageQuota&quot;: 1024,\r\n  &quot;syntheticEnabled&quot;: true,\r\n  &quot;useHostUnitWeighting&quot;: false,\r\n  &quot;visitsAnnualQuota&quot;: 0,\r\n  &quot;visitsQuota&quot;: -1\r\n}\r\n\r\n```\r\n\r\nHere is my task - I need to find the difference between the **updated.json** and **downloaded.json**\r\n\r\nI am using diff\r\n```\r\ndiff &lt;(jq -S . update.json) &lt;(jq -S . downloaded.json)\r\n```\r\n\r\nIt produces the following result\r\n```\r\n&lt;   &quot;davisDataUnitsEnabled&quot;: false,\r\n---\r\n&gt;   &quot;davisDataUnitsEnabled&quot;: true,\r\n15c15\r\n&lt;   &quot;expirationTime&quot;: 1652572799000,\r\n---\r\n&gt;   &quot;expirationTime&quot;: 0,\r\n23c23\r\n&lt;   &quot;hostUnitsQuota&quot;: 2147483647,\r\n---\r\n&gt;   &quot;hostUnitsQuota&quot;: -1,\r\n36c36\r\n&lt;   &quot;isRumEnabled&quot;: false,\r\n---\r\n&gt;   &quot;isRumEnabled&quot;: true,\r\n```\r\n\r\nWhat I want instead - to create a new object with the original (from updated.json) and new (from downloaded.json) files, so it should look the following way:\r\n```\r\n    &quot;Original&quot;: {\r\n        &quot;davisDataUnitsEnabled&quot;: false,\r\n        &quot;expirationTime&quot;: 1652572799000,\r\n        &quot;hostUnitsQuota&quot;: 2147483647,\r\n        &quot;isRumEnabled&quot;: false\r\n    },\r\n    &quot;Updated&quot;: {\r\n        &quot;davisDataUnitsEnabled&quot;: true,\r\n        &quot;expirationTime&quot;: 0,\r\n        &quot;hostUnitsQuota&quot;: -1,\r\n        &quot;isRumEnabled&quot;: true\r\n    }\r\n}\r\n```\r\nI tried to use ``to_entries`` and ``from_entries`` see the difference between the updated and downloaded with the following jq command combining all together:\r\n```\r\njq -n \\\r\n--argfile original original.json \\\r\n--argfile download downloaded.json \\\r\n--argfile template template.json \\\r\n&#39;$original |$original +=$template | \r\n($original | to_entries) as $x | \r\n($download | to_entries) as $y | \r\n$y - $x | from_entries&#39;\r\n```\r\nHowever, the output is quite different compared to the diff:\r\n```\r\n{\r\n  &quot;davisDataUnitsEnabled&quot;: true,\r\n  &quot;demUnitsAnnualQuota&quot;: -1,\r\n  &quot;demUnitsQuota&quot;: -1,\r\n  &quot;expirationTime&quot;: 0,\r\n  &quot;hostUnitsQuota&quot;: -1,\r\n  &quot;isRumEnabled&quot;: true,\r\n  &quot;logAnalyticsIngressQuota&quot;: -1,\r\n  &quot;logAnalyticsIngressQuotaAnnually&quot;: -1,\r\n  &quot;sessionStorageQuota&quot;: 102400,\r\n  &quot;syntheticEnabled&quot;: true,\r\n  &quot;visitsAnnualQuota&quot;: 0\r\n}\r\n```\r\n\r\nSeven more keys are listed in the above output, instead of four from diff, and these seven keys have exactly the same values in the `updated.json` and `downloaded.json`\r\n\r\nMy questions - what causes these seven additional keys to appear in the jq output? \r\nCan I get with jq a correct output of keys with differences in values and have the output formatted the way I want?\r\n\r\n--\r\nP.S. After some digging, figured out that ``comm`` is giving me the output I want \r\n```\r\ncomm --nocheck-order -13 &lt;(jq -S . updated.json) &lt;(jq -S . downloaded.json)\r\n```\r\nWhich produces the output:\r\n```\r\n  &quot;davisDataUnitsEnabled&quot;: true,\r\n  &quot;expirationTime&quot;: 0,\r\n  &quot;hostUnitsQuota&quot;: -1,\r\n  &quot;isRumEnabled&quot;: true,\r\n```\r\nNow if I could put that output under the ``&quot;Updated&quot;`` object via `JQ` while ignoring the trailing comma, that probably would be the end result...\r\n\r\n**UPDATE** I figured out what was the problem and wrote the answer below. Leaving the question as is, because someone might encounter the same situation.",
        "link": "https://stackoverflow.com/questions/64198097/jq-create-a-new-object-from-the-diff-in-key-values-of-two-json-files",
        "title": "jq - create a new object from the diff in key values of two JSON files"
    },
    {
        "tags": [
            "arrays",
            "bash",
            "shell",
            "unix",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 10286519,
                    "reputation": 5985,
                    "user_id": 7589636,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa78a73e889b0b4e61a931d9237012c5?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "thanasisp",
                    "link": "https://stackoverflow.com/users/7589636/thanasisp"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1601839475,
                "post_id": 64198823,
                "comment_id": 113523860,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 10286519,
                    "reputation": 5985,
                    "user_id": 7589636,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa78a73e889b0b4e61a931d9237012c5?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "thanasisp",
                    "link": "https://stackoverflow.com/users/7589636/thanasisp"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1601842300,
                "post_id": 64198823,
                "comment_id": 113524618,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 7394686,
                    "reputation": 394,
                    "user_id": 5627026,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/RRVlZ.png?s=256",
                    "display_name": "Hedi Bejaoui",
                    "link": "https://stackoverflow.com/users/5627026/hedi-bejaoui"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1601844478,
                "post_id": 64198823,
                "comment_id": 113525184,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1663529298,
                "creation_date": 1663529298,
                "answer_id": 73765844,
                "question_id": 64198823,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I&#39;m not entirely sure what your question really is, because that syntax should already work. The only thing missing is to actually declare and assign the variable:\r\n\r\n```\r\ni=bird\r\narr1=(`jq &quot;.$i.names&quot; 123.json | sed...`)\r\n```\r\n\r\nOr by defining a variable for jq and using it (same concept):\r\n\r\n```\r\ni=bird\r\narr1=(`jq --arg animal &quot;$i&quot; &#39;.[$animal].names&#39; 123.json | sed...`)\r\n```",
                "title": "shell script to parse a json and storing values as array"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1663529298,
        "creation_date": 1601838814,
        "last_edit_date": 1601840212,
        "question_id": 64198823,
        "body_markdown": "here i am parsing a json file and storing values as array.\r\n```\r\narr1=(`jq &#39;.animal.names&#39;  123.json | sed...`)\r\n``` \r\n***output: fox tiger lion***\r\n\r\nnow i need to parse values dynamically (i = birds or fish)\r\n```\r\neg    arr1=(`jq .$i.names  123.json | sed...`)\r\n```\r\n ```\r\nit should be as \r\n \r\narr1=(`jq &#39;.bird.names&#39;  123.json | sed...`) \r\n or      \r\narr1=(`jq &#39;.fish.names&#39;  123.json | sed...`).\r\n```\r\nSome guidance will be helpful.\r\n\r\n",
        "link": "https://stackoverflow.com/questions/64198823/shell-script-to-parse-a-json-and-storing-values-as-array",
        "title": "shell script to parse a json and storing values as array"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1601876961,
                "creation_date": 1601876961,
                "answer_id": 64203047,
                "question_id": 64202896,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can do it very simply as below\r\n\r\n    jq -n --arg a &quot;xyz&quot; &#39;{ ($a): { &quot;b&quot;: 1 ,&quot;c&quot;: 2 } }&#39;\r\n\r\nor with contents from stdin\r\n\r\n    echo &#39;{ &quot;b&quot;: 1 ,&quot;c&quot;: 2 }&#39; | jq -n --arg a &quot;xyz&quot; &#39;{ ($a): inputs }&#39;\r\n\r\nor without `-n`\r\n\r\n    echo &#39;{ &quot;b&quot;: 1 ,&quot;c&quot;: 2 }&#39; | jq --arg a &quot;xyz&quot; &#39;{ ($a): . }&#39;\r\n\r\nor with both keyname and the object configurable\r\n\r\n    jq -n --arg k &quot;xyz&quot; --argjson v &#39;{ &quot;b&quot;: 1 ,&quot;c&quot;: 2 }&#39; &#39;{ ($k): $v }&#39;",
                "title": "jq - assign to the key name the value from a variable"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1601876961,
        "creation_date": 1601875676,
        "last_edit_date": 1601876422,
        "question_id": 64202896,
        "body_markdown": "I have a `JSON` object `` {&quot;b&quot;:1,&quot;c&quot;:2}`` and want to put this object under the object with the key named ``xyz``. \r\n\r\nHowever, the key name is coming from the shell variable. So in other words, I first need to get the key name, and after that put ``{&quot;b&quot;:1,&quot;c&quot;:2}`` under it so the result looks like following:\r\n```\r\n{\r\n  &quot;xyz&quot;: {\r\n    &quot;b&quot;: 1,\r\n    &quot;c&quot;: 2\r\n  }\r\n}\r\n```\r\nI came up with the following statement. It does the job, but want to know if there are more efficient ways to do it by eliminating temporary ``new`` entry.\r\n```\r\njq -n --arg a &quot;xyz&quot;  &#39;{&quot;b&quot;:1,&quot;c&quot;:2} as $new | {$new} | with_entries(if .key == &quot;new&quot; then .key = $a else . end)&#39;\r\n```\r\n",
        "link": "https://stackoverflow.com/questions/64202896/jq-assign-to-the-key-name-the-value-from-a-variable",
        "title": "jq - assign to the key name the value from a variable"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 429522,
                    "reputation": 2070,
                    "user_id": 812461,
                    "user_type": "registered",
                    "accept_rate": 97,
                    "profile_image": "https://www.gravatar.com/avatar/819a82c94b061b6a30dd2a24203b3a78?s=256&d=identicon&r=PG",
                    "display_name": "yesh",
                    "link": "https://stackoverflow.com/users/812461/yesh"
                },
                "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": 1601881501,
                "post_id": 64203739,
                "comment_id": 113532182,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1601883021,
                "last_edit_date": 1601883021,
                "creation_date": 1601882551,
                "answer_id": 64204068,
                "question_id": 64203739,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "One safe way would be to emit the JSON records with a NULL byte padding and then later read it back in a shell loop, delimiting on that byte\r\n\r\n    while IFS= read -r -d &#39;&#39; key &amp;&amp; IFS= read -r -d &#39;&#39; value; do\r\n        printf &#39;%s\\n&#39; &quot;$value&quot; &gt; &quot;$key&quot;\r\n    done &lt; &lt;(jq -j &#39;.data | to_entries[] | (.key, &quot;\\u0000&quot;, .value, &quot;\\u0000&quot;)&#39; json)\r\n\r\nSince the NULL byte can&#39;t be part of a &quot;valid&quot; byte in any of the input records, it is used as the delimit character. The `jq` expression \r\n\r\n    (.key, &quot;\\u0000&quot;, .value, &quot;\\u0000&quot;)\r\n\r\nappends the NULL byte between the key and the value field, which is read with a while loop , two reads at a time to store the key name and the value fields in the respective variables.\r\n\r\nNote that `&lt;(..)` is a bash/ksh93/zsh process substitution technique, which is not POSIX compliant and might not work in pure bourne shells.",
                "title": "Loop over JSON and create files with key as filename and value as file content"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1601883021,
        "creation_date": 1601881043,
        "last_edit_date": 1601881681,
        "question_id": 64203739,
        "body_markdown": "I have a sample JSON like\r\n\r\n      &quot;request_id&quot;: &quot;016-ae81e5737add&quot;,\r\n      &quot;renewable&quot;: false,\r\n      &quot;data&quot;: {\r\n          &quot;client_decrypted.key&quot;: &quot;-----BEGIN KEY-----sdjijhgisdTRjkRD05\\n-----END KEY-----&quot;,\r\n          &quot;passphrase&quot;: &quot;password&quot;\r\n        }\r\n\r\nIn my bash script, I am reading the JSON specifically the contents of `data` key. I would like to create files with the filename as `key` (e.g: files like `client_decrypted.key` &amp; `passphrase`) with the contents of the files as the `value` of the corresponding key.\r\n\r\nI was able to use jq to read the key &amp; value pair\r\n```\r\nfor pair in $( jq -r &quot;.data | to_entries|map(\\&quot;\\(.key)=\\(.value|tostring)\\&quot;)|.[]&quot;); do\r\n    echo $${pair} # OUTPUT=passphrase=password\r\ndone\r\n```\r\n\r\nI guess I can use IFS to split each pair on `=`. Is there a better way of doing this?",
        "link": "https://stackoverflow.com/questions/64203739/loop-over-json-and-create-files-with-key-as-filename-and-value-as-file-content",
        "title": "Loop over JSON and create files with key as filename and value as file content"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 213379,
                    "reputation": 9974,
                    "user_id": 466738,
                    "user_type": "registered",
                    "accept_rate": 94,
                    "profile_image": "https://www.gravatar.com/avatar/cd7d5ad7f0cd49262fcb6136f8db7760?s=256&d=identicon&r=PG",
                    "display_name": "Adam Michalik",
                    "link": "https://stackoverflow.com/users/466738/adam-michalik"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1670404182,
                "post_id": 64206982,
                "comment_id": 131866589,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1601895137,
                "last_edit_date": 1601895137,
                "creation_date": 1601895066,
                "answer_id": 64207176,
                "question_id": 64206982,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; There is any way to get parse this json with jq within a single command?\r\n\r\nIt depends on how you define a single command. It can be done using a pipeline that contains two invocations of `jq`:\r\n\r\n```bash\r\nINPUT=&#39;{\r\n  &quot;key&quot;: &quot;{\\&quot;first\\&quot;:\\&quot;123\\&quot;,\\&quot;second\\&quot;:\\&quot;456\\&quot;}&quot;\r\n}&#39;\r\n\r\necho &quot;$INPUT&quot; | jq -r .key | jq .\r\n```\r\n\r\n`jq -r .key` tells `jq` to echo the raw value of `.key`, not its JSON representation (it is a string, normally `jq` outputs it as it is represented in the input JSON).\r\n\r\nThe output is:\r\n\r\n```bash\r\n{\r\n  &quot;first&quot;: &quot;123&quot;,\r\n  &quot;second&quot;: &quot;456&quot;\r\n}\r\n```\r\n\r\nThe second invocation of `jq` (`jq .`) doesn&#39;t do anything to the data; it just format it nicely (as depicted above) and coloured (it does not colour the output if it does not go to the terminal).\r\n\r\nHowever, it shows that its input is a JSON (the raw value of `.key`) that can be processed further. You can, for example, use `jq .first` instead to get `&quot;123&quot;` (the string encoded as JSON) or `jq -r .first` to get `123` (the raw value).",
                "title": "How to parse with jq a json encoded as string inside a json"
            },
            {
                "up_vote_count": 15,
                "is_accepted": false,
                "score": 15,
                "last_activity_date": 1601895275,
                "creation_date": 1601895275,
                "answer_id": 64207231,
                "question_id": 64206982,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use `fromjson`, e.g.\r\n\r\n    jq &#39;.key|fromjson|.first&#39;\r\n\r\nAs pointed out in a comment, this can be abbreviated by omitting the last pipe character.\r\n\r\nIn general, it’s better to avoid calling jq twice when one call is sufficient.",
                "title": "How to parse with jq a json encoded as string inside a json"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 5,
        "last_activity_date": 1601895275,
        "creation_date": 1601894268,
        "question_id": 64206982,
        "body_markdown": "There is any way to get parse this json with jq within a single command? I would like to do something like this: `jq .key.first`. But yea, taking into consideration that the `key` is a string and need to be first parsed to json.\r\n\r\n```json\r\n{\r\n  &quot;key&quot;: &quot;{\\&quot;first\\&quot;:\\&quot;123\\&quot;,\\&quot;second\\&quot;:\\&quot;456\\&quot;}&quot;\r\n}\r\n```",
        "link": "https://stackoverflow.com/questions/64206982/how-to-parse-with-jq-a-json-encoded-as-string-inside-a-json",
        "title": "How to parse with jq a json encoded as string inside a json"
    },
    {
        "tags": [
            "arrays",
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1601909134,
                "post_id": 64210344,
                "comment_id": 113545062,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 19215910,
                    "reputation": 143,
                    "user_id": 14040656,
                    "user_type": "registered",
                    "profile_image": "https://lh5.googleusercontent.com/-sgJ38yJyYGs/AAAAAAAAAAI/AAAAAAAAAAA/AMZuucmOQ3k9Mc9vEs4oTdUX5MxgbcidUw/s256-rj/photo.jpg",
                    "display_name": "jfrank",
                    "link": "https://stackoverflow.com/users/14040656/jfrank"
                },
                "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": 1601998384,
                "post_id": 64210344,
                "comment_id": 113577384,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1601908206,
                "creation_date": 1601908206,
                "answer_id": 64210669,
                "question_id": 64210344,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I used range() to iterate over the elements of the arrays:\r\n\r\n    jq &#39;[range(.en|length) as $i | {en: .en[$i], fr: .fr[$i]}]&#39; file.json\r\n",
                "title": "Combine two JSON arrays in a single file using jq"
            },
            {
                "up_vote_count": 6,
                "is_accepted": true,
                "score": 6,
                "last_activity_date": 1601909093,
                "creation_date": 1601909093,
                "answer_id": 64210908,
                "question_id": 64210344,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could also use `transpose` to &quot;zip&quot; the arrays together:\r\n\r\n    [[.en,.fr] | transpose[] | {en:.[0], fr:.[1]} ]",
                "title": "Combine two JSON arrays in a single file using jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1602054474,
                "creation_date": 1602054474,
                "answer_id": 64238936,
                "question_id": 64210344,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a solution that will work with arbitrarily many keys and that does not require knowledge of the key names beforehand:\r\n```\r\ndef objectify($keys):\r\n  [$keys, .] | transpose | map({(.[0]): .[1]}) | add;\r\n\r\nkeys_unsorted as $keys\r\n| [[.[]] | transpose[] | objectify($keys)]\r\n```",
                "title": "Combine two JSON arrays in a single file using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 2,
        "last_activity_date": 1602054474,
        "creation_date": 1601907067,
        "last_edit_date": 1601950314,
        "question_id": 64210344,
        "body_markdown": "I have a JSON file with two arrays. I&#39;d like to combine the arrays into a single array of objects, each of which contains an element from each of the original arrays.\r\n\r\nJSON input looks like this:\r\n\r\n```\r\n{\r\n  &quot;en&quot;: [\r\n    &quot;E1&quot;,\r\n    &quot;E2&quot;,\r\n    &quot;E3&quot;,\r\n    &quot;E4&quot;\r\n  ],\r\n  &quot;fr&quot;: [\r\n    &quot;F1&quot;,\r\n    &quot;F2&quot;,\r\n    &quot;F3&quot;,\r\n    &quot;F4&quot;\r\n  ]\r\n}\r\n```\r\n\r\nDesired output:\r\n```\r\n[\r\n  { &quot;en&quot;:&quot;E1&quot;, &quot;fr&quot;:&quot;F1&quot;},\r\n  { &quot;en&quot;:&quot;E2&quot;, &quot;fr&quot;:&quot;F2&quot;},\r\n  { &quot;en&quot;:&quot;E3&quot;, &quot;fr&quot;:&quot;F3&quot;},\r\n  { &quot;en&quot;:&quot;E4&quot;, &quot;fr&quot;:&quot;F4&quot;}\r\n]\r\n```\r\n\r\nNo matter what I try I can&#39;t tame jq into delivering this. The closest I have come is using the filter `. | {en:.en[],fr:.fr[]}` which gives me every possible pairing of the arrays as follows:\r\n\r\n```\r\n{\r\n  &quot;en&quot;: &quot;E1&quot;,\r\n  &quot;fr&quot;: &quot;F1&quot;\r\n}\r\n{\r\n  &quot;en&quot;: &quot;E1&quot;,\r\n  &quot;fr&quot;: &quot;F2&quot;\r\n}\r\n{\r\n  &quot;en&quot;: &quot;E1&quot;,\r\n  &quot;fr&quot;: &quot;F3&quot;\r\n}\r\n{\r\n  &quot;en&quot;: &quot;E1&quot;,\r\n  &quot;fr&quot;: &quot;F4&quot;\r\n}\r\n{\r\n  &quot;en&quot;: &quot;E2&quot;,\r\n  &quot;fr&quot;: &quot;F1&quot;\r\n}\r\n{\r\n  &quot;en&quot;: &quot;E2&quot;,\r\n  &quot;fr&quot;: &quot;F2&quot;\r\n}\r\n{\r\n  &quot;en&quot;: &quot;E2&quot;,\r\n  &quot;fr&quot;: &quot;F3&quot;\r\n}\r\n{\r\n  &quot;en&quot;: &quot;E2&quot;,\r\n  &quot;fr&quot;: &quot;F4&quot;\r\n}\r\n{\r\n  &quot;en&quot;: &quot;E3&quot;,\r\n  &quot;fr&quot;: &quot;F1&quot;\r\n}\r\n{\r\n  &quot;en&quot;: &quot;E3&quot;,\r\n  &quot;fr&quot;: &quot;F2&quot;\r\n}\r\n{\r\n  &quot;en&quot;: &quot;E3&quot;,\r\n  &quot;fr&quot;: &quot;F3&quot;\r\n}\r\n{\r\n  &quot;en&quot;: &quot;E3&quot;,\r\n  &quot;fr&quot;: &quot;F4&quot;\r\n}\r\n{\r\n  &quot;en&quot;: &quot;E4&quot;,\r\n  &quot;fr&quot;: &quot;F1&quot;\r\n}\r\n{\r\n  &quot;en&quot;: &quot;E4&quot;,\r\n  &quot;fr&quot;: &quot;F2&quot;\r\n}\r\n{\r\n  &quot;en&quot;: &quot;E4&quot;,\r\n  &quot;fr&quot;: &quot;F3&quot;\r\n}\r\n{\r\n  &quot;en&quot;: &quot;E4&quot;,\r\n  &quot;fr&quot;: &quot;F4&quot;\r\n}\r\n```\r\n\r\nHow can I get it to pair the first elements of each array, the second elements, etc.",
        "link": "https://stackoverflow.com/questions/64210344/combine-two-json-arrays-in-a-single-file-using-jq",
        "title": "Combine two JSON arrays in a single 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": 1601914111,
                "post_id": 64212113,
                "comment_id": 113547501,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1020072,
                    "reputation": 243994,
                    "user_id": 1030675,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/957956ce51706d03f19a4dc85a767bb1?s=256&d=identicon&r=PG",
                    "display_name": "choroba",
                    "link": "https://stackoverflow.com/users/1030675/choroba"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1601914155,
                "post_id": 64212113,
                "comment_id": 113547517,
                "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": 1601915467,
                "post_id": 64212113,
                "comment_id": 113548083,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1601915125,
                "creation_date": 1601915125,
                "answer_id": 64212562,
                "question_id": 64212113,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Do you mean something like this?\r\n\r\nI used `del` to remove an entry instead of `|=` with `map`.\r\n\r\n    #!/bin/bash\r\n    env=$1\r\n    json=$2\r\n    \r\n    case &quot;$env&quot; in\r\n        (dev)  indices=&#39;index(&quot;http://company.com&quot;)&#39; ;;\r\n        (prod) indices=&#39;index(&quot;http://company.com&quot;),index(&quot;http://localhost&quot;)&#39; ;;\r\n        (*) echo Invalid env &quot;$env&quot; &gt;&amp;2 ;;\r\n    esac\r\n    \r\n    command=&quot;del(.allowed_origin[.allowed_origin|$indices])&quot;\r\n    echo &quot;$command&quot;\r\n    jq &quot;$command&quot; &quot;$json&quot;\r\n\r\n",
                "title": "Multiple operations with an array"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1601915125,
        "creation_date": 1601913391,
        "question_id": 64212113,
        "body_markdown": "I&#39;m using an application that depends on a JSON config file and unfortunately, there is no way to configure it for different environments. The configuration file looks like this:\r\n```\r\n{\r\n  &quot;allowed_origin&quot;: [\r\n    &quot;http://localhost&quot;,\r\n    &quot;http://companydev.com&quot;,\r\n    &quot;http://company.com&quot;\r\n  &quot;\r\n}\r\n```\r\n\r\nFor `dev` we would like to have this:\r\n```\r\n{\r\n  &quot;allowed_origin&quot;: [\r\n    &quot;http://localhost&quot;,\r\n    &quot;http://companydev.com&quot;\r\n  &quot;\r\n}\r\n```\r\n\r\nFor `prod`:\r\n```\r\n{\r\n  &quot;allowed_origin&quot;: [\r\n    &quot;http://company.com&quot;\r\n  &quot;\r\n}\r\n```\r\n\r\nI don&#39;t know if it&#39;s possible to process the JSON in a single jq pass. To delete the `localhost` this works `. allowed_origin |= map(select(index(&quot;http://localhost&quot;)|not))`.\r\nBut how to do the other one? I tried somethings but I did not have any success.",
        "link": "https://stackoverflow.com/questions/64212113/multiple-operations-with-an-array",
        "title": "Multiple operations with an array"
    },
    {
        "tags": [
            "json",
            "shell",
            "select",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1602356913,
                "last_edit_date": 1602356913,
                "creation_date": 1602304384,
                "answer_id": 64290001,
                "question_id": 64213506,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Your requirement is: If prefix exists in name, update the last array element, else the first one.\r\n\r\nWhen the array has one element, like for `application1`, the last is the first also.\r\n\r\n```bash\r\n#!/bin/bash\r\n\r\napplication=&quot;$1&quot;\r\nname=&quot;$2&quot;\r\njson_file=&quot;file.json&quot;\r\nind=0\r\n\r\n# if name matches &quot;-&quot;, set index to the last array element\r\n[[ &quot;$name&quot; == *&quot;-&quot;* ]] &amp;&amp; ind=-1\r\n\r\njq --arg app &quot;$application&quot; \\\r\n   --arg name &quot;$name&quot; \\\r\n   --argjson ind &quot;$ind&quot; \\\r\n   &#39;.root[$app][$ind].names += [$name]&#39; &quot;$json_file&quot;\r\n```\r\n\r\nI believe above script is self-explanatory enough, `--argjson` used for having an unquoted index, `+=` stands for `|= . +`.\r\n\r\n&lt;hr&gt;\r\n\r\n## Testing\r\n\r\nCommands below produce the expected result.\r\n\r\n```\r\nbash test.sh application1 jr-John\r\nbash test.sh application2 jr-John\r\nbash test.sh application1 Mary\r\nbash test.sh application2 Mary\r\n```",
                "title": "How to conditionally select array index to update based on value"
            },
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1602509427,
                "last_edit_date": 1602509427,
                "creation_date": 1602321024,
                "answer_id": 64291819,
                "question_id": 64213506,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It took me a while to have any confidence that I have understood the requirements, but I believe the following at least captures the essence of what you have in mind.\r\n\r\nTo make the solution easier to understand, we begin with a helper function, the name of which makes its purpose clear enough, at least given the context:\r\n\r\n```\r\ndef updateFirstNamesArrayWithMatchingPrefix($prefix; $value):\r\n  (first( range(0; length) as $i\r\n          | if any(.[$i].names[]; startswith($prefix))\r\n\t        then $i else empty end) // 0) as $i\r\n  | .[$i].names += [$value] ;\r\n\r\n  \r\n.root |=\r\n  if .[$app] | length == 1 \r\n  then .[$app][0].names += [ $name ]\r\n  elif .[$app] | length &gt; 1\r\n  then \r\n    ( $name | split(&quot;-&quot;)) as $components\r\n    | if $components|length==1  # no prefix\r\n      then .[$app][0].names += [ $name  ]\r\n      else ($components[0] + &quot;-&quot; ) as $prefix\r\n      | .[$app] |= updateFirstNamesArrayWithMatchingPrefix($prefix; $name)\r\n      end\r\n  else .\r\n  end\r\n``` \r\n## Testing\r\nThe above passes the four tests originally proposed by\r\n@Inian:\r\n```\r\njq --arg app &quot;application1&quot; --arg name &quot;foo&quot; -f script.jq jsonFile\r\njq --arg app &quot;application2&quot; --arg name &quot;jr-foo&quot; -f script.jq jsonFile\r\njq --arg app &quot;application2&quot; --arg name &quot;sr-foo&quot; -f script.jq jsonFile\r\njq --arg app &quot;application2&quot; --arg name &quot;foo&quot; -f script.jq jsonFile\r\n```\r\n## Herrings?\r\nBased on my understanding of the problem, it seems to me that `walk` may be a bit of a red herring, but if not, I hope you&#39;ll be able to adapt the above to meet your actual requirements.\r\n\r\n",
                "title": "How to conditionally select array index to update based on value"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1602509427,
        "creation_date": 1601919151,
        "last_edit_date": 1602336154,
        "question_id": 64213506,
        "body_markdown": "I have a json file as below, need to append the new name into `.root.application.names`, but if the name passed in has prefix (everything before `-`, in below example it&#39;s `jr`), then find the list with same prefix names already present, and update it, if there is only one names list or if there is no matching list, then update first list.\r\n\r\n\r\nIn the below example, if\r\n\r\n`$application == &#39;application1&#39; and $name == &lt;whatever&gt;; just update first list under application1, as there is only one list under application1, nothing to choose from.`\r\n\r\n` $application == &#39;application2&#39; and if $name has no prefix delimiter &quot;-&quot; or unmatched prefix (say sr-allen); then update the first list under application2.names, because foo has no or unmatched prefix.`\r\n\r\n` $application == &#39;application2&#39; and say $name == jr-allen; then update the second list under application2, because $name has prefix &quot;jr-&quot; and there is a list with items matching this prefix.`\r\n\r\n\r\n\r\n```\r\n{\r\n    &quot;root&quot;: {\r\n        &quot;application1&quot;: [\r\n            {\r\n                &quot;names&quot;: [\r\n                    &quot;john&quot;\r\n                ],\r\n                &quot;project&quot;: &quot;generic&quot;\r\n            }\r\n        ],\r\n        &quot;application2&quot;: [\r\n            {\r\n                &quot;names&quot;: [\r\n                    &quot;peter&quot;,\r\n                    &quot;jack&quot;\r\n                ],\r\n                &quot;project&quot;: &quot;generic&quot;\r\n            },\r\n            {\r\n                &quot;names&quot;: [\r\n                    &quot;jr-sam&quot;,\r\n                    &quot;jr-mike&quot;,\r\n                    &quot;jr-rita&quot;\r\n                ],\r\n                &quot;project&quot;: &quot;junior-project&quot;\r\n            }\r\n         ]\r\n     }\r\n}\r\n```\r\n\r\n\r\nI found how to update the list, not sure how to add these conditions, any help please?\r\n\r\n`jq &#39;.&quot;root&quot;.&quot;application2&quot;[1].names[.&quot;root&quot;.&quot;application2&quot;[1].names| length] |= . + &quot;jr-allen&quot;&#39; foo.json`\r\n\r\n\r\nUpdate: \r\ngood if I can do this with jq/walk, I am still trying as below, but couldn&#39;t get anywhere close.\r\n\r\n```\r\nprefix=$(echo ${name} | cut -d&quot;-&quot; -f1) # this gives the prefix, e.g: &quot;jr&quot;\r\njq -r --arg app &quot;${application}&quot; name &quot;${name}&quot; prefix &quot;${prefix}&quot;&#39;\r\n    def walk(f):\r\n    . as $in\r\n    | if type == &quot;object&quot; then\r\n        reduce keys[] as $key\r\n            ( {}; . + { ($key):  ($in[$key] | walk(f)) } ) | f\r\n    elif type == &quot;array&quot; then map( walk(f) ) | f\r\n    else f\r\n    end;\r\n  walk( if type==&quot;object&quot; and .&quot;$app&quot; and (.names[]|startswith(&quot;$prefix&quot;)) ) then .names[]=&quot;$name&quot; else . end )\r\n&#39; foo.json\r\n```",
        "link": "https://stackoverflow.com/questions/64213506/how-to-conditionally-select-array-index-to-update-based-on-value",
        "title": "How to conditionally select array index to update based on value"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1601931367,
                "creation_date": 1601931367,
                "answer_id": 64216084,
                "question_id": 64215674,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Should waited the requisite 5 minutes. \r\n\r\nFound my answer elsewhere:\r\n\r\n```\r\njq -cr  &#39;.[] | {id: .id, content: .content | sub(&quot;,&quot;; &quot;&quot;), assignee: .assignee.name} \r\n```",
                "title": "jq: find and replace within filter"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1651730943,
                "creation_date": 1651730943,
                "answer_id": 72122658,
                "question_id": 64215674,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Yes you can use `gsub/2`.\r\n\r\nFilter\r\n```\r\n. | gsub(&quot;,&quot;;&quot;&quot;)\r\n```\r\n\r\nInput\r\n```\r\n1235,&quot;some text, sometimes with a comma, perhaps&quot;, &quot;John Doe&quot;\r\n```\r\n\r\nOutput\r\n```\r\n1235&quot;some text sometimes with a comma perhaps&quot; &quot;John Doe&quot;\r\n```\r\n\r\nDemo\r\n\r\nhttps://jqplay.org/s/n5fFtBK7uj",
                "title": "jq: find and replace within filter"
            }
        ],
        "is_answered": false,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1651730943,
        "creation_date": 1601929276,
        "last_edit_date": 1601930211,
        "question_id": 64215674,
        "body_markdown": "I return a few json values from an API feed using this command:\r\n\r\n```\r\ncurl -s -u user:pass -H &#39;my header&#39; https://example.com/data.json | jq -cr  &#39;.[] | {id: .id, content: .content, assignee: .assignee.name}\r\n```\r\n\r\nI&#39;m getting a CSV just as I need it, namely:\r\n```\r\n1235,&quot;some text, sometimes with a comma, perhaps&quot;, &quot;John Doe&quot;\r\n```\r\n\r\nEverything is great, but command in the &quot;content: .content&quot; values are throwing off our processing of the data.\r\n\r\nI&#39;m trying to replace commas within the command, and not even sure what terminology to search for. Ideally I&#39;d use something like this:\r\n\r\n```\r\njq -cr  &#39;.[] | {id: .id, content: *** BEGIN DO SOMETHING .content END DO SOMETHING***, assignee: .assignee.name}\r\n```\r\n\r\n...I just don&#39;t know what that *something* is.\r\n\r\nI&#39;m guessing it&#39;s a gsub, but not sure how to isolate the syntax for .content.\r\n\r\n",
        "link": "https://stackoverflow.com/questions/64215674/jq-find-and-replace-within-filter",
        "title": "jq: find and replace within filter"
    },
    {
        "tags": [
            "json",
            "bash",
            "eval",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1613587,
                    "reputation": 786618,
                    "user_id": 1491895,
                    "user_type": "registered",
                    "accept_rate": 69,
                    "profile_image": "https://www.gravatar.com/avatar/82f9e178a16364bf561d0ed4da09a35d?s=256&d=identicon&r=PG",
                    "display_name": "Barmar",
                    "link": "https://stackoverflow.com/users/1491895/barmar"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1601961654,
                "post_id": 64219781,
                "comment_id": 113560986,
                "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": 1601961785,
                "post_id": 64219781,
                "comment_id": 113561012,
                "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": 1601961787,
                "post_id": 64219781,
                "comment_id": 113561013,
                "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": 1601961833,
                "post_id": 64219781,
                "comment_id": 113561032,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 16868359,
                    "reputation": 1,
                    "user_id": 12197497,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/75c75af74a95be851c598ebc618d5f4b?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "rgarla",
                    "link": "https://stackoverflow.com/users/12197497/rgarla"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1601968701,
                "post_id": 64219781,
                "comment_id": 113563275,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1601964547,
                "creation_date": 1601964547,
                "answer_id": 64220215,
                "question_id": 64219781,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using `eval` here is like shooting yourself in the foot.\r\n\r\nWhy not just pipe the output of your python command to the jq command?\r\n\r\nConsider:\r\n```\r\nfunction mypython {\r\n  cat &lt;&lt;&quot;EOF&quot;\r\n{&quot;A&quot;:&quot;ab3241c&quot;,&quot;B&quot;:&quot;d12e31234f&quot;,&quot;c&quot;:&quot;[g$x&gt;Q)M&amp;.N+v8&quot;}\r\nEOF\r\n}\r\n\r\nexpression=&#39;to_entries[] | .key + &quot;=\\&quot;&quot; + .value + &quot;\\&quot;&quot;&#39;\r\n\r\nmypython | jq -r &quot;$expression&quot;\r\n```\r\n\r\nNote that using `expression` here seems pointless as well.  In general, it would be better either to &quot;inline&quot; it, or put it in a file and use jq&#39;s -f command-line option.\r\n\r\n(Notice also that the first &quot;.&quot; in your `expression` is not needed.)\r\n",
                "title": "Is there a fix for this Expression to get the key value pairs right"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1601965755,
                "last_edit_date": 1601965755,
                "creation_date": 1601965430,
                "answer_id": 64220373,
                "question_id": 64219781,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you really must use `eval`, then consider:\r\n```\r\nfunction mypython {\r\n  cat &lt;&lt;&quot;EOF&quot;\r\n{&quot;A&quot;:&quot;ab3241c&quot;,&quot;B&quot;:&quot;d12e31234f&quot;,&quot;c&quot;:&quot;[g$x&gt;Q)M&amp;.N+v8&quot;}\r\nEOF\r\n}\r\n\r\nexpression=&#39;to_entries[] | .key + \\&quot;=\\\\\\&quot;\\&quot; + .value + \\&quot;\\\\\\&quot;\\&quot;&#39;\r\n\r\neval &quot;mypython | jq -r \\&quot;$expression\\&quot;&quot;\r\n```\r\n\r\n### Output\r\n```\r\nA=&quot;ab3241c&quot;\r\nB=&quot;d12e31234f&quot;\r\nc=&quot;[g$x&gt;Q)M&amp;.N+v8&quot;\r\n```\r\n",
                "title": "Is there a fix for this Expression to get the key value pairs right"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1601968424,
        "creation_date": 1601961499,
        "last_edit_date": 1601968424,
        "question_id": 64219781,
        "body_markdown": "I have this python script which prints this output in raw string format.\r\n\r\n    {&quot;A&quot;:&quot;ab3241c&quot;,&quot;B&quot;:&quot;d12e31234f&quot;,&quot;c&quot;:&quot;[g$x&gt;Q)M&amp;.N+v8&quot;}\r\n\r\nI am using jq to set the values of A,B and c\r\n\r\nSomething like this\r\n\r\n    expression=&#39;. | to_entries | .[] | .key + &quot;=\\&quot;&quot; + .value + &quot;\\&quot;&quot;&#39;\r\n    eval &quot;$(python script.py | jq -r &quot;$expression&quot;)&quot;\r\n\r\nThis works fine A and B. And when I do something like \r\n\r\n    echo $A\r\n    ab3241c\r\n\r\nBut the problem is with c where i get the output as \r\n\r\n    [g\\u003eQ)M\\u0026.N+v8\r\nso $x&gt; and &amp; are getting converted to unicode.\r\nCan I fix the expression to avoid this?\r\n\r\nI fixed it using \r\nexpression as \r\n\r\n    expression=&#39;to_entries | map(&quot;\\(.key)=\\(.value | @sh)&quot;) | .[]&#39;\r\n\r\n",
        "link": "https://stackoverflow.com/questions/64219781/is-there-a-fix-for-this-expression-to-get-the-key-value-pairs-right",
        "title": "Is there a fix for this Expression to get the key value pairs right"
    },
    {
        "tags": [
            "json",
            "yaml",
            "key",
            "jq",
            "pipeline"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 13729676,
                    "reputation": 3397,
                    "user_id": 9907481,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/53e46ecea950971c9f3d3d7419db0ac2?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "amsh",
                    "link": "https://stackoverflow.com/users/9907481/amsh"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1602007945,
                "post_id": 64229569,
                "comment_id": 113581861,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1602133210,
                "last_edit_date": 1602133210,
                "creation_date": 1602018521,
                "answer_id": 64233820,
                "question_id": 64229569,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The detailed requirements are unclear, but hopefully you&#39;ll be able to use the following jq program as a guide:\r\n```\r\n..\r\n| objects\r\n| select( .data10 == &quot;true&quot; )\r\n| to_entries[]\r\n| select(.key != &quot;data10&quot;)\r\n| [.key, .value]\r\n```\r\n\r\nThis will recursively (thanks to the initial `..`) examine all the JSON objects in the input.\r\n\r\n## p.s. \r\nIf you want to make the selection based on whether .data10 is `&quot;true&quot;` or `true`, you could change the criterion to `.data10 | . == true or . == &quot;true&quot;`.",
                "title": "how to output all the keys and values from json using jq?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1602063659,
                "last_edit_date": 1602063659,
                "creation_date": 1602062004,
                "answer_id": 64240900,
                "question_id": 64229569,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "\r\n```\r\njq &#39;to_entries | map(select(.value.data10==&quot;true&quot;)) | from_entries&#39; data.json\r\n```\r\n\r\ninput ***data.json***,\r\nwith **false** value:\r\n```\r\n{\r\n  &quot;FOO&quot;: {\r\n    &quot;data10&quot;: &quot;false&quot;,\r\n    &quot;name&quot;: &quot;Donald&quot;,\r\n    &quot;location&quot;: &quot;Stockholm&quot;\r\n  },\r\n  &quot;BAR&quot;: {\r\n    &quot;data10&quot;: &quot;true&quot;,\r\n    &quot;name&quot;: &quot;Walt&quot;,\r\n    &quot;location&quot;: &quot;Stockholm&quot;\r\n  },\r\n  &quot;BAZ&quot;: {\r\n    &quot;data10&quot;: &quot;true&quot;,\r\n    &quot;name&quot;: &quot;Jack&quot;,\r\n    &quot;location&quot;: &quot;Whereever&quot;\r\n  }\r\n}\r\n```\r\noutput:\r\n```\r\n{\r\n  &quot;BAR&quot;: {\r\n    &quot;data10&quot;: &quot;true&quot;,\r\n    &quot;name&quot;: &quot;Walt&quot;,\r\n    &quot;location&quot;: &quot;Stockholm&quot;\r\n  },\r\n  &quot;BAZ&quot;: {\r\n    &quot;data10&quot;: &quot;true&quot;,\r\n    &quot;name&quot;: &quot;Jack&quot;,\r\n    &quot;location&quot;: &quot;Whereever&quot;\r\n  }\r\n}\r\n```\r\nbased on: https://stackoverflow.com/a/37843822/983325",
                "title": "how to output all the keys and values from json using jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1602133210,
        "creation_date": 1601999990,
        "last_edit_date": 1602045571,
        "question_id": 64229569,
        "body_markdown": "I am trying to out all the data from my json file that matches the value &quot;data10=true&quot; it does that but only grabs the names, how can i make it so it will output everything in my json file with anything that matches the &quot;data10=true&quot;?\r\n\r\nthis is what ive got `      data=$(jq -c &#39;to_entries[] | select (.value.data10 == &quot;true&quot;)| [.key, .value.name]&#39; data.json )`\r\n\r\nThis is in my YAML template btw, running it as a pipeline in devops.",
        "link": "https://stackoverflow.com/questions/64229569/how-to-output-all-the-keys-and-values-from-json-using-jq",
        "title": "how to output all the keys and values from json using jq?"
    },
    {
        "tags": [
            "json",
            "count",
            "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": 1602091840,
                "post_id": 64243574,
                "comment_id": 113613454,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1602093107,
                "last_edit_date": 1602093107,
                "creation_date": 1602072508,
                "answer_id": 64243717,
                "question_id": 64243574,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You don&#39;t need separate invocations of `jq`. You can do it one shot as below invoking the function on the array\r\n\r\n    { id: .dependencyId, vulnCount: (.vulnerabilities|length) }\r\n\r\nThe issue with your attempt was `[]` exposes all the objects inside the array and the `length` function on the object counts the number of key/value pairs in a given object. \r\n\r\nThe object in `129707` has two key/value pairs, with key names `name` and `severity`. In second id with `129708`, there are two objects inside, each object is printed with count 2 along with the id. Since `129709` does not have any objects inside, it is totally ignored in the resulting output.\r\n\r\n",
                "title": "How to append and count the number of elements using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1602093107,
        "creation_date": 1602072005,
        "question_id": 64243574,
        "body_markdown": "So I have this json. I need to count the number of elements inside the `vulnerabilities[]` arrays\r\n```\r\n{\r\n  &quot;dependencyId&quot;: 129707,\r\n  &quot;isVirtual&quot;: &quot;false&quot;,\r\n  &quot;vulnerabilities&quot;: [\r\n    {\r\n     &quot;name&quot;: &quot;vul&quot;,\r\n     &quot;severity&quot;: &quot;LOW&quot;,\r\n    }\r\n   ]\r\n}\r\n{\r\n  &quot;dependencyId&quot;: 129708,\r\n  &quot;isVirtual&quot;: &quot;false&quot;,\r\n  &quot;vulnerabilities&quot;: [\r\n    {\r\n     &quot;name&quot;: &quot;vul&quot;,\r\n     &quot;severity&quot;: &quot;LOW&quot;,\r\n    },\r\n    {\r\n     &quot;name&quot;: &quot;vul&quot;,\r\n     &quot;severity&quot;: &quot;HIGH&quot;,\r\n    }\r\n  ]\r\n}\r\n{\r\n  &quot;dependencyId&quot;: 129709,\r\n  &quot;isVirtual&quot;: &quot;false&quot;,\r\n  &quot;vulnerabilities&quot;: []\r\n}\r\n```\r\nWhat I have tried is this\r\n```\r\njq &#39;.&#39; c.json | jq  &#39;{id: .dependencyId, vulnCount: .vulnerabilities[] | length}&#39;\r\n```\r\n**Result :**\r\n```\r\n{\r\n  &quot;id&quot;: 129707,\r\n  &quot;vulnCount&quot;: 2\r\n}\r\n{\r\n  &quot;id&quot;: 129708,\r\n  &quot;vulnCount&quot;: 2\r\n}\r\n{\r\n  &quot;id&quot;: 129709,\r\n  &quot;vulnCount&quot;: 2\r\n}\r\n```\r\n**Expected Result**\r\n```\r\n{\r\n  &quot;id&quot;: 129707,\r\n  &quot;vulnCount&quot;: 1\r\n}\r\n{\r\n  &quot;id&quot;: 129708,\r\n  &quot;vulnCount&quot;: 2\r\n}\r\n{\r\n  &quot;id&quot;: 129709,\r\n  &quot;vulnCount&quot;: 0\r\n}\r\n```\r\nSo how do I get the number of vulnerabilities from `vulnerabilities[]` depending the number of element from the array?",
        "link": "https://stackoverflow.com/questions/64243574/how-to-append-and-count-the-number-of-elements-using-jq",
        "title": "How to append and count the number of elements using jq"
    },
    {
        "tags": [
            "json",
            "select",
            "jq",
            "string-matching"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3959308,
                    "reputation": 53394,
                    "user_id": 3266847,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/U0oyt.png?s=256",
                    "display_name": "Benjamin W.",
                    "link": "https://stackoverflow.com/users/3266847/benjamin-w"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1602105934,
                "post_id": 64252276,
                "comment_id": 113619014,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "user_type": "does_not_exist",
                    "display_name": "anon"
                },
                "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": 1602106459,
                "post_id": 64252276,
                "comment_id": 113619175,
                "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": 1602109807,
                "post_id": 64252276,
                "comment_id": 113620187,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "user_type": "does_not_exist",
                    "display_name": "anon"
                },
                "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": 1602115337,
                "post_id": 64252276,
                "comment_id": 113621458,
                "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": 1602123272,
                "post_id": 64252276,
                "comment_id": 113623011,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "user_type": "does_not_exist",
                    "display_name": "anon"
                },
                "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": 1602174698,
                "post_id": 64252276,
                "comment_id": 113643946,
                "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": 1602177135,
                "post_id": 64252276,
                "comment_id": 113645135,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "user_type": "does_not_exist",
                    "display_name": "anon"
                },
                "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": 1602177266,
                "post_id": 64252276,
                "comment_id": 113645184,
                "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": 1602177447,
                "post_id": 64252276,
                "comment_id": 113645263,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "user_type": "does_not_exist",
                    "display_name": "anon"
                },
                "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": 1602177513,
                "post_id": 64252276,
                "comment_id": 113645302,
                "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": 1602177790,
                "post_id": 64252276,
                "comment_id": 113645427,
                "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": 1602179454,
                "post_id": 64252276,
                "comment_id": 113646116,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "user_type": "does_not_exist",
                    "display_name": "anon"
                },
                "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": 1602183233,
                "post_id": 64252276,
                "comment_id": 113647633,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1602223207,
                "last_edit_date": 1602223207,
                "creation_date": 1602122706,
                "answer_id": 64254766,
                "question_id": 64252276,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The streaming parser (invoked with --stream) is usually not needed for the kind of task you describe, so in this response, I&#39;m going to assume that the following (or a variant thereof) will suffice:\r\n\r\n```\r\n.[]\r\n| select( .body | test(&quot;Hello&quot;) )._id\r\n```\r\n\r\nThis of course assumes that the input is valid JSON.\r\n\r\n### Handling comma-delimited JSON\r\n\r\nIf your input is a comma-delimited stream of JSON as shown in the Q, you could use the following in conjunction with the -n command-line option:\r\n```\r\n# This is a variant of the built-in `recurse/1`:\r\ndef iterate(f): def r: f | (., r); r;\r\n\r\niterate( inputs? | .[] | select( .body | test(&quot;Hello&quot;) )._id )\r\n```\r\n\r\nPlease note that this assumes that whatever occurs on a line after a delimiting comma can be ignored.",
                "title": "Fuzzy match string with jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1602179305,
                "last_edit_date": 1602179305,
                "creation_date": 1602123132,
                "answer_id": 64254820,
                "question_id": 64252276,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Assuming the input is modified slightly to make it a stream of the arrays as shown in the Q:\r\n```\r\njq -nr --stream &#39;\r\n  fromstream(1|truncate_stream(inputs))\r\n  | select(.body | test(&quot;Hello&quot;))\r\n  | ._id\r\n&#39;\r\n```\r\nproduces the desired output.\r\n\r\n`test` uses regex matching.  In your case, it seems you could use simple substring matching instead.\r\n\r\n## Handling extraneous commas\r\nAssuming the input has commas between a stream of valid JSON exactly as shown, you could presumably use `sed` to remove them first.\r\n\r\nOr, if you want an only-jq solution, use the following in conjunction with the -n, -r and --stream command-line options:\r\n```\r\ndef iterate:\r\n  fromstream(1|truncate_stream(inputs?))\r\n  | select(.body | test(&quot;Hello&quot;))\r\n  | ._id,\r\n    iterate;\r\n\r\n\r\niterate\r\n```\r\n(Notice the &quot;?&quot;.)",
                "title": "Fuzzy match string with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": -1,
        "last_activity_date": 1602223207,
        "creation_date": 1602104578,
        "last_edit_date": 1602139957,
        "question_id": 64252276,
        "body_markdown": "Let&#39;s say I have some JSON in a file, it&#39;s a subset of JSON data extracted from a larger JSON file - that&#39;s why I&#39;ll use `stream` later in my attempted solution - and it looks like this:\r\n\r\n    [\r\n    {&quot;_id&quot;:&quot;1&quot;,&quot;@&quot;:{},&quot;article&quot;:false,&quot;body&quot;:&quot;Hello world&quot;,&quot;comments&quot;:&quot;3&quot;,&quot;createdAt&quot;:&quot;20201007200628&quot;,&quot;creator&quot;:{&quot;id&quot;:&quot;4a7ba8fd719d43598b977dd548eed6aa&quot;,&quot;bio&quot;:&quot;&quot;,&quot;blocked&quot;:false,&quot;followed&quot;:false,&quot;human&quot;:false,&quot;integration&quot;:false,&quot;joined&quot;:&quot;20201007200628&quot;,&quot;muted&quot;:false,&quot;name&quot;:&quot;mkscott&quot;,&quot;rss&quot;:false,&quot;private&quot;:false,&quot;username&quot;:&quot;mkscott&quot;,&quot;verified&quot;:false,&quot;verifiedComments&quot;:false,&quot;badges&quot;:[],&quot;score&quot;:&quot;0&quot;,&quot;interactions&quot;:258,&quot;state&quot;:1},&quot;depth&quot;:&quot;0&quot;,&quot;depthRaw&quot;:0,&quot;hashtags&quot;:[],&quot;id&quot;:&quot;2d4126e342ed46509b55facb49b992a5&quot;,&quot;impressions&quot;:&quot;3&quot;,&quot;links&quot;:[],&quot;sensitive&quot;:false,&quot;state&quot;:4,&quot;upvotes&quot;:&quot;0&quot;},\r\n    {&quot;_id&quot;:&quot;2&quot;,&quot;@&quot;:{},&quot;article&quot;:false,&quot;body&quot;:&quot;Goodbye world&quot;,&quot;comments&quot;:&quot;3&quot;,&quot;createdAt&quot;:&quot;20201007200628&quot;,&quot;creator&quot;:{&quot;id&quot;:&quot;4a7ba8fd719d43598b977dd548eed6aa&quot;,&quot;bio&quot;:&quot;&quot;,&quot;blocked&quot;:false,&quot;followed&quot;:false,&quot;human&quot;:false,&quot;integration&quot;:false,&quot;joined&quot;:&quot;20201007200628&quot;,&quot;muted&quot;:false,&quot;name&quot;:&quot;mkscott&quot;,&quot;rss&quot;:false,&quot;private&quot;:false,&quot;username&quot;:&quot;mkscott&quot;,&quot;verified&quot;:false,&quot;verifiedComments&quot;:false,&quot;badges&quot;:[],&quot;score&quot;:&quot;0&quot;,&quot;interactions&quot;:258,&quot;state&quot;:1},&quot;depth&quot;:&quot;0&quot;,&quot;depthRaw&quot;:0,&quot;hashtags&quot;:[],&quot;id&quot;:&quot;2d4126e342ed46509b55facb49b992a5&quot;,&quot;impressions&quot;:&quot;3&quot;,&quot;links&quot;:[],&quot;sensitive&quot;:false,&quot;state&quot;:4,&quot;upvotes&quot;:&quot;0&quot;}\r\n    ],\r\n    [\r\n    {&quot;_id&quot;:&quot;55&quot;,&quot;@&quot;:{},&quot;article&quot;:false,&quot;body&quot;:&quot;Hello world&quot;,&quot;comments&quot;:&quot;3&quot;,&quot;createdAt&quot;:&quot;20201007200628&quot;,&quot;creator&quot;:{&quot;id&quot;:&quot;3a7ba8fd719d43598b977dd548eed6aa&quot;,&quot;bio&quot;:&quot;&quot;,&quot;blocked&quot;:false,&quot;followed&quot;:false,&quot;human&quot;:false,&quot;integration&quot;:false,&quot;joined&quot;:&quot;20201007200628&quot;,&quot;muted&quot;:false,&quot;name&quot;:&quot;mkscott&quot;,&quot;rss&quot;:false,&quot;private&quot;:false,&quot;username&quot;:&quot;jkscott&quot;,&quot;verified&quot;:false,&quot;verifiedComments&quot;:false,&quot;badges&quot;:[],&quot;score&quot;:&quot;0&quot;,&quot;interactions&quot;:258,&quot;state&quot;:1},&quot;depth&quot;:&quot;0&quot;,&quot;depthRaw&quot;:0,&quot;hashtags&quot;:[],&quot;id&quot;:&quot;2d4126e342ed46509b55facb49b992a5&quot;,&quot;impressions&quot;:&quot;3&quot;,&quot;links&quot;:[],&quot;sensitive&quot;:false,&quot;state&quot;:4,&quot;upvotes&quot;:&quot;0&quot;},\r\n    {&quot;_id&quot;:&quot;56&quot;,&quot;@&quot;:{},&quot;article&quot;:false,&quot;body&quot;:&quot;Goodbye world&quot;,&quot;comments&quot;:&quot;3&quot;,&quot;createdAt&quot;:&quot;20201007200628&quot;,&quot;creator&quot;:{&quot;id&quot;:&quot;3a7ba8fd719d43598b977dd548eed6aa&quot;,&quot;bio&quot;:&quot;&quot;,&quot;blocked&quot;:false,&quot;followed&quot;:false,&quot;human&quot;:false,&quot;integration&quot;:false,&quot;joined&quot;:&quot;20201007200628&quot;,&quot;muted&quot;:false,&quot;name&quot;:&quot;mkscott&quot;,&quot;rss&quot;:false,&quot;private&quot;:false,&quot;username&quot;:&quot;jkscott&quot;,&quot;verified&quot;:false,&quot;verifiedComments&quot;:false,&quot;badges&quot;:[],&quot;score&quot;:&quot;0&quot;,&quot;interactions&quot;:258,&quot;state&quot;:1},&quot;depth&quot;:&quot;0&quot;,&quot;depthRaw&quot;:0,&quot;hashtags&quot;:[],&quot;id&quot;:&quot;2d4126e342ed46509b55facb49b992a5&quot;,&quot;impressions&quot;:&quot;3&quot;,&quot;links&quot;:[],&quot;sensitive&quot;:false,&quot;state&quot;:4,&quot;upvotes&quot;:&quot;0&quot;}\r\n    ]\r\n\r\nIt describes 4 posts written by 2 different authors, with unique `_id` fields for each post. Both authors wrote 2 posts, where 1 says &quot;Hello World&quot; and the other says &quot;Goodbye World&quot;.\r\n\r\nI want to match on the word &quot;Hello&quot; and return the `_id` only for fields containing &quot;Hello&quot;. The expected result is:\r\n\r\n    1\r\n    55\r\n\r\nThe closest I could come in my attempt was:\r\n\r\n    jq -nr --stream &#39;\r\n    fromstream(1|truncate_stream(inputs))\r\n    | select(.body %like% &quot;Hello&quot;)\r\n    | ._id\r\n    &#39; &lt;input_file",
        "link": "https://stackoverflow.com/questions/64252276/fuzzy-match-string-with-jq",
        "title": "Fuzzy match string with jq"
    },
    {
        "tags": [
            "arrays",
            "parsing",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1602152741,
                "creation_date": 1602152741,
                "answer_id": 64260575,
                "question_id": 64259063,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could just `add` the array of objects together. Use the `|=` operator to write it back to `.target` itself\r\n\r\n    jq &#39;.target |= add&#39;",
                "title": "Convert array of objects to object using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1602152791,
        "creation_date": 1602147299,
        "last_edit_date": 1602152791,
        "question_id": 64259063,
        "body_markdown": "I am looking for way to convert array of objects as mentioned in example below to just an object using `jq`. \r\n\r\n    {\r\n    \t&quot;appName&quot;: &quot;ABC&quot;,\r\n    \t&quot;target&quot;: [{\r\n    \t\t\t&quot;connectedApp_SalesforceServiceCloud&quot;: &quot;false&quot;\r\n    \t\t},\r\n    \t\t{\r\n    \t\t\t&quot;connectedApp_SalesforceSalesCloud&quot;: &quot;false&quot;\r\n    \t\t},\r\n    \t\t{\r\n    \t\t\t&quot;connectedApp_DataDotcom&quot;: &quot;true&quot;\r\n    \t\t},\r\n    \t\t{\r\n    \t\t\t&quot;connectedApp_SalesforceChatter&quot;: &quot;true&quot;\r\n    \t\t}\r\n    \t]\r\n    }\r\n\r\nO/p Expected : \r\n\r\n    {\r\n    \t&quot;appName&quot;: &quot;ABC&quot;,\r\n    \t&quot;target&quot;: {\r\n    \t\t&quot;connectedApp_SalesforceServiceCloud&quot;: &quot;false&quot;,\r\n    \t\t&quot;connectedApp_SalesforceSalesCloud&quot;: &quot;true&quot;,\r\n    \t\t&quot;connectedApp_DataDotcom&quot;: &quot;true&quot;,\r\n    \t\t&quot;connectedApp_SalesforceChatter&quot;: &quot;true&quot;\r\n    \t}\r\n    }",
        "link": "https://stackoverflow.com/questions/64259063/convert-array-of-objects-to-object-using-jq",
        "title": "Convert array of objects to object using jq"
    },
    {
        "tags": [
            "json",
            "select",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1602180266,
                "last_edit_date": 1602180266,
                "creation_date": 1602179065,
                "answer_id": 64267970,
                "question_id": 64264926,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Judging from your requirements, it seems you need an expression to select objects  in the `.Body[]` array where `.webServerName` key is `www.example.com:443` or the key basically exists\r\n\r\n    .[].Body |= map(select(.webServerName == &quot;www.example.com:443&quot; or has(&quot;webServerName&quot;) ))\r\n\r\nBoth your attempts though valid are really convoluted. The standard pattern to selectively filter out objects inside the array is to use the `|=` operator with the right `select` expression.\r\n\r\nThe `| {Tenant: $x, Body: [$y]}` is wrong, because it is applied to each of the 2 objects you filtered in the previous expression. So each of the result has a `Tenant` field created. Since you have no change in key names (same key `Tenant`), there is really no purpose to re-create new objects with `{..}`.",
                "title": "jq - select and filter only certain objects from the array"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1602753098,
        "creation_date": 1602167995,
        "last_edit_date": 1602753098,
        "question_id": 64264926,
        "body_markdown": "My JSON file has the following structure\r\n```\r\n[\r\n    {\r\n        &quot;Header&quot;: {\r\n            &quot;Tenant&quot;: &quot;T1&quot;\r\n        },\r\n        &quot;Body&quot;: [\r\n            {\r\n                &quot;agentTechnologyType&quot;: &quot;JAVA&quot;,\r\n                &quot;entityId&quot;: &quot;SERVICE-EDA448F07EDBDAA6&quot;,\r\n                &quot;serviceType&quot;: &quot;WebRequest&quot;,\r\n                &quot;webServerName&quot;: &quot;www.example.com:443&quot;\r\n            },\r\n            {\r\n                &quot;agentTechnologyType&quot;: &quot;TOMCAT&quot;,\r\n                &quot;entityId&quot;: &quot;SERVICE-728B1FF49D132C89&quot;,\r\n                &quot;serviceType&quot;: &quot;WebRequest&quot;,\r\n                &quot;webServerName&quot;: &quot;www.example.com:80&quot;\r\n            },\r\n            {\r\n                &quot;agentTechnologyType&quot;: &quot;JAVA&quot;,\r\n                &quot;entityId&quot;: &quot;SERVICE-42A0FB8666B36EB4&quot;,\r\n                &quot;serviceType&quot;: &quot;Process&quot;\r\n            },\r\n            {\r\n                &quot;agentTechnologyType&quot;: &quot;APACHE&quot;,\r\n                &quot;serviceType&quot;: &quot;WebRequest&quot;,\r\n                &quot;webServerName&quot;: &quot;www.example.com:443&quot;\r\n            }\r\n        ]\r\n    }\r\n]\r\n```\r\nI need to apply several filters and leave in the ``.Body[]`` array objects according to different criteria:\r\n\r\n 1. Only select these objects in the ``.Body[]`` array which *do not* have ``.webServerName`` key present - this condition should leave only the object #2 inside the ``.Body[]`` array \r\n 2. Only select these objects in the ``.Body[]`` array  where ``.webServerName`` value is ``www.example.com:443`` - that should leave objects # 0,3.\r\n 3. Select all objects which have ``.webServerName`` key present, so negating the condition #1 - this should leave all object except #2.\r\n\r\nFor #1 the filter below does the job\r\n```\r\n[.[].Header as $x |  (.[].Body[] | select( (.webServerName == null  ))) as $y | {Tenant: $x, Body: [$y]} ]\r\n```\r\nIt gives the following output:\r\n```\r\n[\r\n  {\r\n    &quot;Tenant&quot;: {\r\n      &quot;Tenant&quot;: &quot;T1&quot;\r\n    },\r\n    &quot;Body&quot;: [\r\n      {\r\n        &quot;agentTechnologyType&quot;: &quot;JAVA&quot;,\r\n        &quot;entityId&quot;: &quot;SERVICE-42A0FB8666B36EB4&quot;,\r\n        &quot;serviceType&quot;: &quot;Process&quot;\r\n      }\r\n    ]\r\n  }\r\n]\r\n```\r\nBut when I tried to modify the filter for the condition #2\r\n```\r\n[.[].Header as $x |  (.[].Body[] | select( (.webServerName == &quot;www.example.com:443&quot;  ))) as $y | {Tenant: $x, Body: [$y]} ] \r\n```\r\nThis gave me the following output - two entries instead of having one.\r\n\r\n```\r\n[\r\n  {\r\n    &quot;Tenant&quot;: {\r\n      &quot;Tenant&quot;: &quot;T1&quot;\r\n    },\r\n    &quot;Body&quot;: [\r\n      {\r\n        &quot;agentTechnologyType&quot;: &quot;JAVA&quot;,\r\n        &quot;entityId&quot;: &quot;SERVICE-EDA448F07EDBDAA6&quot;,\r\n        &quot;serviceType&quot;: &quot;WebRequest&quot;,\r\n        &quot;webServerName&quot;: &quot;www.example.com:443&quot;\r\n      }\r\n    ]\r\n  },\r\n  {\r\n    &quot;Tenant&quot;: {\r\n      &quot;Tenant&quot;: &quot;T1&quot;\r\n    },\r\n    &quot;Body&quot;: [\r\n      {\r\n        &quot;agentTechnologyType&quot;: &quot;APACHE&quot;,\r\n        &quot;serviceType&quot;: &quot;WebRequest&quot;,\r\n        &quot;webServerName&quot;: &quot;www.example.com:443&quot;\r\n      }\r\n    ]\r\n  }\r\n]\r\n``` \r\nWhile the expected output should look like for case #2:\r\n```\r\n[\r\n  {\r\n    &quot;Tenant&quot;: {\r\n      &quot;Tenant&quot;: &quot;T1&quot;\r\n    },\r\n    &quot;Body&quot;: [\r\n      {\r\n        &quot;agentTechnologyType&quot;: &quot;JAVA&quot;,\r\n        &quot;entityId&quot;: &quot;SERVICE-EDA448F07EDBDAA6&quot;,\r\n        &quot;serviceType&quot;: &quot;WebRequest&quot;,\r\n        &quot;webServerName&quot;: &quot;www.example.com:443&quot;\r\n      },\r\n      {\r\n        &quot;agentTechnologyType&quot;: &quot;APACHE&quot;,\r\n        &quot;serviceType&quot;: &quot;WebRequest&quot;,\r\n        &quot;webServerName&quot;: &quot;www.example.com:443&quot;\r\n      }\r\n    ]\r\n  }\r\n]\r\n```\r\nAnd the following for case #3:\r\n```\r\n[\r\n  {\r\n    &quot;Header&quot;: {\r\n      &quot;Tenant&quot;: &quot;T1&quot;\r\n    },\r\n    &quot;Body&quot;: [\r\n      {\r\n        &quot;agentTechnologyType&quot;: &quot;JAVA&quot;,\r\n        &quot;entityId&quot;: &quot;SERVICE-EDA448F07EDBDAA6&quot;,\r\n        &quot;serviceType&quot;: &quot;WebRequest&quot;,\r\n        &quot;webServerName&quot;: &quot;www.example.com:443&quot;\r\n      },\r\n      {\r\n        &quot;agentTechnologyType&quot;: &quot;TOMCAT&quot;,\r\n        &quot;entityId&quot;: &quot;SERVICE-728B1FF49D132C89&quot;,\r\n        &quot;serviceType&quot;: &quot;WebRequest&quot;,\r\n        &quot;webServerName&quot;: &quot;www.example.com:80&quot;\r\n      },\r\n      {\r\n        &quot;agentTechnologyType&quot;: &quot;APACHE&quot;,\r\n        &quot;serviceType&quot;: &quot;WebRequest&quot;,\r\n        &quot;webServerName&quot;: &quot;www.example.com:443&quot;\r\n      }\r\n    ]\r\n  }\r\n]\r\n```\r\nI am trying to figure out where I made an error - in the selection condition or in the forming of the new object at the end.\r\n",
        "link": "https://stackoverflow.com/questions/64264926/jq-select-and-filter-only-certain-objects-from-the-array",
        "title": "jq - select and filter only certain objects from the array"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1602251066,
                "last_edit_date": 1602251066,
                "creation_date": 1602250666,
                "answer_id": 64281230,
                "question_id": 64281133,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use the following :\r\n\r\n    to_entries | map(select(.key | startswith(&quot;us_cell_&quot;)) | .value.ip_ranges) | add\r\n\r\n[Try it here](https://jqplay.org/s/GT8P5IF8tS).\r\n\r\n[`to_entries`](https://stedolan.github.io/jq/manual/#to_entries,from_entries,with_entries) maps the root object into an array of objects with `key` and `value` fields corresponding to the fields of the original object.\r\n\r\nWe filter that to retain only those which have a key starting with &quot;us_cell_&quot;, map it further to keep only the ip ranges and finally merge those arrays together.",
                "title": "How can you filter on &quot;Keys&quot; using jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1602251066,
        "creation_date": 1602250336,
        "question_id": 64281133,
        "body_markdown": "I am looking to filter a JSON stream based on its keys. Here is the public JSON file:\r\nhttps://s3.amazonaws.com/okta-ip-ranges/ip_ranges.json that I am trying to wrangle. When I filter this for keys `jq &#39;keys&#39;`, I get the following output\r\n```\r\n[\r\n  &quot;apac_cell_1&quot;,\r\n  &quot;emea_cell_1&quot;,\r\n  &quot;emea_cell_2&quot;,\r\n  &quot;preview_cell_1&quot;,\r\n  &quot;preview_cell_2&quot;,\r\n  &quot;preview_cell_3&quot;,\r\n  &quot;us_cell_1&quot;,\r\n  &quot;us_cell_10&quot;,\r\n  &quot;us_cell_11&quot;,\r\n  &quot;us_cell_12&quot;,\r\n  &quot;us_cell_2&quot;,\r\n  &quot;us_cell_3&quot;,\r\n  &quot;us_cell_4&quot;,\r\n  &quot;us_cell_5&quot;,\r\n  &quot;us_cell_6&quot;,\r\n  &quot;us_cell_7&quot;\r\n]\r\n```\r\nI am trying to get all the `ip_ranges` associated with the keys starting with &quot;us_cell_*&quot; and I have not found a way to do it. Most of the filtering seems to be focused on the values and not the keys.",
        "link": "https://stackoverflow.com/questions/64281133/how-can-you-filter-on-keys-using-jq",
        "title": "How can you filter on &quot;Keys&quot; using jq?"
    },
    {
        "tags": [
            "bash",
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 4663062,
                    "reputation": 89888,
                    "user_id": 3776858,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Cagbk.jpg?s=256",
                    "display_name": "Cyrus",
                    "link": "https://stackoverflow.com/users/3776858/cyrus"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1602276122,
                "post_id": 64286774,
                "comment_id": 113680012,
                "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": 1602276132,
                "post_id": 64286774,
                "comment_id": 113680015,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 11751872,
                    "reputation": 73,
                    "user_id": 8600742,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/17b505fe98e4f402da2ec7cc593c0083?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "akhinair",
                    "link": "https://stackoverflow.com/users/8600742/akhinair"
                },
                "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": 1602276287,
                "post_id": 64286774,
                "comment_id": 113680058,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 11751872,
                    "reputation": 73,
                    "user_id": 8600742,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/17b505fe98e4f402da2ec7cc593c0083?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "akhinair",
                    "link": "https://stackoverflow.com/users/8600742/akhinair"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1602277471,
                "post_id": 64286774,
                "comment_id": 113680472,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 10286519,
                    "reputation": 5985,
                    "user_id": 7589636,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa78a73e889b0b4e61a931d9237012c5?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "thanasisp",
                    "link": "https://stackoverflow.com/users/7589636/thanasisp"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1602278694,
                "post_id": 64286774,
                "comment_id": 113680830,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1602332714,
                "last_edit_date": 1602332714,
                "creation_date": 1602282491,
                "answer_id": 64288066,
                "question_id": 64286774,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It is more tricky to match the regex, sort or anything inside `jq`. GNU `sort` command has a nice parameter, `-V` that stands for version sorting, so here is a simple way to do this, also without any awk or sort splitting to fields or similar.\r\n\r\n```bash\r\njq -r &#39;.validNodeVersions[]&#39; file.json | grep &quot;^1\\.15&quot; | sort -V | tail -1\r\n1.15.12-gke.20\r\n```\r\n\r\n`jq` is doing a simple selection of values here, `grep` filters these values by version and after sorting by version we get the highest.",
                "title": "Select highest version value from JSON array"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1602332714,
        "creation_date": 1602274746,
        "last_edit_date": 1602282697,
        "question_id": 64286774,
        "body_markdown": "I have an JSON result and i need to search for a specific value and get from the array.\r\n\r\nFor example here is my JSON and I need to search for a version `1.15` having the higher patch version inside the `validNodeVersions` array. So here I wanted to retrieve the value `1.15.12-gke.20` and that is the highest 1.15 versions for the array list. Can somebody please help on this?\r\n\r\nBasically I am looking always to pick the highest patch release for any of the version. for `1.15` it is `1.15.12-gke.20`.\r\n\r\n`gcloud container get-server-config --format json`\r\n\r\n```json\r\n{\r\n  &quot;channels&quot;: [\r\n    {\r\n      &quot;channel&quot;: &quot;REGULAR&quot;,\r\n      &quot;defaultVersion&quot;: &quot;1.17.9-gke.1504&quot;,\r\n      &quot;validVersions&quot;: [\r\n        &quot;1.17.9-gke.6300&quot;,\r\n        &quot;1.17.9-gke.1504&quot;\r\n      ]\r\n    },\r\n    {\r\n      &quot;channel&quot;: &quot;STABLE&quot;,\r\n      &quot;defaultVersion&quot;: &quot;1.16.13-gke.401&quot;,\r\n      &quot;validVersions&quot;: [\r\n        &quot;1.16.13-gke.401&quot;,\r\n        &quot;1.15.12-gke.20&quot;\r\n      ]\r\n    }\r\n  ],\r\n  &quot;defaultClusterVersion&quot;: &quot;1.16.13-gke.401&quot;,\r\n  &quot;defaultImageType&quot;: &quot;COS&quot;,\r\n  &quot;validImageTypes&quot;: [\r\n    &quot;UBUNTU&quot;,\r\n    &quot;UBUNTU_CONTAINERD&quot;\r\n  ],\r\n  &quot;validMasterVersions&quot;: [\r\n    &quot;1.17.12-gke.500&quot;,\r\n    &quot;1.14.10-gke.50&quot;\r\n  ],\r\n  &quot;validNodeVersions&quot;: [\r\n    &quot;1.17.12-gke.500&quot;,\r\n    &quot;1.16.8-gke.12&quot;,\r\n    &quot;1.15.12-gke.20&quot;,\r\n    &quot;1.15.12-gke.17&quot;,\r\n    &quot;1.15.12-gke.16&quot;,\r\n    &quot;1.15.12-gke.13&quot;,\r\n    &quot;1.15.12-gke.9&quot;,\r\n    &quot;1.15.12-gke.6&quot;,\r\n    &quot;1.15.12-gke.3&quot;,\r\n    &quot;1.15.12-gke.2&quot;,\r\n    &quot;1.15.11-gke.17&quot;,\r\n    &quot;1.15.11-gke.15&quot;,\r\n    &quot;1.15.11-gke.13&quot;,\r\n    &quot;1.15.11-gke.12&quot;,\r\n    &quot;1.15.11-gke.11&quot;,\r\n    &quot;1.15.11-gke.9&quot;,\r\n    &quot;1.15.11-gke.5&quot;,\r\n    &quot;1.15.11-gke.3&quot;,\r\n    &quot;1.15.11-gke.1&quot;,\r\n    &quot;1.15.9-gke.26&quot;,\r\n    &quot;1.15.8-gke.3&quot;,\r\n    &quot;1.15.7-gke.23&quot;,\r\n    &quot;1.15.4-gke.22&quot;,\r\n    &quot;1.14.10-gke.0&quot;,\r\n    &quot;1.14.9-gke.0&quot;\r\n  ]\r\n}\r\n```",
        "link": "https://stackoverflow.com/questions/64286774/select-highest-version-value-from-json-array",
        "title": "Select highest version value from JSON array"
    },
    {
        "tags": [
            "bash",
            "shell",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1602280997,
                "last_edit_date": 1602280997,
                "creation_date": 1602280596,
                "answer_id": 64287796,
                "question_id": 64287645,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You may use it like this:\r\n\r\n    jq -r --arg p &quot;$project&quot; --arg a &quot;$app&quot; &#39;.[$p][$a]&#39; file.json\r\n\r\nor else:\r\n\r\n    jq -r --arg p &quot;$project&quot; --arg a &quot;$app&quot; &#39;.[$p] | .[$a]&#39; file.json\r\n\r\n&lt;p/&gt;\r\n\r\n    1.3.7\r\n",
                "title": "How to use key variables to get a second level value of json file using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1602280997,
        "creation_date": 1602279617,
        "question_id": 64287645,
        "body_markdown": "I need to get a specific value from a json file using jq in a bash script (busybox). The json file looks like this:\r\n\r\n    {\r\n      &quot;example.com&quot;: {\r\n        &quot;backend&quot;: &quot;1.3.7&quot;\r\n      }\r\n    }\r\n\r\nIn my script there are two variables: `project` and `app` - as there are of course multiple projects and applications. I need to use these variable values to get the version value. In this example `project` is &quot;example.com&quot; and `app` is &quot;backend&quot;\r\n\r\nI tried this\r\n\r\n    jq --arg p &quot;$project&quot; --arg a &quot;$app&quot; &#39;.[$p].[$a]&#39; file.json\r\n\r\nBut I do get the error\r\n\r\n    jq: error: syntax error, unexpected &#39;[&#39;, expecting FORMAT or QQSTRING_START (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n    .[$p].[$a]      \r\n    jq: 1 compile error",
        "link": "https://stackoverflow.com/questions/64287645/how-to-use-key-variables-to-get-a-second-level-value-of-json-file-using-jq",
        "title": "How to use key variables to get a second level value of json file using jq"
    },
    {
        "tags": [
            "arrays",
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1602288374,
                "last_edit_date": 1602288374,
                "creation_date": 1602287418,
                "answer_id": 64288625,
                "question_id": 64288520,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use `map` to map the array of objects to key-value pairs based on the fields you&#39;re interested in, then `add` to merge these pairs into an object.\r\n\r\n    $ jq &#39;map({(.title): .url}) | add&#39; test.json\r\n    {\r\n      &quot;channel 1&quot;: &quot;rtsp://thelink&quot;,\r\n      &quot;channel UFO&quot;: &quot;rtsp://thatlink&quot;,\r\n      &quot;channel oreo&quot;: &quot;rtsp://thatotherlink&quot;,\r\n      &quot;channel blabla&quot;: &quot;rtsp://yetanotherlink&quot;,\r\n      &quot;channel potato&quot;: &quot;rtsp://anotherlinkwhatnow&quot;\r\n    }",
                "title": "JQ to flatten an array into an object"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1602288564,
        "creation_date": 1602286337,
        "last_edit_date": 1602288564,
        "question_id": 64288520,
        "body_markdown": "I&#39;m having trouble using JQ in what should be a simple task.\r\n\r\nHere&#39;s a sample JSON:\r\n\r\n    [\r\n    \t{\r\n    \t\t&quot;title&quot;: &quot;channel 1&quot;,\r\n    \t\t&quot;url&quot;: &quot;rtsp://thelink&quot;\r\n    \t},\r\n    \t{\r\n    \t\t&quot;title&quot;: &quot;channel UFO&quot;,\r\n    \t\t&quot;url&quot;: &quot;rtsp://thatlink&quot;\r\n    \t},\r\n    \t{\r\n    \t\t&quot;title&quot;: &quot;channel oreo&quot;,\r\n    \t\t&quot;url&quot;: &quot;rtsp://thatotherlink&quot;\r\n    \t},\r\n    \t{\r\n    \t\t&quot;title&quot;: &quot;channel blabla&quot;,\r\n    \t\t&quot;url&quot;: &quot;rtsp://yetanotherlink&quot;\r\n    \t},\r\n    \t{\r\n    \t\t&quot;title&quot;: &quot;channel potato&quot;,\r\n    \t\t&quot;url&quot;: &quot;rtsp://anotherlinkwhatnow&quot;\r\n    \t}\r\n    ]\r\n\r\nI&#39;m attempting to flatten the array into a larger one for easier parsing later on low power devices. Here&#39;s what it should look like:\r\n\r\n\t{\r\n\t\t&quot;channel 1&quot;: &quot;rtsp://thelink&quot;,\r\n\t\t&quot;channel UFO&quot;: &quot;rtsp://thatlink&quot;,\r\n\t\t&quot;channel oreo&quot;: &quot;rtsp://thatotherlink&quot;,\r\n\t\t&quot;channel blabla&quot;: &quot;rtsp://yetanotherlink&quot;,\r\n\t\t&quot;channel potato&quot;: &quot;rtsp://anotherlinkwhatnow&quot;\r\n\t}\r\n\r\nI won&#39;t even pretend to understand the full structure of how JSON works, but with each little problem of this type solved, I come closer to understanding.\r\n\r\nAny help appreciated. FWIW, being proficient in PHP I can very simply iterate with a `foreach` and recreate the new one with each value as a key. But I really wish to better understand how JQ works (not for lack of trying or reading the manual!).",
        "link": "https://stackoverflow.com/questions/64288520/jq-to-flatten-an-array-into-an-object",
        "title": "JQ to flatten an array into an object"
    },
    {
        "tags": [
            "json",
            "select",
            "jq",
            "siblings"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1602317374,
                "creation_date": 1602317374,
                "answer_id": 64291339,
                "question_id": 64289911,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The following pipeline makes the solution fairly self-explanatory, assuming one understands the basic syntax and the -r command-line option:\r\n```\r\n&lt; input.json jq -r &#39;\r\n  .[]\r\n  | .code as $code\r\n  | .files[]\r\n  | select(.fileType == &quot;video&quot;)\r\n  | &quot;\\($code), \\&quot;\\(.url)\\&quot;&quot;\r\n&#39;\r\n```\r\n ",
                "title": "Print only one property of an object that is within an an array attribute as well as a property that is a sibling to the array property in jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1602336071,
        "creation_date": 1602303340,
        "last_edit_date": 1602336071,
        "question_id": 64289911,
        "body_markdown": "I have a json file that looks like so:\r\n\r\n```json\r\n[\r\n  {\r\n    &quot;code&quot;: &quot;1234&quot;, \r\n    &quot;files&quot;: [\r\n        {\r\n            &quot;fileType&quot;: &quot;pdf&quot;,\r\n            &quot;url&quot;: &quot;http://.../a.pdf&quot;\r\n        },\r\n        {\r\n            &quot;fileType&quot;: &quot;video&quot;,\r\n            &quot;url&quot;: &quot;http://.../b.mp4&quot;\r\n        }\r\n    ]\r\n  },\r\n  {\r\n    &quot;code&quot;: &quot;4321&quot;, \r\n    &quot;files&quot;: [\r\n        {\r\n            &quot;fileType&quot;: &quot;pdf&quot;,\r\n            &quot;url&quot;: &quot;http://.../c.pdf&quot;\r\n        },\r\n        {\r\n            &quot;fileType&quot;: &quot;video&quot;,\r\n            &quot;url&quot;: &quot;http://.../d.mp4&quot;\r\n        }\r\n    ]\r\n  },\r\n  {\r\n    &quot;code&quot;: &quot;9999&quot;, \r\n    &quot;files&quot;: [\r\n        {\r\n            &quot;fileType&quot;: &quot;pdf&quot;,\r\n            &quot;url&quot;: &quot;http://.../e.pdf&quot;\r\n        }\r\n    ]\r\n  }\r\n]\r\n```\r\n\r\nI would like to print out only the files that are of `fileType` == `video` in the `files` array such that I end up with output that looks like so:\r\n\r\n```\r\n1234, &quot;http://.../b.mp4&quot;\r\n4321, &quot;http://.../d.mp4&quot;\r\n```\r\n\r\nSo far I am only able to output something that looks like this:\r\n\r\n```\r\n1234, &quot;http://.../a.pdf&quot;, &quot;http://.../b.mp4&quot;,\r\n4321, &quot;http://.../c.pdf&quot;, &quot;http://.../d.mp4&quot;\r\n```\r\n\r\nUsing the following:\r\n\r\n```\r\njq -r &#39;.[] | select(.files[]?.fileType == &quot;video&quot;) | [.code, .files[].url] | @csv&#39;\r\n```\r\n\r\nI was wondering how I can filter the `.files[]` based on the `fileType` as I am outputting them?",
        "link": "https://stackoverflow.com/questions/64289911/print-only-one-property-of-an-object-that-is-within-an-an-array-attribute-as-wel",
        "title": "Print only one property of an object that is within an an array attribute as well as a property that is a sibling to the array property in jq"
    },
    {
        "tags": [
            "json",
            "linux",
            "bash",
            "go",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 47502,
                    "reputation": 213658,
                    "user_id": 140750,
                    "user_type": "registered",
                    "accept_rate": 92,
                    "profile_image": "https://www.gravatar.com/avatar/4c7af12cad08c95bc206a9636d164224?s=256&d=identicon&r=PG",
                    "display_name": "William Pursell",
                    "link": "https://stackoverflow.com/users/140750/william-pursell"
                },
                "edited": false,
                "score": 4,
                "creation_date": 1602389469,
                "post_id": 64300498,
                "comment_id": 113702394,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 247912,
                    "reputation": 3966,
                    "user_id": 522962,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/46a4df8cd89c9f2feb1a36346f8d7a6f?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "user_78361084",
                    "link": "https://stackoverflow.com/users/522962/user-78361084"
                },
                "reply_to_user": {
                    "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": 0,
                "creation_date": 1602389690,
                "post_id": 64300498,
                "comment_id": 113702417,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 247912,
                    "reputation": 3966,
                    "user_id": 522962,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/46a4df8cd89c9f2feb1a36346f8d7a6f?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "user_78361084",
                    "link": "https://stackoverflow.com/users/522962/user-78361084"
                },
                "reply_to_user": {
                    "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": 0,
                "creation_date": 1602389914,
                "post_id": 64300498,
                "comment_id": 113702445,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1260595,
                    "reputation": 8072,
                    "user_id": 1218985,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/ogY2u.jpg?s=256",
                    "display_name": "1218985",
                    "link": "https://stackoverflow.com/users/1218985/1218985"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1602389998,
                "post_id": 64300498,
                "comment_id": 113702458,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 247912,
                    "reputation": 3966,
                    "user_id": 522962,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/46a4df8cd89c9f2feb1a36346f8d7a6f?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "user_78361084",
                    "link": "https://stackoverflow.com/users/522962/user-78361084"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1602390075,
                "post_id": 64300498,
                "comment_id": 113702464,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 247912,
                    "reputation": 3966,
                    "user_id": 522962,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/46a4df8cd89c9f2feb1a36346f8d7a6f?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "user_78361084",
                    "link": "https://stackoverflow.com/users/522962/user-78361084"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1602390152,
                "post_id": 64300498,
                "comment_id": 113702472,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 247912,
                    "reputation": 3966,
                    "user_id": 522962,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/46a4df8cd89c9f2feb1a36346f8d7a6f?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "user_78361084",
                    "link": "https://stackoverflow.com/users/522962/user-78361084"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1602390338,
                "post_id": 64300498,
                "comment_id": 113702496,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 468289,
                    "reputation": 190915,
                    "user_id": 874188,
                    "user_type": "registered",
                    "accept_rate": 62,
                    "profile_image": "https://www.gravatar.com/avatar/091f411d57db5be8298e057a32e5ad72?s=256&d=identicon&r=PG",
                    "display_name": "tripleee",
                    "link": "https://stackoverflow.com/users/874188/tripleee"
                },
                "edited": false,
                "score": 3,
                "creation_date": 1602403126,
                "post_id": 64300498,
                "comment_id": 113704652,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 247912,
                    "reputation": 3966,
                    "user_id": 522962,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/46a4df8cd89c9f2feb1a36346f8d7a6f?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "user_78361084",
                    "link": "https://stackoverflow.com/users/522962/user-78361084"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1602433435,
                "post_id": 64300498,
                "comment_id": 113712402,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1602392105,
                "creation_date": 1602392105,
                "answer_id": 64300724,
                "question_id": 64300498,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use io.Pipe() which basically creates a synchronous in-memory pipe and it can be used to connect code expecting an io.Reader with code expecting an io.Writer. For instance, if you have a json content like this:\r\n\r\n```JSON\r\n{\r\n  &quot;fruits&quot;: [\r\n    &quot;apples&quot;,\r\n    &quot;oranges&quot;,\r\n    &quot;pears&quot;\r\n  ]\r\n}\r\n```\r\n\r\nYou can try something like this:\r\n\r\n```go\r\npackage main\r\n\r\nimport (\r\n\t&quot;bytes&quot;\r\n\t&quot;io&quot;\r\n\t&quot;os&quot;\r\n\t&quot;os/exec&quot;\r\n)\r\n\r\nfunc main() {\r\n\tc1 := exec.Command(&quot;cat&quot;, &quot;/home/fruits.json&quot;)\r\n\tc2 := exec.Command(&quot;jq&quot;, &quot;.fruits[0:2]&quot;)\r\n\r\n\tr, w := io.Pipe()\r\n\tc1.Stdout = w\r\n\tc2.Stdin = r\r\n\r\n\tvar b2 bytes.Buffer\r\n\tc2.Stdout = &amp;b2\r\n\r\n\tc1.Start()\r\n\tc2.Start()\r\n\tc1.Wait()\r\n\tw.Close()\r\n\tc2.Wait()\r\n\tio.Copy(os.Stdout, &amp;b2)\r\n}\r\n\r\n```\r\nIt will gives you something like this:\r\n\r\n```JSON\r\n[\r\n  &quot;apples&quot;,\r\n  &quot;oranges&quot;\r\n]\r\n```\r\n\r\nEven though you can pipe several commands like this, I would strongly recommend to use the [json][1] package from standard library to Marshal and Unmarshal JSON.\r\n\r\n\r\n  [1]: https://golang.org/pkg/encoding/json/",
                "title": "How do I safely run a jq command with a | (pipe) character?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1602433489,
        "creation_date": 1602389083,
        "last_edit_date": 1602433489,
        "question_id": 64300498,
        "body_markdown": "I have program that lets users parse JSON data with jq. I am shelling out to jq rather than using a library because the ones I&#39;ve found have weird and inconsistent behaviour. The problem I have is that jq often has `|` (pipe) characters and, that could potentially let users run non-jq commands. e.g.:\r\n\r\n`jq . | rm file.txt`\r\n\r\nHow do I safely let users run this?\r\n\r\n\r\nRight now, I invoke it as this in Go (where file.txt contains the raw json):\r\n\r\n```\r\ncmd = exec.Command(&quot;bash&quot;, &quot;-c&quot;, fmt.Sprintf(&quot;cat file.txt | %s&quot;, cmd))\r\n```\r\n\r\nThanks!\r\n\r\nEDIT:\r\nAs pointed out several times, this question isn&#39;t about piping commands together. It is about how to safely execute a jq command that has pipes in it. I don&#39;t want users to do this: curl &#39;api.icndb.com/jokes/random/3&#39; | jq -r &#39;.value[] | .joke | rm file.txt&#39;. Please re-open.\r\n",
        "link": "https://stackoverflow.com/questions/64300498/how-do-i-safely-run-a-jq-command-with-a-pipe-character",
        "title": "How do I safely run a jq command with a | (pipe) character?"
    },
    {
        "tags": [
            "jq",
            "jmespath"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1616911856,
                "creation_date": 1616911856,
                "answer_id": 66838834,
                "question_id": 64308650,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "**people[?general.id !=`100`] || people**\r\n\r\n    {\r\n      &quot;people&quot;: [\r\n        {\r\n          &quot;general&quot;: {\r\n            &quot;id&quot;: 100,\r\n            &quot;age&quot;: 20,\r\n            &quot;other&quot;: &quot;foo&quot;,\r\n            &quot;name&quot;: &quot;Bob&quot;\r\n          },\r\n          &quot;history&quot;: {\r\n            &quot;first_login&quot;: &quot;2014-01-01&quot;,\r\n            &quot;last_login&quot;: &quot;2014-01-02&quot;\r\n          }\r\n        },\r\n        {\r\n          &quot;general&quot;: {\r\n            &quot;id&quot;: 101,\r\n            &quot;age&quot;: 30,\r\n            &quot;other&quot;: &quot;bar&quot;,\r\n            &quot;name&quot;: &quot;Bill&quot;\r\n          },\r\n          &quot;history&quot;: {\r\n            &quot;first_login&quot;: &quot;2014-05-01&quot;,\r\n            &quot;last_login&quot;: &quot;2014-05-02&quot;\r\n          }\r\n        }\r\n      ]\r\n    }\r\n\r\nif else condition works here\r\n",
                "title": "Conditional if/then/else for JMESPath?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1638565036,
                "last_edit_date": 1638565036,
                "creation_date": 1637799671,
                "answer_id": 70104488,
                "question_id": 64308650,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It is possible but not cleanly. The general form is to:\r\n1. Make the value you are testing an array (wrap in square braces)\r\n2. Apply the map function to map the filtered array to what value you want if true\r\n3. At this point you have an array that is populated with one (true) item if the array filter passed, otherwise it is empty\r\n3. Concat to that array one item (the false value)\r\n4. Finally, take item at index 0 in this array - which will be the result of the condition\r\n\r\nThis should allow you to also derive possible transformations for both the false and true conditions\r\n\r\nFor example, if the test data is as so:\r\n````\r\n{\r\n   &quot;test&quot;: 11\r\n}\r\n````\r\n\r\nDepending on the value you can get either produce the results (using test data 11 and 2 as example):\r\n\r\n - &quot;Yes, the value is 11 which is greater than 10&quot; \r\n - **OR**\r\n - &quot;No the value is 2 which is less than or equal to 10&quot;\r\n\r\nLike so:\r\n````\r\n[\r\n    map(\r\n        &amp;join(&#39; &#39;, [&#39;Yes, the value is&#39;, to_string(@), &#39;which is greater than 10&#39;]), \r\n        [test][? @ &gt; `10`]\r\n    ), \r\n    join(&#39; &#39;, [&#39;No the value is&#39;, to_string(test), &#39; which is less than or equal to 10&#39;])\r\n][] | @[0]\r\n````\r\n\r\nSo to abstract a template:\r\n\r\n````\r\n[\r\n    map(\r\n        &amp;&lt;True Expression Here&gt;, \r\n        [&lt;Expression you are testing&gt;][? @ &lt;Test Expression&gt;]\r\n    ), \r\n    &lt;False Expression Here&gt;)\r\n][] | @[0]\r\n````\r\n",
                "title": "Conditional if/then/else for JMESPath?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1725127953,
                "creation_date": 1725127953,
                "answer_id": 78935813,
                "question_id": 64308650,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Input\r\n\r\n    {\r\n      &quot;SubscriptionId&quot;: 2,\r\n      &quot;CustomerId&quot;: 234,\r\n      &quot;ShowContractIn&quot;: &quot;Monthly&quot;,\r\n      &quot;AnnualCost&quot;: 1200.00,\r\n      &quot;MonthlyCost&quot;: 100.00 \r\n    }\r\n\r\nTransformation\r\n\r\n    {\r\n      ContractCost: ShowContractIn == &#39;Monthly&#39; &amp;&amp; MonthlyCost || AnnualCost\r\n    }\r\n\r\nOutput\r\n\r\n    {\r\n      &quot;ContractCost&quot;: 100.00\r\n    }\r\n\r\ntaken from \r\n[enter link description here][1]\r\n\r\n\r\n  [1]: https://support.templafy.com/hc/en-us/articles/14297914575005-How-to-use-JMESPath-for-External-Data-Source-Transformation",
                "title": "Conditional if/then/else for JMESPath?"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 4,
        "last_activity_date": 1725127953,
        "creation_date": 1602447793,
        "question_id": 64308650,
        "body_markdown": "Am trying to do a simple if/then/else using JMESPath\r\n\r\nFor example: &#39;if the input is a string, return the string, else return the &quot;value&quot; property of the input&#39;. An input of `&quot;abc&quot;` would return `&quot;abc&quot;`. An input of `{&quot;value&quot;:&quot;def&quot;}` would return `&quot;def&quot;`\r\n\r\n\r\nWith `jq` this is easy: `if .|type == &quot;string&quot; then . else .value end`\r\n\r\nWith JMESPath, I can get the type\r\n\r\n`type(@)`\r\n\r\nor the input:\r\n\r\n`@`\r\n\r\nor the `value` property:\r\n\r\n`value`\r\n\r\nbut I have not found a way to combine them into an if-then-else. Is there any way to do this?",
        "link": "https://stackoverflow.com/questions/64308650/conditional-if-then-else-for-jmespath",
        "title": "Conditional if/then/else for JMESPath?"
    },
    {
        "tags": [
            "bash",
            "jq",
            "yq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 15538452,
                    "reputation": 63,
                    "user_id": 11210009,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/OFKSi.jpg?s=256",
                    "display_name": "lukashino",
                    "link": "https://stackoverflow.com/users/11210009/lukashino"
                },
                "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": 1602501261,
                "post_id": 64316280,
                "comment_id": 113731049,
                "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": 1602501306,
                "post_id": 64316280,
                "comment_id": 113731067,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 15538452,
                    "reputation": 63,
                    "user_id": 11210009,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/OFKSi.jpg?s=256",
                    "display_name": "lukashino",
                    "link": "https://stackoverflow.com/users/11210009/lukashino"
                },
                "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": 1602505443,
                "post_id": 64316280,
                "comment_id": 113733004,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1602500641,
                "creation_date": 1602500641,
                "answer_id": 64316588,
                "question_id": 64316280,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Well I came up with this python3 one-liner that serves my intentions so far but if anyone know more robust solutions I am happy to accept it.\r\n\r\n```\r\npython3 -c &#39;from sys import argv; print(&quot;.&quot; + argv[1].replace(&quot;.&quot;, &quot;\\&quot;][\\&quot;&quot;)[2:] + &quot;\\&quot;]&quot;)&#39; &quot;.cars.big-trucks&quot;\r\n```\r\nreturns \\\r\n.[&quot;cars&quot;][&quot;big-trucks&quot;]",
                "title": "YQ/JQ special characters query convertor"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1602501274,
        "creation_date": 1602499411,
        "last_edit_date": 1602501274,
        "question_id": 64316280,
        "body_markdown": "I am using yq together with jq and as I have learned you need to &quot;escape&quot; special characters in keys to quotes and brackets.\r\nI would like to query the data using the pure dot syntax .cars.big-trucks but I was unable to find any tool that would do the conversion for me.\r\n\r\nMy ideal usage would be:\r\n```\r\nquery=$(jq-query-convert &quot;.cars.big-trucks&quot;)\r\nyq -r $query cars.yaml\r\n```\r\n\r\nAny ideas? Thanks\r\n\r\nExample yaml file:\r\n```\r\n%YAML 1.1\r\n---\r\n\r\ncars:\r\n    big-trucks: 42\r\n```\r\n\r\nFor jq users an example json would be:\r\n```\r\n{\r\n &quot;cars&quot;: {\r\n  &quot;big-trucks&quot;: 42\r\n }\r\n}\r\n```\r\nqueried by \r\n```\r\ncat cars.json | jq &quot;$q&quot;",
        "link": "https://stackoverflow.com/questions/64316280/yq-jq-special-characters-query-convertor",
        "title": "YQ/JQ special characters query convertor"
    },
    {
        "tags": [
            "json",
            "csv",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1602558063,
                "last_edit_date": 1602558063,
                "creation_date": 1602552275,
                "answer_id": 64327224,
                "question_id": 64326827,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "In order to reuse a value of the upper level, like the `timestamp`, for every item of the `rssiSignature` array, you can define it as a variable. You can get your csv like this:\r\n\r\n```bash\r\njq -r &#39;.timestamp as $t | .transmitterId as $tid |\r\n       .rssiSignature[] | [ $t, $tid, .receiverId, .rssi] | @csv\r\n      &#39; file.json\r\n```\r\n\r\nOutput:\r\n\r\n```none\r\n1574228579837,&quot;30451155eda2&quot;,&quot;001bc509408201d5&quot;,-52\r\n1574228579837,&quot;30451155eda2&quot;,&quot;001bc50940820228&quot;,-85\r\n```\r\n&lt;hr&gt;\r\n\r\nAlso here is an way to print headers for an output file in `bash`, independent of what commands we call, using [commands grouping][1].\r\n\r\n```bash\r\n(\r\nprintf &quot;timestamp,transmitterId,receiverId,rssi\\n&quot;\r\njq -r &#39;.timestamp as $t | .transmitterId as $tid |\r\n       .rssiSignature[] | [ $t, $tid, .receiverId, .rssi] | @csv\r\n      &#39; file.json\r\n) &gt; output.csv\r\n```\r\n\r\n  [1]: https://www.gnu.org/software/bash/manual/html_node/Command-Grouping.html",
                "title": "Nested array in JSON to different rows in CSV"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1602556865,
                "last_edit_date": 1602556865,
                "creation_date": 1602553202,
                "answer_id": 64327313,
                "question_id": 64326827,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Actually, the task can be accomplished without the use of any variables; one can also coax jq to include a header:\r\n\r\n```\r\njq -r &#39;\r\n  [&quot;timestamp&quot;,&quot;transmitterId&quot;,&quot;receiverId&quot;,&quot;rssi&quot;],\r\n   [.timestamp, .transmitterId] + (.rssiSignature[] | [.receiverId,.rssi])\r\n  | @csv&#39;\r\n```\r\n\r\n### A single header with multiple files\r\n\r\nOne way to produce a single header with multiple input files would be to use `inputs` in conjunction with the `-n` command-line option. This happens also to be efficient:\r\n```\r\njq -nr &#39;\r\n[&quot;timestamp&quot;,&quot;transmitterId&quot;,&quot;receiverId&quot;,&quot;rssi&quot;],\r\n (inputs |\r\n  [.timestamp, .transmitterId] + (.rssiSignature[] | [.receiverId,.rssi]))\r\n| @csv&#39;\r\n```\r\n",
                "title": "Nested array in JSON to different rows in CSV"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1602558063,
        "creation_date": 1602547438,
        "last_edit_date": 1602552481,
        "question_id": 64326827,
        "body_markdown": "I have the following JSON:\r\n```json\r\n{\r\n  &quot;transmitterId&quot;: &quot;30451155eda2&quot;,\r\n  &quot;rssiSignature&quot;: [\r\n    {\r\n      &quot;receiverId&quot;: &quot;001bc509408201d5&quot;,\r\n      &quot;receiverIdType&quot;: 1,\r\n      &quot;rssi&quot;: -52,\r\n      &quot;numberOfDecodings&quot;: 5,\r\n      &quot;rssiSum&quot;: -52\r\n    },\r\n    {\r\n      &quot;receiverId&quot;: &quot;001bc50940820228&quot;,\r\n      &quot;receiverIdType&quot;: 1,\r\n      &quot;rssi&quot;: -85,\r\n      &quot;numberOfDecodings&quot;: 5,\r\n      &quot;rssiSum&quot;: -85\r\n    }\r\n  ],\r\n  &quot;timestamp&quot;: 1574228579837\r\n}\r\n```\r\nI want to convert it to CSV format, where each row corresponds to an entry in `rssiSignature` (I have added the header row for visualization purposes):\r\n```\r\ntimestamp,transmitterId,receiverId,rssi\r\n1574228579837,&quot;30451155eda2&quot;,&quot;001bc509408201d5&quot;,-52\r\n1574228579837,&quot;30451155eda2&quot;,&quot;001bc50940820228&quot;,-85\r\n```\r\nMy current attempt is the following, but I get a single CSV row:\r\n```\r\n$ jq -r &#39;[.timestamp, .transmitterId, .rssiSignature[].receiverId, .rssiSignature[].rssi] | @csv&#39; test.jsonl\r\n1574228579837,&quot;30451155eda2&quot;,&quot;001bc509408201d5&quot;,&quot;001bc50940820228&quot;,-52,-85\r\n```\r\nHow can I use jq to generate different rows for each entry of the `rssiSignature` array?",
        "link": "https://stackoverflow.com/questions/64326827/nested-array-in-json-to-different-rows-in-csv",
        "title": "Nested array in JSON to different rows in CSV"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 4663062,
                    "reputation": 89888,
                    "user_id": 3776858,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Cagbk.jpg?s=256",
                    "display_name": "Cyrus",
                    "link": "https://stackoverflow.com/users/3776858/cyrus"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1602572463,
                "post_id": 64329995,
                "comment_id": 113754758,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1602572487,
                "creation_date": 1602572487,
                "answer_id": 64330164,
                "question_id": 64329995,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`cat 1.json | jq -r &#39;.data.activeTargets[] | select(.discoveredLabels.__address__ == &quot;prometheus.1.de&quot;) | .health&#39;`",
                "title": "get value based on another subelement"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1602573495,
        "creation_date": 1602571745,
        "last_edit_date": 1602573495,
        "question_id": 64329995,
        "body_markdown": "I have the following JSON file from which I want to get the value of `health`, which is `up`.\r\nThe result should be based on the `__address__`.\r\n\r\n    {\r\n      &quot;status&quot;: &quot;success&quot;,\r\n      &quot;data&quot;: {\r\n        &quot;activeTargets&quot;: [\r\n          {\r\n            &quot;discoveredLabels&quot;: {\r\n              &quot;__address__&quot;: &quot;prometheus.1.de&quot;,\r\n              &quot;__metrics_path__&quot;: &quot;/federate&quot;,\r\n              &quot;__param_match[]&quot;: &quot;{job=~\\&quot;.*\\&quot;}&quot;,\r\n              &quot;__scheme__&quot;: &quot;http&quot;,\r\n              &quot;job&quot;: &quot;federate&quot;\r\n            },\r\n            &quot;labels&quot;: {\r\n              &quot;instance&quot;: &quot;prometheus.1.de:80&quot;,\r\n              &quot;job&quot;: &quot;federate&quot;\r\n            },\r\n            &quot;scrapePool&quot;: &quot;federate&quot;,\r\n            &quot;scrapeUrl&quot;: &quot;http://prometheus.1.de:80/federate?match%5B%5D=%7Bjob%3D~%22.%2A%22%7D&quot;,\r\n            &quot;globalUrl&quot;: &quot;http://prometheus.1.de:80/federate?match%5B%5D=%7Bjob%3D~%22.%2A%22%7D&quot;,\r\n            &quot;lastError&quot;: &quot;&quot;,\r\n            &quot;lastScrape&quot;: &quot;2020-10-13T06:35:59.96463521Z&quot;,\r\n            &quot;lastScrapeDuration&quot;: 3.339807114,\r\n            &quot;health&quot;: &quot;up&quot;\r\n          },\r\n          {\r\n            &quot;discoveredLabels&quot;: {\r\n              &quot;__address__&quot;: &quot;localhost:9090&quot;,\r\n              &quot;__metrics_path__&quot;: &quot;/metrics&quot;,\r\n              &quot;__scheme__&quot;: &quot;http&quot;,\r\n              &quot;job&quot;: &quot;prometheus&quot;\r\n            },\r\n            &quot;labels&quot;: {\r\n              &quot;instance&quot;: &quot;localhost:9090&quot;,\r\n              &quot;job&quot;: &quot;prometheus&quot;\r\n            },\r\n            &quot;scrapePool&quot;: &quot;prometheus&quot;,\r\n            &quot;scrapeUrl&quot;: &quot;http://localhost:9090/metrics&quot;,\r\n            &quot;globalUrl&quot;: &quot;http://prometheus-2:9090/metrics&quot;,\r\n            &quot;lastError&quot;: &quot;&quot;,\r\n            &quot;lastScrape&quot;: &quot;2020-10-13T06:35:53.366524719Z&quot;,\r\n            &quot;lastScrapeDuration&quot;: 0.005405697,\r\n            &quot;health&quot;: &quot;up&quot;\r\n          }\r\n        ],\r\n        &quot;droppedTargets&quot;: []\r\n      }\r\n    }\r\n\r\n\r\ni tried this: \r\n```\r\n$ cat 1.json | jq -r &#39;.data.activeTargets[] | .health |= map(select(.discoveredLabels.__address__ == &quot;prometheus.1.de&quot;))&#39;\r\njq: error (at &lt;stdin&gt;:0): Cannot iterate over string (&quot;up&quot;)\r\n```\r\nany tips?\r\n\r\n",
        "link": "https://stackoverflow.com/questions/64329995/get-value-based-on-another-subelement",
        "title": "get value based on another subelement"
    },
    {
        "tags": [
            "curl",
            "jq",
            "substitution",
            "fish"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1602599913,
                "creation_date": 1602599913,
                "answer_id": 64337373,
                "question_id": 64330473,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I find the nested `set` confusing. Did you intend to do use $location to hold the downloaded JSON data, and $address to hold the results of jq? If yes, split them out into separate statements\r\n\r\n```fish\r\nset url &quot;https://us1.locationiq.com/v1/reverse.phpkey=$key&amp;lat=$exifLat&amp;lon=$exifLon&amp;format=json&quot;\r\nset location (curl -s $url)\r\nset address (echo $location | jq --raw-output  &#39;.address.state,.address.city&#39;)\r\n```",
                "title": "Fish Shell | Command Substitution using curl and JSON for variable assignment"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1602599913,
        "creation_date": 1602573844,
        "question_id": 64330473,
        "body_markdown": "I cannot find any doc for Fish Shell regarding using Command Substitution more than once.\r\n\r\nI&#39;m trying to assign the state, city from the JSON result set (jq parser) piped from a curl API query of LocationIQ.  2 Command Substitution 1:(curl) and 2:(jq).  I don&#39;t need the location variable assignment if I can get the address variable assignment\r\n\r\nPurpose of Function:\r\n#Take 2 arguments (Latitude, Longitude) and return 2 variables $State, $City\r\n\r\n**The JSON:**\r\n\r\n    {\r\n      &quot;address&quot;: {\r\n        &quot;city&quot;: &quot;Aurora&quot;,\r\n        &quot;country&quot;: &quot;United States of America&quot;,\r\n        &quot;country_code&quot;: &quot;us&quot;,\r\n        &quot;county&quot;: &quot;Kane County&quot;,\r\n        &quot;postcode&quot;: &quot;60504&quot;,\r\n        &quot;road&quot;: &quot;Ridge Road&quot;,\r\n        &quot;state&quot;: &quot;Illinois&quot;\r\n      },\r\n      &quot;boundingbox&quot;: [\r\n        &quot;41.729347&quot;,\r\n        &quot;41.730247&quot;,\r\n        &quot;-88.264466&quot;,\r\n        &quot;-88.261979&quot;\r\n      ],\r\n      &quot;display_name&quot;: &quot;Ridge Road, Aurora, Kane County, Illinois, 60504, USA&quot;,\r\n      &quot;importance&quot;: 0.2,\r\n      &quot;lat&quot;: &quot;41.729476&quot;,\r\n      &quot;licence&quot;: &quot;https://locationiq.com/attribution&quot;,\r\n      &quot;lon&quot;: &quot;-88.263423&quot;,\r\n      &quot;place_id&quot;: &quot;333878957973&quot;\r\n    }\r\n\r\n\r\n**My Function:**\r\n\r\n    function getLocation            \r\n       set key &#39;hidden&#39;\r\n       set exifLat $argv[1]\r\n       set exifLon $argv[2]\r\n       set location (curl -s &quot;https://us1.locationiq.com/v1/reverse.phpkey=$key&amp;lat=$exifLat&amp;lon=$exifLon&amp;format=json&quot; | set address (jq --raw-output  &#39;.address.state,.address.city&#39;) )\r\n       \r\n       echo &quot;Location: $location\r\n       echo &quot;state:    $address[1]&quot;\r\n       echo &quot;city:     $address[2]&quot;\r\n    end\r\n\r\n\r\n\r\n&gt; **Error**: fish Command substitution not allowed\r\n\r\nWorks fine using only the curl Command substitution -&gt;removing the: set address &amp; parens for jq.\r\n\r\n    set location (curl -s &quot;https://us1.locationiq.com/v1/reverse.phpkey=$key&amp;lat=$exifLat&amp;lon=$exifLon&amp;format=json&quot; | jq --raw-output  &#39;.address.state,.address.city&#39;)\r\n\r\nI&#39;m still pretty novice - maybe there is a better way to achieve my desired result: Assign the JSON State to a variable and City to a variable?\r\n\r\nI originally tried (slicing the location[17] - City, location[19] - State) and getting inconsistent results as the fields seem to be dynamic and affecting how many results which affects the ordering.\r\n\r\nAny help appreciated!",
        "link": "https://stackoverflow.com/questions/64330473/fish-shell-command-substitution-using-curl-and-json-for-variable-assignment",
        "title": "Fish Shell | Command Substitution using curl and JSON for variable assignment"
    },
    {
        "tags": [
            "json",
            "performance",
            "schema",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1602828385,
                "last_edit_date": 1602828385,
                "creation_date": 1602618231,
                "answer_id": 64342130,
                "question_id": 64340429,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using `inputs` is the way to go, whether or not any parallelization techniques are brought to bear.  \r\n\r\nIn the jq module for inducing structural schema that I wrote some time ago (https://gist.github.com/pkoppstein/a5abb4ebef3b0f72a6ed), there&#39;s a filter, `schema/1` defined as:\r\n```\r\ndef schema(stream):\r\n  reduce stream as $x (&quot;null&quot;;  typeUnion(.; $x|typeof));\r\n```\r\n\r\nThis can therefore be used as suggested by this snippet:\r\n```\r\njq -n &#39;include &quot;schema&quot;; schema(inputs)&#39; FILESPECIFICATIONS\r\n```\r\n(This assumes that the file &quot;schema.jq&quot; defining the `schema` module has been appropriately installed.)\r\n\r\nThe point here is not so much that schema.jq might be adapted to your particular expectations, but that the above &quot;def&quot; can serve as a guide (whether or not using jq) for how to write an efficient schema-inference engine, in the sense of being able to handle a very large number of instances.  That is, you basically have only to write a definition of `typeof` (which should yield the desired &quot;type&quot; in the most general sense), and of `typeUnion` (which defines how two types are to be combined).\r\n\r\nOf course, inferring schemas can be a tricky business. In particular, `schema(stream)` will never fail, assuming the inputs are valid JSON.  That is, whether or not the inferred schema will be useful depends largely on how it is used.  I find that an integrated approach based on these elements to be essential:\r\n\r\n1. a schema specification language;\r\n2. a schema inference engine that generates schemas that conform to (1);\r\n\r\n3. a schema-checker.\r\n\r\n## Further thoughts\r\n`schema.jq` is simple enough to be tailored to more specific requirements, e.g. to infer dates.\r\n\r\nYou might be interested in JESS (&quot;JSON Extended Structural Schemas&quot;), which combines a JSON-based specification language with jq-oriented tools: https://github.com/pkoppstein/JESS\r\n\r\n\r\n",
                "title": "Inducing a schema using jq more efficiently"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1602828385,
        "creation_date": 1602611002,
        "last_edit_date": 1602819870,
        "question_id": 64340429,
        "body_markdown": "I ingest a lot of data. It comes from lots of different sources, and all ultimately goes into BigQuery. \r\n\r\nI preparse into .jsonl file(s) — 1 line per record, named by destination table.\r\n\r\nFor a rough sense of scale, here&#39;s a sample from a dataset I&#39;m doing now. (All the data below is real, just lightly redacted / cleaned up.)\r\n\r\n```bash\r\n% find json -type f -size +2000c -print0 | head -z | sort |  wc --files0-from=-\r\n  2   387   4737 json/baz_1.jsonl\r\n  3   579   7055 json/baz_2.jsonl\r\n  1   193   2358 json/baz_3.jsonl\r\n 25  4835  58958 json/baz_4.jsonl\r\n 37  7161  87467 json/baz_5.jsonl\r\n  3   580   7072 json/baz_6.jsonl\r\n 15  2897  35393 json/baz_7.jsonl\r\n129 24950 304262 json/baz_8.jsonl\r\n  3   373   4221 json/foo_1.jsonl\r\n  6   746   8491 json/foo_2.jsonl\r\n224 42701 520014 total\r\n\r\n% wc -l *.jsonl\r\n    11576 foos.jsonl\r\n       20 bars.jsonl\r\n   337770 bazzes.jsonl\r\n   349366 total\r\n\r\n% du -m *.jsonl\r\n 3      foos.jsonl\r\n 1      bars.jsonl\r\n93      bazzes.jsonl\r\n```\r\n\r\nThis is relatively small for me. Other datasets are in the millions of rows / terabytes of data range.\r\n\r\nBecause the data comes from external sources, often undocumented, often not matching specs or just plain messy (e.g. various signal values for null, multiple date formats in the same field, etc), I don&#39;t really know the structure beforehand.\r\n\r\nHowever, I want to have a nice, clean, efficient structure in my destination table — e.g. cast to the correct type like integer/bool/date, set `REQUIRED`/`NULLABLE` correctly, know which columns are actually enums, convert stringified arrays into `REPEATED` columns, have a good guess on what I can use effectively for partitioning / clustering, etc. etc.\r\n\r\nIt inevitably requires some manual work on samples to infer what&#39;s actually going on, but my first pass for doing this is `jq` (version 1.6).\r\n\r\nThis is my current code:\r\n\r\n`~/.jq`\r\n```jq\r\ndef isempty(v):\r\n (v == null or v == &quot;&quot; or v == [] or v == {});\r\n\r\ndef isnotempty(v):\r\n (isempty(v) | not);\r\n\r\ndef remove_empty:\r\n  walk(\r\n   if type == &quot;array&quot; then\r\n      map(select(isnotempty(.)))\r\n   elif type == &quot;object&quot; then\r\n      with_entries(select(isnotempty(.value))) # Note: this will remove keys with empty values\r\n   else .\r\n   end\r\n  );\r\n\r\n# bag of words\r\ndef bow(stream):\r\n  reduce stream as $word ({}; .[($word|tostring)] += 1);\r\n\r\n# https://stackoverflow.com/questions/46254655/how-to-merge-json-objects-by-grouping-on-key-with-jq\r\ndef add_by(f):\r\n  reduce .[] as $x ({}; ($x|f) as $f | .[$f] += [$x])\r\n  | [.[] | add];\r\n\r\n# takes array of {string: #, ...}\r\ndef merge_counts:\r\n  map(.|to_entries)|flatten | add_by(.key)|from_entries;\r\n```\r\n\r\n`induce_schema.sh` (linebreaks added)\r\n```zsh\r\n#!/bin/zsh\r\n\r\npv -cN ingestion -s `wc -l $1` -l $1 | \\\r\njq  -c --unbuffered --stream &#39;{&quot;name&quot;: ( .[0]), &quot;encoded_type&quot;:( .[1] | type),  \\\r\n   &quot;tonumber&quot;: (.[1] |  if (type == &quot;string&quot;) then try(tonumber|type) catch type else null end), \\\r\n   &quot;chars&quot;: (.[1] | if(type==&quot;string&quot;) then try(split(&quot;&quot;) | sort | unique | join(&quot;&quot;)) else null end), \\\r\n   &quot;length&quot;:(.[1] | length),&quot;data&quot;:.[1]}&#39; |  \\\r\n# sed -r &#39;s/[0-9]+(,|])/&quot;array&quot;\\1/g&#39; | awk &#39;!_[$0]++&#39; | sort | \\\r\npv -cN grouping -l | \\\r\njq -sc &#39;. | group_by(.name,.encoded_type,.tonumber)[] | {&quot;name&quot;:first|.name, \\ \r\n   &quot;encoded_type&quot;:([(first|.encoded_type),(first|.tonumber)]|unique - [null]|join(&quot;_&quot;)), \\\r\n   &quot;allchars&quot;: (map(.chars) | join(&quot;&quot;)|split(&quot;&quot;)|sort|unique|join(&quot;&quot;)), \\\r\n   &quot;count_null&quot;: (map(.data | select(.==null)) | length), \\\r\n   &quot;count_empty&quot;: (map(.data | select(.==[] or . == {} or . == &quot;&quot;)) | length), \\\r\n   &quot;count_nonempty&quot;: (map(.data | select(. != null and . != &quot;&quot;)) |length), \\\r\n   &quot;unique&quot;: (map(.data)|unique|length), &quot;length&quot;: bow(.[] | .length)  }&#39; | \\\r\npv -cN final -l | \\\r\njq -sc &#39;. | group_by(.name)[] | {&quot;name&quot;:first|.name, \\\r\n   &quot;nullable&quot;:(map(.encoded_type) | contains([&quot;null&quot;])), \\\r\n   &quot;schemas_count&quot;:(map(. | select(.encoded_type != &quot;null&quot;) )|length), \\\r\n   &quot;lengths&quot;:(map(.length)|merge_counts), &quot;total_nonempty&quot;:(map(.count_nonempty)|add), \\\r\n   &quot;total_null&quot;:(map(.count_null)|add), &quot;total_empty&quot;: (map(.count_empty) |add), \\\r\n   &quot;schemas&quot;:map(. | select(.encoded_type != &quot;null&quot;) | del(.name) )}&#39;\r\n```\r\n\r\nHere&#39;s a partial output for `bars.jsonl` (linebreaks added for ease of reading):\r\n```json\r\n{&quot;name&quot;:[&quot;FILING CODE&quot;],&quot;nullable&quot;:false,&quot;schemas_count&quot;:1,\r\n &quot;lengths&quot;:{&quot;0&quot;:1930,&quot;2&quot;:16},\r\n &quot;total_nonempty&quot;:16,&quot;total_null&quot;:0,&quot;total_empty&quot;:1930,\r\n &quot;schemas&quot;:[\r\n  {&quot;encoded_type&quot;:&quot;string&quot;,&quot;allchars&quot;:&quot;EGPWX&quot;,\r\n   &quot;count_null&quot;:0,&quot;count_empty&quot;:1930,&quot;count_nonempty&quot;:16,&quot;unique&quot;:6,\r\n   &quot;length&quot;:{&quot;0&quot;:1930,&quot;2&quot;:16}}\r\n ]}\r\n{&quot;name&quot;:[&quot;LAST NAME&quot;],&quot;nullable&quot;:true,&quot;schemas_count&quot;:1,\r\n &quot;lengths&quot;:{&quot;0&quot;:416,&quot;5&quot;:4650,&quot;6&quot;:5648,&quot;7&quot;:4796,&quot;4&quot;:1934,&quot;8&quot;:3042,&quot;9&quot;:1362,&quot;10&quot;:570,&quot;11&quot;:226,&quot;3&quot;:284,&quot;14&quot;:30,&quot;12&quot;:70,&quot;13&quot;:54,&quot;16&quot;:20,&quot;15&quot;:26,&quot;17&quot;:10,&quot;18&quot;:8,&quot;2&quot;:4,&quot;19&quot;:2},\r\n &quot;total_nonempty&quot;:22736,&quot;total_null&quot;:2,&quot;total_empty&quot;:416,\r\n &quot;schemas&quot;:[\r\n  {&quot;encoded_type&quot;:&quot;string&quot;,&quot;allchars&quot;:&quot; ABCDEFGHIJKLMNOPQRSTUVWXYZ&quot;,\r\n   &quot;count_null&quot;:0,&quot;count_empty&quot;:416,&quot;count_nonempty&quot;:22736,&quot;unique&quot;:6233,\r\n   &quot;length&quot;:{&quot;5&quot;:4650,&quot;6&quot;:5648,&quot;7&quot;:4796,&quot;4&quot;:1934,&quot;8&quot;:3042,&quot;9&quot;:1362,&quot;10&quot;:570,&quot;11&quot;:226,&quot;3&quot;:284,&quot;14&quot;:30,&quot;12&quot;:70,&quot;0&quot;:416,&quot;13&quot;:54,&quot;16&quot;:20,&quot;15&quot;:26,&quot;17&quot;:10,&quot;18&quot;:8,&quot;2&quot;:4,&quot;19&quot;:2}}\r\n ]}\r\n{&quot;name&quot;:[&quot;NUMBER OF COFFEES&quot;],&quot;nullable&quot;:false,&quot;schemas_count&quot;:2,\r\n &quot;lengths&quot;:{&quot;1&quot;:16,&quot;0&quot;:4},\r\n &quot;total_nonempty&quot;:16,&quot;total_null&quot;:0,&quot;total_empty&quot;:4,\r\n &quot;schemas&quot;:[\r\n  {&quot;encoded_type&quot;:&quot;number_string&quot;,&quot;allchars&quot;:&quot;1&quot;,\r\n   &quot;count_null&quot;:0,&quot;count_empty&quot;:0,&quot;count_nonempty&quot;:16,&quot;unique&quot;:1,\r\n   &quot;length&quot;:{&quot;1&quot;:16}},\r\n  {&quot;encoded_type&quot;:&quot;string&quot;,&quot;allchars&quot;:&quot;&quot;,\r\n   &quot;count_null&quot;:0,&quot;count_empty&quot;:4,&quot;count_nonempty&quot;:0,&quot;unique&quot;:1,\r\n   &quot;length&quot;:{&quot;0&quot;:4}}\r\n ]}\r\n{&quot;name&quot;:[&quot;OFFICE CODE&quot;],&quot;nullable&quot;:false,&quot;schemas_count&quot;:2,\r\n &quot;lengths&quot;:{&quot;3&quot;:184,&quot;0&quot;:22092},\r\n &quot;total_nonempty&quot;:1036,&quot;total_null&quot;:0,&quot;total_empty&quot;:22092,\r\n &quot;schemas&quot;:[\r\n  {&quot;encoded_type&quot;:&quot;number_string&quot;,&quot;allchars&quot;:&quot;0123456789&quot;,\r\n   &quot;count_null&quot;:0,&quot;count_empty&quot;:0,&quot;count_nonempty&quot;:852,&quot;unique&quot;:254,\r\n   &quot;length&quot;:{&quot;3&quot;:852}}, \r\n  {&quot;encoded_type&quot;:&quot;string&quot;,&quot;allchars&quot;:&quot;0123456789ABCDEIJQRSX&quot;,\r\n   &quot;count_null&quot;:0,&quot;count_empty&quot;:22092,&quot;count_nonempty&quot;:184,&quot;unique&quot;:66,\r\n   &quot;length&quot;:{&quot;0&quot;:22092,&quot;3&quot;:184}}\r\n ]}\r\n{&quot;name&quot;:[&quot;SOURCE FILE&quot;],&quot;nullable&quot;:true,&quot;schemas_count&quot;:1,\r\n &quot;lengths&quot;:{&quot;0&quot;:416,&quot;7&quot;:22708},\r\n &quot;total_nonempty&quot;:22708,&quot;total_null&quot;:23124,&quot;total_empty&quot;:416,\r\n &quot;schemas&quot;:[\r\n  {&quot;encoded_type&quot;:&quot;string&quot;,&quot;allchars&quot;:&quot;0123456789F_efil&quot;,\r\n   &quot;count_null&quot;:0,&quot;count_empty&quot;:416,&quot;count_nonempty&quot;:22708,&quot;unique&quot;:30,\r\n   &quot;length&quot;:{&quot;7&quot;:22708,&quot;0&quot;:416}}\r\n ]}\r\n...\r\n```\r\n\r\n---\r\nThe point of this is to get a summary of &quot;how is this unknown dataset structured and what&#39;s in it&quot; that I can readily transform into my BigQuery table schema / parameters, use to point at what I&#39;ll probably need to do next for turning it into something cleaner &amp; more usable than what I got, etc.\r\n\r\nThis code works, but those `-s` (slurp) lines are really hard on server RAM. (They simply wouldn&#39;t work on if the dataset were any larger than this; I added those parts just today. On the `bazzes` dataset, it uses about 20GB total RAM, including swap.)\r\n\r\nIt also doesn&#39;t detect e.g. any of the date/time [field types](https://cloud.google.com/bigquery/docs/reference/standard-sql/data-types).\r\n\r\nI believe it should be possible to make this far more efficient using @joelpurra&#39;s [jq + parallel](https://github.com/joelpurra/jq-hopkok/tree/master/src/parallelism) and/or the jq cookbook&#39;s [reduce inputs](https://github.com/stedolan/jq/wiki/Cookbook#processing-a-large-number-of-lines-or-json-entities), but I&#39;m having difficulty figuring out how.\r\n\r\nSo, I&#39;d appreciate advice on how to make this \r\n1. more CPU &amp; RAM efficient\r\n2. otherwise more useful (e.g. recognize date fields, which could be in almost any format)",
        "link": "https://stackoverflow.com/questions/64340429/inducing-a-schema-using-jq-more-efficiently",
        "title": "Inducing a schema using jq more efficiently"
    },
    {
        "tags": [
            "json",
            "jq",
            "flatten"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1602625597,
                "creation_date": 1602625597,
                "answer_id": 64343618,
                "question_id": 64343527,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Q.E.D. as follows:\r\n```\r\n.Id as $Id\r\n| .items\r\n| [ range(0; length) as $index_position\r\n   | {$Id} + .[$index_position] + {$index_position} ]\r\n\r\n```\r\n\r\nThe key to brevity (or at least DRY-ness) here is that the jq expression `{$x}` expands to `{&quot;x&quot;: $x}`.",
                "title": "Flatten JSON with Jq with array index in output"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1602625853,
        "creation_date": 1602625091,
        "last_edit_date": 1602625853,
        "question_id": 64343527,
        "body_markdown": "I&#39;m trying to create a single json output based on a nested Json:\r\n\r\n    {\r\n        &quot;Id&quot; : &quot;1&quot;,\r\n        &quot;items&quot; : [\r\n            {&quot;item_name&quot; : &quot;shirt&quot;,&quot;value&quot; : 10},\r\n            {&quot;item_name&quot; : &quot;dress&quot;,&quot;value&quot; : 20},\r\n            {&quot;item_name&quot; : &quot;ice cream&quot;,&quot;value&quot; : 30}\r\n        ] \r\n    }\r\n\r\nMy expected output would be:\r\n```\r\n[\r\n  {\r\n    &quot;id&quot;: &quot;1&quot;,\r\n    &quot;item_name&quot;: &quot;shirt&quot;,\r\n    &quot;value&quot;: 10,\r\n    &quot;index_position&quot;: 0\r\n  },\r\n  {\r\n    &quot;id&quot;: &quot;1&quot;,\r\n    &quot;item_name&quot;: &quot;dress&quot;,\r\n    &quot;value&quot;: 20,\r\n    &quot;index_position&quot;: 1\r\n  },\r\n  {\r\n    &quot;id&quot;: &quot;1&quot;,\r\n    &quot;item_name&quot;: &quot;ice cream&quot;,\r\n    &quot;value&quot;: 30,\r\n    &quot;index_position&quot;: 2\r\n  }\r\n]\r\n```\r\n\r\nThe only output that I was able to fetch is on this snippet:\r\n\r\nhttps://jqplay.org/s/G6mYAI47LE\r\n\r\nWhat would be the best way to iterate over an inner array and at the same time fetch the outer object data?",
        "link": "https://stackoverflow.com/questions/64343527/flatten-json-with-jq-with-array-index-in-output",
        "title": "Flatten JSON with Jq with array index in output"
    },
    {
        "tags": [
            "json",
            "key",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1602713918,
                "post_id": 64360375,
                "comment_id": 113811402,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1602730570,
                "creation_date": 1602730570,
                "answer_id": 64364180,
                "question_id": 64360375,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Assuming the input as shown has been tidied a bit to make it valid JSON, running\r\n```\r\njq -r &#39;\r\n  .update\r\n  | [.operation] + (.restrictions.user.results[] | [.username, .userKey])\r\n  | @csv\r\n&#39;\r\n```\r\nagainst it would yield:\r\n```\r\n&quot;update&quot;,&quot;xxxx&quot;,&quot;yyyyy&quot;\r\n```\r\n\r\n",
                "title": "How to retrieve deep-linked kv pair using jq"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1602772483,
        "creation_date": 1602704168,
        "last_edit_date": 1602772483,
        "question_id": 64360375,
        "body_markdown": "got to this section of json with jq -r &#39;.update[]&#39; now need to find, operation:restrictions:user:results:username,userKey\r\n\r\n    \r\n    &quot;update&quot;: {\r\n    &quot;operation&quot;: &quot;update&quot;,\r\n    &quot;restrictions&quot;: {\r\n      &quot;user&quot;: {\r\n        &quot;results&quot;: [\r\n          {\r\n            &quot;type&quot;: &quot;known&quot;,\r\n            &quot;username&quot;: &quot;xxxx&quot;,\r\n            &quot;userKey&quot;: &quot;yyyyy&quot;,\r\n            &quot;profilePicture&quot;: {\r\n              &quot;path&quot;: &quot;/download/attachments/49710215/user-avatar&quot;,\r\n              &quot;width&quot;: 48,\r\n              &quot;height&quot;: 48,\r\n              &quot;isDefault&quot;: false\r\n            },\r\n            &quot;displayName&quot;: &quot;xxxyyyzzz&quot;,\r\n            &quot;_links&quot;: {\r\n              &quot;self&quot;: &quot;aa&quot;\r\n            },\r\n            &quot;_expandable&quot;: {\r\n              &quot;status&quot;: &quot;&quot;\r\n            }\r\n          },",
        "link": "https://stackoverflow.com/questions/64360375/how-to-retrieve-deep-linked-kv-pair-using-jq",
        "title": "How to retrieve deep-linked kv pair using jq"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1602765484,
                "creation_date": 1602765484,
                "answer_id": 64371753,
                "question_id": 64370295,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Convert the object to an association list with `to_entries`, then construct the desired string using interpolation. The `-r` option produces raw text, rather than JSON-encoded strings.\r\n\r\n    $ jq -r &#39;to_entries[] | &quot;\\(.key) : \\(.value)&quot;&#39; tmp.json\r\n    host1 : 10.1.2.3\r\n    host2 : 10.1.2.2\r\n    host3 : 10.1.18.1\r\n",
                "title": "Reformat JSON key/value pair to a colon separated format using jq"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1602766399,
                "creation_date": 1602766399,
                "answer_id": 64372041,
                "question_id": 64370295,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "An alternate version, not present in the _potentially_ duplicate question linked in the comments. \r\n\r\n    jq -r &#39;keys_unsorted[] as $k | [ $k, .[$k] ] | join(&quot; : &quot;)&#39; \r\n\r\nStore the keys in `$k` and get the value associated with it, and put the results to an array `[..]` and join the array elements by ` : `",
                "title": "Reformat JSON key/value pair to a colon separated format using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1602766399,
        "creation_date": 1602760277,
        "last_edit_date": 1602765247,
        "question_id": 64370295,
        "body_markdown": "I am new to `jq`, I want to convert below data:\r\n\r\n    {\r\n      &quot;host1&quot;: &quot;10.1.2.3&quot; ,\r\n      &quot;host2&quot;:  &quot;10.1.2.2&quot; ,\r\n      &quot;host3&quot;: &quot;10.1.18.1&quot;\r\n    }\r\n\r\nto this below format:\r\n\r\n    host1 : 10.1.2.3\r\n    host2 : 10.1.2.2\r\n    host3 : 10.1.18.1\r\n\r\n",
        "link": "https://stackoverflow.com/questions/64370295/reformat-json-key-value-pair-to-a-colon-separated-format-using-jq",
        "title": "Reformat JSON key/value pair to a colon separated format using jq"
    },
    {
        "tags": [
            "json",
            "bash",
            "select",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 4663062,
                    "reputation": 89888,
                    "user_id": 3776858,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Cagbk.jpg?s=256",
                    "display_name": "Cyrus",
                    "link": "https://stackoverflow.com/users/3776858/cyrus"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1602794293,
                "post_id": 64379263,
                "comment_id": 113840746,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1602796894,
                "creation_date": 1602796894,
                "answer_id": 64379824,
                "question_id": 64379263,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If instead of trying to extract variable names from the JSON, you populate an associate array with the names as keys, it&#39;s pretty straightforward.\r\n\r\n\r\n```sh\r\n#!/usr/bin/env bash\r\n\r\ndeclare -A sauces\r\nwhile IFS=$&#39;\\001&#39; read -r name value; do\r\n    sauces[$name]=$value\r\ndone &lt; &lt;(jq -r &#39;.env_vars[] | &quot;\\(.name)\\u0001\\(.value)&quot;&#39; saucy.json)\r\n\r\nfor name in &quot;${!sauces[@]}&quot;; do\r\n    echo &quot;$name is ${sauces[$name]}&quot;\r\ndone\r\n```\r\n\r\nprints out\r\n\r\n```none\r\nSAUCE_VALUE is sauceValue\r\nSAUCE_KEY is sauceKey\r\n```",
                "title": "select specific values from json &amp; convert into bash variables"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1602800765,
        "creation_date": 1602794042,
        "last_edit_date": 1602800765,
        "question_id": 64379263,
        "body_markdown": "I&#39;m new to jq, I have the following JSON &amp; I need to extract FOUR values i.e. SAUCE_KEY, sauceKey, SAUCE_VALUE, sauceValue etc. And I need to covert these bash variables as i.e.\r\n\r\n    SAUCE_KEY=sauceKey\r\n    SAUCE_VALUE=sauceValue\r\n\r\nIf I will echo it, it should print it&#39;s value ie. echo $SAUCE_KEY\r\n\r\nI have used the code as:\r\n```\r\njq -r &#39;.env_vars[] | with_entries(select([.key] | inside([&quot;.env_vars[].name&quot;, &quot;.env_vars[].value&quot;])))&#39; | jq -r &quot;to_entries|map(\\&quot;\\(.value)=\\(.value|tostring)\\&quot;)|.[]&quot;\r\n```\r\nBy doing so, i was able to get values as\r\nname=SAUCE_KEY, value=sauceKey and so on.\r\n\r\n```\r\n{\r\n  &quot;@type&quot;: &quot;env_vars&quot;,\r\n  &quot;env_vars&quot;: [\r\n    {\r\n      &quot;@type&quot;: &quot;env_var&quot;,\r\n      &quot;@href&quot;: &quot;/repo/xxxxx/env_var/xxxxx&quot;,\r\n      &quot;@representation&quot;: &quot;standard&quot;,\r\n      &quot;@permissions&quot;: {\r\n        &quot;read&quot;: true,\r\n        &quot;write&quot;: true\r\n      },\r\n      &quot;name&quot;: &quot;SAUCE_KEY&quot;,\r\n      &quot;value&quot;: &quot;sauceKey&quot;\r\n    },\r\n    {\r\n      &quot;@type&quot;: &quot;env_var&quot;,\r\n      &quot;@href&quot;: &quot;/repo/xxxxx/env_var/xxxxx&quot;,\r\n      &quot;@representation&quot;: &quot;standard&quot;,\r\n      &quot;@permissions&quot;: {\r\n        &quot;read&quot;: true,\r\n        &quot;write&quot;: true\r\n      },\r\n      &quot;name&quot;: &quot;SAUCE_VALUE&quot;,\r\n      &quot;value&quot;: &quot;sauceValue&quot;\r\n    }\r\n  ]\r\n}\r\n```",
        "link": "https://stackoverflow.com/questions/64379263/select-specific-values-from-json-convert-into-bash-variables",
        "title": "select specific values from json &amp; convert into bash variables"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1602844015,
                "post_id": 64386912,
                "comment_id": 113854763,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 17137162,
                    "reputation": 75,
                    "user_id": 12401927,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/48e5b2b0d3f9c6d2b7b19134a49addeb?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "garima",
                    "link": "https://stackoverflow.com/users/12401927/garima"
                },
                "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": 1602844974,
                "post_id": 64386912,
                "comment_id": 113855176,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1602856847,
                "last_edit_date": 1602856847,
                "creation_date": 1602843565,
                "answer_id": 64387277,
                "question_id": 64386912,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You need to have the header array the required fields in a separate array and put them together in a tabular format using `@tsv`\r\n\r\n    jq -r &#39;[ &quot;name&quot;, &quot;cluster/server&quot;, &quot;status&quot; ], \r\n           ( .data[] | [.name, .type, .status]  ), \r\n           ( .data[].servers[] | [ .name, .type, .status ] ) | @tsv&#39;\r\n\r\nThe requirement was modified since originally posted to have the server information exactly below the cluster information\r\n\r\n    jq -r &#39;[ &quot;name&quot;, &quot;cluster/server&quot;, &quot;status&quot; ],\r\n           ( .data[] | [.name, .type, .status], ( .servers[] | [.name, .type, .status] ) ) | @tsv&#39;",
                "title": "How to print nested JSON array data in a tabular format?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1602858118,
        "creation_date": 1602842113,
        "last_edit_date": 1602858118,
        "question_id": 64386912,
        "body_markdown": "I want to read the status of clusters and servers inside it.\r\n\r\nBelow is the sample json file \r\n\r\n```\r\n&quot;data&quot;: [{\r\n        &quot;id&quot;: 7865,\r\n        &quot;timeCreated&quot;: 1602589399294,\r\n        &quot;timeUpdated&quot;: 1602748892149,\r\n        &quot;name&quot;: &quot;gw-ext-1&quot;,\r\n        &quot;type&quot;: &quot;CLUSTER&quot;,\r\n        &quot;status&quot;: &quot;RUNNING&quot;,\r\n        &quot;multicastEnabled&quot;: false,\r\n        &quot;primaryNodeId&quot;: 546,\r\n        &quot;servers&quot;: [{\r\n            &quot;id&quot;: 768,\r\n            &quot;timeCreated&quot;: 1602589028419,\r\n            &quot;timeUpdated&quot;: 1602747941321,\r\n            &quot;name&quot;: &quot;gw-jpg208765-1&quot;,\r\n            &quot;type&quot;: &quot;SERVER&quot;,\r\n            &quot;serverType&quot;: &quot;GATEWAY&quot;,\r\n            &quot;status&quot;: &quot;RUNNING&quot;,\r\n            &quot;addresses&quot;: [{\r\n                &quot;networkInterface&quot;: &quot;eng123&quot;\r\n            },\r\n            {\r\n                &quot;networkInterface&quot;: &quot;eng124&quot;\r\n            }],\r\n            &quot;clusterId&quot;: 098,\r\n            &quot;clusterName&quot;: &quot;gw-ext-1&quot;,\r\n            &quot;currentClusteringPort&quot;: 897,\r\n            &quot;runtimeInformation&quot;: {\r\n                &quot;Information&quot;: {\r\n                    &quot;runtime&quot;: {\r\n                        &quot;name&quot;: &quot;abctech&quot;,\r\n                        &quot;version&quot;: &quot;1.6.8&quot;\r\n                    },\r\n                    &quot;specification&quot;: {\r\n                        &quot;vendor&quot;: &quot;rrr&quot;,\r\n                        &quot;name&quot;: &quot;rrrt&quot;,\r\n                        &quot;version&quot;: &quot;1.8.89&quot;\r\n                    }\r\n                },\r\n                &quot;osInformation&quot;: {\r\n                    &quot;name&quot;: &quot;LX&quot;,\r\n                    &quot;version&quot;: &quot;35&quot;,\r\n                    &quot;architecture&quot;: &quot;klh&quot;\r\n                },\r\n                &quot;mExpirationDate&quot;: 098765589283662\r\n            }\r\n        },\r\n        {\r\n            &quot;id&quot;: 876,\r\n            &quot;timeCreated&quot;: 1602589007370,\r\n            &quot;timeUpdated&quot;: 1602748894901,\r\n            &quot;name&quot;: &quot;gw-jpg208765-2&quot;,\r\n            &quot;type&quot;: &quot;SERVER&quot;,\r\n            &quot;serverType&quot;: &quot;GATEWAY&quot;,\r\n            &quot;mVersion&quot;: &quot;3.9.1&quot;,\r\n            &quot;gaVersion&quot;: &quot;3.9.1&quot;,\r\n            &quot;agentVersion&quot;: &quot;1.9.5&quot;,\r\n            &quot;ExpirationDate&quot;: 32521996800000,\r\n            &quot;ExpirationDate&quot;: 1665661007000,\r\n            &quot;status&quot;: &quot;DISCONNECTED&quot;,\r\n            &quot;addresses&quot;: [{\r\n                &quot;networkInterface&quot;: &quot;engg&quot;\r\n            },\r\n            {\r\n                &quot;networkInterface&quot;: &quot;engg&quot;\r\n            }],\r\n            &quot;clusterId&quot;: 768,\r\n            &quot;clusterName&quot;: &quot;gw-ext-1&quot;,\r\n            &quot;serverPort&quot;: 987,\r\n            &quot;currentClusteringPort&quot;: 987,\r\n            &quot;runtimeInformation&quot;: {\r\n                &quot;abcInfo&quot;: {\r\n                    &quot;runtime&quot;: {\r\n                        &quot;name&quot;: &quot;abc&quot;,\r\n                        &quot;version&quot;: &quot;1.2.3&quot;\r\n                    },\r\n                    &quot;specification&quot;: {\r\n                        &quot;vendor&quot;: &quot;RRR&quot;,\r\n                        &quot;name&quot;: &quot;RTR&quot;,\r\n                        &quot;version&quot;: &quot;1.8.0&quot;\r\n                    }\r\n                },\r\n                &quot;osInformation&quot;: {\r\n                    &quot;name&quot;: &quot;LX&quot;,\r\n                    &quot;version&quot;: &quot;4.78&quot;,\r\n                    &quot;architecture&quot;: &quot;eng&quot;\r\n                },\r\n                &quot;ExpirationDate&quot;: 8765478999765\r\n            }\r\n        }],\r\n        &quot;visibilityMap&quot;: {\r\n            &quot;mapNodes&quot;: [{\r\n                &quot;serverId&quot;: 765,\r\n                &quot;visibleNodeIds&quot;: [765,\r\n                876],\r\n                &quot;unknownNodeIps&quot;: []\r\n            },\r\n            {\r\n                &quot;serverId&quot;: 876,\r\n                &quot;visibleNodeIds&quot;: [765,\r\n                876],\r\n                &quot;unknownNodeIps&quot;: []\r\n            }]\r\n        }\r\n    },\r\n\t{\r\n        &quot;id&quot;: 7865,\r\n        &quot;timeCreated&quot;: 1602589399294,\r\n        &quot;timeUpdated&quot;: 1602748892149,\r\n        &quot;name&quot;: &quot;gw-ext-2&quot;,\r\n        &quot;type&quot;: &quot;CLUSTER&quot;,\r\n        &quot;status&quot;: &quot;RUNNING&quot;,\r\n        &quot;multicastEnabled&quot;: false,\r\n        &quot;primaryNodeId&quot;: 546,\r\n        &quot;servers&quot;: [{\r\n            &quot;id&quot;: 768,\r\n            &quot;timeCreated&quot;: 1602589028419,\r\n            &quot;timeUpdated&quot;: 1602747941321,\r\n            &quot;name&quot;: &quot;gw-jpg208766-1&quot;,\r\n            &quot;type&quot;: &quot;SERVER&quot;,\r\n            &quot;serverType&quot;: &quot;GATEWAY&quot;,\r\n            &quot;status&quot;: &quot;RUNNING&quot;,\r\n            &quot;addresses&quot;: [{\r\n                &quot;networkInterface&quot;: &quot;eng123&quot;\r\n            },\r\n            {\r\n                &quot;networkInterface&quot;: &quot;eng124&quot;\r\n            }],\r\n            &quot;clusterId&quot;: 098,\r\n            &quot;clusterName&quot;: &quot;gw-ext-2&quot;,\r\n            &quot;currentClusteringPort&quot;: 897,\r\n            &quot;runtimeInformation&quot;: {\r\n                &quot;Information&quot;: {\r\n                    &quot;runtime&quot;: {\r\n                        &quot;name&quot;: &quot;abctech&quot;,\r\n                        &quot;version&quot;: &quot;1.6.8&quot;\r\n                    },\r\n                    &quot;specification&quot;: {\r\n                        &quot;vendor&quot;: &quot;rrr&quot;,\r\n                        &quot;name&quot;: &quot;rrrt&quot;,\r\n                        &quot;version&quot;: &quot;1.8.89&quot;\r\n                    }\r\n                },\r\n                &quot;osInformation&quot;: {\r\n                    &quot;name&quot;: &quot;LX&quot;,\r\n                    &quot;version&quot;: &quot;35&quot;,\r\n                    &quot;architecture&quot;: &quot;klh&quot;\r\n                },\r\n                &quot;mExpirationDate&quot;: 098765589283662\r\n            }\r\n        },\r\n        {\r\n            &quot;id&quot;: 876,\r\n            &quot;timeCreated&quot;: 1602589007370,\r\n            &quot;timeUpdated&quot;: 1602748894901,\r\n            &quot;name&quot;: &quot;gw-jpg208766-2&quot;,\r\n            &quot;type&quot;: &quot;SERVER&quot;,\r\n            &quot;serverType&quot;: &quot;GATEWAY&quot;,\r\n            &quot;mVersion&quot;: &quot;3.9.1&quot;,\r\n            &quot;gaVersion&quot;: &quot;3.9.1&quot;,\r\n            &quot;agentVersion&quot;: &quot;1.9.5&quot;,\r\n            &quot;ExpirationDate&quot;: 32521996800000,\r\n            &quot;ExpirationDate&quot;: 1665661007000,\r\n            &quot;status&quot;: &quot;DISCONNECTED&quot;,\r\n            &quot;addresses&quot;: [{\r\n                &quot;networkInterface&quot;: &quot;engg&quot;\r\n            },\r\n            {\r\n                &quot;networkInterface&quot;: &quot;engg&quot;\r\n            }],\r\n            &quot;clusterId&quot;: 768,\r\n            &quot;clusterName&quot;: &quot;gw-ext-2&quot;,\r\n            &quot;serverPort&quot;: 987,\r\n            &quot;currentClusteringPort&quot;: 987,\r\n            &quot;runtimeInformation&quot;: {\r\n                &quot;abcInfo&quot;: {\r\n                    &quot;runtime&quot;: {\r\n                        &quot;name&quot;: &quot;abc&quot;,\r\n                        &quot;version&quot;: &quot;1.2.3&quot;\r\n                    },\r\n                    &quot;specification&quot;: {\r\n                        &quot;vendor&quot;: &quot;RRR&quot;,\r\n                        &quot;name&quot;: &quot;RTR&quot;,\r\n                        &quot;version&quot;: &quot;1.8.0&quot;\r\n                    }\r\n                },\r\n                &quot;osInformation&quot;: {\r\n                    &quot;name&quot;: &quot;LX&quot;,\r\n                    &quot;version&quot;: &quot;4.78&quot;,\r\n                    &quot;architecture&quot;: &quot;eng&quot;\r\n                },\r\n                &quot;ExpirationDate&quot;: 8765478999765\r\n            }\r\n        }],\r\n        &quot;visibilityMap&quot;: {\r\n            &quot;mapNodes&quot;: [{\r\n                &quot;serverId&quot;: 765,\r\n                &quot;visibleNodeIds&quot;: [765,\r\n                876],\r\n                &quot;unknownNodeIps&quot;: []\r\n            },\r\n            {\r\n                &quot;serverId&quot;: 876,\r\n                &quot;visibleNodeIds&quot;: [765,\r\n                876],\r\n                &quot;unknownNodeIps&quot;: []\r\n            }]\r\n        }\r\n    }]\r\n```\r\n\r\n\r\nSo in each cluster we have two servers and this json continues to have around 15 clusters.\r\nI want to filter out the status of each cluster and server in below format\r\n```\r\nname            cluster/server status\r\ngw-ext-1        CLUSTER        RUNNING\r\ngw-jpg208765-1  SERVER         RUNNING\r\ngw-jpg208765-2  SERVER         DISCONNECTED\r\n```\r\nsimilarly for other clusters also.\r\n\r\nI tried few things but its not giving me the servers .. it gives only cluster&#39;s details \r\n\r\n\r\ntarget_id=`echo \\$targetIdResponse | ${env.WORKSPACE}/jq -r &#39;.data[] | [.name, .type, .status]&#39;`\r\nOR\r\n\r\ntarget_id=`echo \\$targetIdResponse | ${env.WORKSPACE}/jq -r &#39;.data[] | [.name, .type, .status, .servers.name, .servers.type, .servers.status]&#39;`\r\n\t\t\r\n\r\n\r\nwhere $targetIdResponse contains my json data\r\n\r\nI want to know how i can filter the above json to get the required data.",
        "link": "https://stackoverflow.com/questions/64386912/how-to-print-nested-json-array-data-in-a-tabular-format",
        "title": "How to print nested JSON array data in a tabular format?"
    },
    {
        "tags": [
            "bash",
            "amazon-web-services",
            "sed",
            "jq",
            "aws-cli"
        ],
        "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": 1602843764,
                "post_id": 64387238,
                "comment_id": 113854650,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 220097,
                    "reputation": 3540,
                    "user_id": 477340,
                    "user_type": "registered",
                    "accept_rate": 60,
                    "profile_image": "https://www.gravatar.com/avatar/a858a54895a4242c16f7f43f92fd343d?s=256&d=identicon&r=PG",
                    "display_name": "khinester",
                    "link": "https://stackoverflow.com/users/477340/khinester"
                },
                "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": 1602844126,
                "post_id": 64387238,
                "comment_id": 113854809,
                "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": 1602844262,
                "post_id": 64387238,
                "comment_id": 113854872,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 220097,
                    "reputation": 3540,
                    "user_id": 477340,
                    "user_type": "registered",
                    "accept_rate": 60,
                    "profile_image": "https://www.gravatar.com/avatar/a858a54895a4242c16f7f43f92fd343d?s=256&d=identicon&r=PG",
                    "display_name": "khinester",
                    "link": "https://stackoverflow.com/users/477340/khinester"
                },
                "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": 1602845366,
                "post_id": 64387238,
                "comment_id": 113855315,
                "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": 1602845859,
                "post_id": 64387238,
                "comment_id": 113855514,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": -1,
                "last_activity_date": 1602865834,
                "creation_date": 1602865834,
                "answer_id": 64393048,
                "question_id": 64387238,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can simplify this by using the [`--output` option](https://docs.aws.amazon.com/cli/latest/userguide/cli-usage-output.html), as well as the [`wait` command](https://docs.aws.amazon.com/cli/latest/reference/route53/wait/resource-record-sets-changed.html)\r\n\r\nYou could do something like this (not tested)\r\n\r\n```bash\r\nID=$(aws route53 change-resource-record-sets \\\r\n    --hosted-zone-id ZONEID \\\r\n    --cli-input-json &quot;{\\&quot;HostedZoneId\\&quot;:\\&quot;Z1R8UBAEXAMPLE\\&quot;,\\&quot;ChangeBatch\\&quot;:{\\&quot;Changes\\&quot;:[{\\&quot;Action\\&quot;:\\&quot;UPSERT\\&quot;,\\&quot;ResourceRecordSet\\&quot;:{\\&quot;Name\\&quot;:\\&quot;www.domain.tld.\\&quot;,\\&quot;Type\\&quot;:\\&quot;CNAME\\&quot;,\\&quot;TTL\\&quot;:300,\\&quot;ResourceRecords\\&quot;:[{\\&quot;Value\\&quot;:\\&quot;${RECORD}\\&quot;}]}}]}}&quot; \\\r\n    --query &#39;ChangeInfo.Id&#39; \\\r\n    --output text)\r\n\r\naws route53 wait resource-record-sets-changed --id $ID\r\n    \r\n```",
                "title": "An error occurred (NoSuchChange) when calling the GetChange operation"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1602865834,
        "creation_date": 1602843416,
        "last_edit_date": 1602857763,
        "question_id": 64387238,
        "body_markdown": "I have the following bash script:\r\n\r\n```\r\n#!/bin/sh\r\n# Update the DNS\r\n\r\nRECORD=$1\r\nif [ -z &quot;${RECORD}&quot; ]; then\r\n\techo &quot;Please provide a valid record (URL endpoint)&quot;\r\n\texit 1\r\nfi\r\n\r\nID=$(aws route53 change-resource-record-sets --hosted-zone-id ZONEID --cli-input-json &quot;{\\&quot;HostedZoneId\\&quot;:\\&quot;Z1R8UBAEXAMPLE\\&quot;,\\&quot;ChangeBatch\\&quot;:{\\&quot;Changes\\&quot;:[{\\&quot;Action\\&quot;:\\&quot;UPSERT\\&quot;,\\&quot;ResourceRecordSet\\&quot;:{\\&quot;Name\\&quot;:\\&quot;www.domain.tld.\\&quot;,\\&quot;Type\\&quot;:\\&quot;CNAME\\&quot;,\\&quot;TTL\\&quot;:300,\\&quot;ResourceRecords\\&quot;:[{\\&quot;Value\\&quot;:\\&quot;${RECORD}\\&quot;}]}}]}}&quot; | grep &quot;/change/&quot; | cut -c 15- | sed -e &#39;s/&quot;//g&#39; | sed &#39;s/\\(.*\\),/\\1 /&#39;))\r\necho &quot;Change ID: ${ID}&quot;\r\naws route53 get-change --id ${ID} | grep INSYNC\r\nwhile [ $? -ne 0 ]\r\ndo\r\n\techo &quot;WAITING FOR DNS TO UPDATE... PLEASE WAIT&quot;\r\n\tsleep 5s\r\n    aws route53 get-change --id ${ID} | grep INSYNC\r\ndone\r\n```\r\n\r\nFor some reason, the `ID` returned appends a `,` at the end, even though I have explicitly removed it with `| grep &quot;/change/&quot; | cut -c 15- | sed -e &#39;s/&quot;//g&#39; | sed &#39;s/\\(.*\\),/\\1 /&#39;)`\r\n\r\nI also tried `| jq -r &#39;.ChangeInfo.Id&#39;` but the `,` is still being appended to `ID`\r\n\r\nWhat am I missing?\r\n\r\nAny advice is much appreciated",
        "link": "https://stackoverflow.com/questions/64387238/an-error-occurred-nosuchchange-when-calling-the-getchange-operation",
        "title": "An error occurred (NoSuchChange) when calling the GetChange operation"
    },
    {
        "tags": [
            "json",
            "select",
            "stream",
            "jq",
            "github-actions"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1602942279,
                "creation_date": 1602942279,
                "answer_id": 64403145,
                "question_id": 64402825,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; I get a &quot;list&quot; of urls.\r\n\r\nThat “list” is actually a *stream* of JSON values, so you could simply enclose your jq expression in `first(   )` to get the first value. Please see the jq manual for further details.\r\n\r\nAnother possibility would to use `map` instead of itemizing the array with `[]`, but using `first` as above would be more efficient.",
                "title": "How to filter array of objects by element property values and select the first element, using jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1602950865,
        "creation_date": 1602940106,
        "last_edit_date": 1602950865,
        "question_id": 64402825,
        "body_markdown": "I&#39;m trying to filter an array of objects by their `name` property, and then select the first element that passed the filter.\r\n\r\nI&#39;ve read https://stackoverflow.com/questions/38121740/how-to-filter-array-of-objects-by-element-property-values-using-jq and I&#39;ve been experimenting with jq and https://jqplay.org/ for the past 2h but I don&#39;t get it.\r\n\r\nThe whole thing is a bash script executed within github actions.\r\n\r\nWhere `ALL_ZEIT_DEPLOYMENTS` is:\r\n\r\n    {\r\n        &quot;deployments&quot;:[\r\n            {\r\n                &quot;uid&quot;:&quot;dpl_95kYvsWHaq3yAuJJ6uAaWXQY287R&quot;,\r\n                &quot;name&quot;:&quot;nrn-v2-mst-aptd-gcms-lcz-sty-c1&quot;,\r\n                &quot;url&quot;:&quot;nrn-v2-mst-aptd-gcms-lcz-sty-c1-n9ru06e1q.vercel.app&quot;\r\n            },\r\n            {\r\n                &quot;uid&quot;:&quot;dpl_Fwk5UXLJFU1miLnSfoUM91gnqSNK&quot;,\r\n                &quot;name&quot;:&quot;nrn-v2-mst-aptd-gcms-lcz-sty-c2&quot;,\r\n                &quot;url&quot;:&quot;nrn-v2-mst-aptd-gcms-lcz-sty-c2-hpbca7bei.vercel.app&quot;\r\n            },\r\n            {\r\n                &quot;uid&quot;:&quot;dpl_5U9vDaGKWBkSJF1H1EYMzreWeYvu&quot;,\r\n                &quot;name&quot;:&quot;nrn-v2-mst-aptd-gcms-lcz-sty-c1&quot;,\r\n                &quot;url&quot;:&quot;nrn-v2-mst-aptd-gcms-lcz-sty-c1-16g58d4zd.vercel.app&quot;\r\n            }\r\n        ]\r\n    }\r\n\r\nAnd the bash script is:\r\n\r\n      # Filter deployments by their &quot;name&quot; property in order to consider only deployments related to the current project\r\n      ZEIT_LATEST_DEPLOYMENT_FOR_CURRENT_PROJECT=`echo $ALL_ZEIT_DEPLOYMENTS | jq &#39;.deployments[] | select(.name == &quot;$VERCEL_PROJECT_NAME&quot;)  | .url&#39;`\r\n      echo &quot;Latest Vercel deployment for current project: &quot; $ZEIT_LATEST_DEPLOYMENT_FOR_CURRENT_PROJECT\r\n\r\n      # Extract the first element (which is the latest vercel deployment), and strip the double quotes from its value\r\n      ZEIT_LATEST_DEPLOYMENT_DOMAIN_FOR_CURRENT_PROJECT=`echo $ZEIT_LATEST_DEPLOYMENT_FOR_CURRENT_PROJECT | jq --raw-output &#39;[].url&#39;`\r\n      echo &quot;Latest Vercel deployment domain url for current project: &quot; $ZEIT_LATEST_DEPLOYMENT_DOMAIN_FOR_CURRENT_PROJECT\r\n\r\n\r\nWith the following `jq` filter `.deployments[] | select(.name == &quot;nrn-v2-mst-aptd-gcms-lcz-sty-c1&quot;)  | .url` executed at https://jqplay.org/ I get a &quot;list&quot; of urls.\r\n\r\n[![enter image description here][1]][1]\r\n\r\nBut, I don&#39;t understand how I extract the first element of this, it&#39;s not an array and even if I try to convert it into an array with `.deployments[] | select(.name == &quot;nrn-v2-mst-aptd-gcms-lcz-sty-c1&quot;)  | [.url] | .[0]` I still get the same result.\r\n\r\n[![enter image description here][2]][2]\r\n\r\nWhat am I missing?\r\n\r\nMy goal is to make it work within Github Actions. \r\n\r\nI&#39;m using the web editor to test things out beforehand. Also, I&#39;d like to split the different part of the processing into different variables so that they&#39;re printed out in the Github Actions logs because it&#39;ll help debug faster. (e.g: filter array, then select first element)\r\n\r\n---\r\n\r\nSolution: \r\n\r\n`first(.deployments[] | select(.name == &quot;nrn-v2-mst-aptd-gcms-lcz-sty-c1&quot;)  | .url)`\r\n\r\n[![enter image description here][3]][3]\r\n\r\n\r\n  [1]: https://i.sstatic.net/jAtkE.png\r\n  [2]: https://i.sstatic.net/LwEqs.png\r\n  [3]: https://i.sstatic.net/H7f9K.png",
        "link": "https://stackoverflow.com/questions/64402825/how-to-filter-array-of-objects-by-element-property-values-and-select-the-first-e",
        "title": "How to filter array of objects by element property values and select the first element, using jq?"
    },
    {
        "tags": [
            "json",
            "jq",
            "gsub"
        ],
        "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": 1603039119,
                "post_id": 64407206,
                "comment_id": 113903477,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1603068896,
                "last_edit_date": 1603068896,
                "creation_date": 1602968242,
                "answer_id": 64407263,
                "question_id": 64407206,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Assuming the new value of .text depends on .title in the *same* JSON object, one model you could follow would be:\r\n\r\n    map(if .title | test(&quot;REGEX&quot;) then .text = ... else ... end)\r\n\r\njq has both `sub` (like sed&#39;s &#39;s&#39; but by default without &quot;g&quot;) and `gsub` (like sed&#39;s &#39;s&#39; but with &quot;g&quot;),\r\nas per the jq manual at https://stedolan.github.io/jq/manual/#RegularexpressionsPCRE\r\n\r\n### Using `walk/1`\r\n\r\nIf you want to make a change in all objects with both .title and .text, you could use `walk/1` along the following lines:\r\n\r\n    walk(if type == &quot;object&quot; and has(&quot;title&quot;) and has(&quot;text&quot;)\r\n         then if .title | test(&quot;REGEX&quot;) then .text = ... else ... end\r\n         else . end)\r\n\r\n**Edit by @Arainty:** using `test` is just for illustration; use `==` to match the exact value. (`.title==&quot;STRING&quot;`)",
                "title": "Replace values where other keys are - jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1603068896,
        "creation_date": 1602967765,
        "last_edit_date": 1603049066,
        "question_id": 64407206,
        "body_markdown": "I&#39;m a bit lost with this `jq` command. I have a `json` file like that:\r\n```json\r\n...\r\n\r\n{\r\n    &quot;class&quot;: &quot;classOne&quot;,\r\n    &quot;title&quot;: &quot;title1&quot;,\r\n    &quot;text&quot;: &quot;text1&quot;\r\n},\r\n{\r\n    &quot;class&quot;: &quot;classTwo&quot;,\r\n    &quot;title&quot;: &quot;title2&quot;,\r\n    &quot;text&quot;: &quot;text2&quot;\r\n},\r\n\r\n...\r\n```\r\nWhat I&#39;m trying to do is replace values of `text`s with another value, depending on the value of `title`.\r\n\r\nHow can I do, and how in general can I replace one value depending on another from the same &#39;group&#39;? Plus, can I specify &#39;only first&#39; or &#39;general&#39; following the way `sed` works with `&#39;.../g&#39;`?\r\n\r\n---\r\n\r\n## Edit\r\nI want to be able to work with any depth of my `json`, that&#39;s why my included code isn&#39;t very big. Basically I want to modify a value depending on the value of another key *always in the same object*.\r\n\r\n---\r\n\r\nTyvm.",
        "link": "https://stackoverflow.com/questions/64407206/replace-values-where-other-keys-are-jq",
        "title": "Replace values where other keys are - jq"
    },
    {
        "tags": [
            "linux",
            "shell",
            "sh",
            "jq",
            "xargs"
        ],
        "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": 1603004105,
                "post_id": 64410325,
                "comment_id": 113894643,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 18730839,
                    "reputation": 103,
                    "user_id": 13656269,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b7ea5a6c71f68c79111d65212acf9137?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "lolsu",
                    "link": "https://stackoverflow.com/users/13656269/lolsu"
                },
                "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": 1603005314,
                "post_id": 64410325,
                "comment_id": 113894900,
                "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": 1603005433,
                "post_id": 64410325,
                "comment_id": 113894919,
                "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": 1603005459,
                "post_id": 64410325,
                "comment_id": 113894930,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 18730839,
                    "reputation": 103,
                    "user_id": 13656269,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b7ea5a6c71f68c79111d65212acf9137?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "lolsu",
                    "link": "https://stackoverflow.com/users/13656269/lolsu"
                },
                "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": 1603005545,
                "post_id": 64410325,
                "comment_id": 113894950,
                "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": 1603005585,
                "post_id": 64410325,
                "comment_id": 113894958,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 18730839,
                    "reputation": 103,
                    "user_id": 13656269,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b7ea5a6c71f68c79111d65212acf9137?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "lolsu",
                    "link": "https://stackoverflow.com/users/13656269/lolsu"
                },
                "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": 1603005882,
                "post_id": 64410325,
                "comment_id": 113895021,
                "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": 1603005962,
                "post_id": 64410325,
                "comment_id": 113895042,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 18730839,
                    "reputation": 103,
                    "user_id": 13656269,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b7ea5a6c71f68c79111d65212acf9137?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "lolsu",
                    "link": "https://stackoverflow.com/users/13656269/lolsu"
                },
                "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": 1603006550,
                "post_id": 64410325,
                "comment_id": 113895194,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1603006132,
                "creation_date": 1603006132,
                "answer_id": 64410806,
                "question_id": 64410325,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "When you write\r\n\r\n```\r\n$(echo {} | wc -w)`\r\n```\r\nThe input to the `wc -w` command is the string `{}`. That&#39;s one word, so the result is `1`, and that gets substituted in place of `$(echo {} | wc -w)`. It&#39;s *not* substituting anything from `xargs` there, because command substitutions are executed first and the results substituted into the command line.\r\n\r\nSo the argument that `xargs` receives contains this `1` already substituted.\r\n\r\n",
                "title": "xargs and command substition issues"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1603021902,
        "creation_date": 1603001921,
        "last_edit_date": 1603021902,
        "question_id": 64410325,
        "body_markdown": "So, i have a horrifying oneliner, that gets a json value extracts data from it using jq and then iterates over the data with xargs. In the end it should produces some xml\r\n```bash\r\nlegendary list-installed --json | jq &#39;.[].title&#39; | sed s/&quot;\\&quot;&quot;/&quot;&quot;/g | xargs -n1 -p -d &quot;\\n&quot; -I {} echo &#39;&lt;button onclick=&quot;&#39;$(legendary list-installed --json | jq &#39;map(if .title == &quot;&#39;{}&#39;&quot; then .app_name elif .title == &quot;_&quot; then &quot;_&quot; else &quot;_&quot; end)&#39;)&#39;&quot;&gt;&#39;{}&#39;&lt;/button&gt;&#39;\r\n```\r\nFirst of all, i didn&#39;t use the `-r` flag with jq because i thought the issue might be comming from it.\r\n\r\nThe expected output should be something like this:\r\n```xml\r\n&lt;button onclick=app name e.g. Coley&gt; The Escapist 2 &lt;/button&gt;\r\n```\r\nSo far that works (except for the app name part, as thats where it begins to get weird)\r\n\r\nBecause i hardly can debug with jq inside the command substition, i wanted to test what xargs gets passed into stdin via another command substition. I changed the part between the two button elements `{}` to `$(echo {})`, which still works. But by accident i piped it into `wc -w`, which outputs ONE if the content of the {} is actually TWO! \r\n[![image][1]][1]\r\n```\r\n❯ ./test.sh\r\n&lt;layout&gt;\r\necho &#39;button onclick=&quot;[&#39; &#39;&quot;_&quot;,&#39; &#39;&quot;_&quot;,&#39; &#39;&quot;_&quot;&#39; &#39;]&quot;&gt;Ape Out&lt;/button&gt;&#39; ?...^C⏎                                                                                                                                           \r\n&gt; cat test.sh\r\n...&#39;$(echo {})&#39;&lt;/button&gt;&#39;\r\n```\r\nIf i just echo the content of {} it returns this (i know that thats a useless echo, its just for consistency):\r\n[![second image][2]][2]\r\nWhen i count the words inside of my shell, and not inside of xargs\r\n```\r\nlegendary list-installed --json | jq &#39;.[].title&#39; | head -n 1 | sed s/&quot;\\&quot;&quot;/&quot;&quot;/g | wc -w\r\n```\r\nit does return two.\r\n\r\nOutput of running with `set -x`\r\n```\r\n❯ ./test.sh\r\n+ echo &#39;&lt;layout&gt;&#39;\r\n&lt;layout&gt;\r\n+ legendary list-installed --json\r\n+ jq &#39;.[].title&#39;\r\n+ sed &#39;s/&quot;//g&#39;\r\n++ legendary list-installed --json\r\n++ jq &#39;map(if .title == &quot;{}&quot; then .app_name elif .title == &quot;_&quot; then &quot;_&quot; else &quot;_&quot; end)&#39;\r\n++ echo &#39;{}&#39;\r\n++ tee lolsu,txt\r\n+ xargs -n1 -p -d &#39;\\n&#39; -I &#39;{}&#39; echo &#39;button onclick=&quot;[&#39; &#39;&quot;_&quot;,&#39; &#39;&quot;_&quot;,&#39; &#39;&quot;_&quot;&#39; &#39;]&quot;&gt;{}&lt;/button&gt;&#39;\r\necho &#39;button onclick=&quot;[&#39; &#39;&quot;_&quot;,&#39; &#39;&quot;_&quot;,&#39; &#39;&quot;_&quot;&#39; &#39;]&quot;&gt;Ape Out&lt;/button&gt;&#39; ?...\r\n```\r\nSeems like its not being substituted correctly... New problem is how i would make it replace the {} with the real one, inside of the substition. \r\n \r\nTLDR:\r\ncounting the value of xargs returns one, while the piped input should be two words (as i am iterating over line and not word)\r\nWhen running in shell it returns two (without using xargs, obv)\r\n\r\n\r\n  [1]: https://i.sstatic.net/E4Uzp.png\r\n  [2]: https://i.sstatic.net/IS31z.png",
        "link": "https://stackoverflow.com/questions/64410325/xargs-and-command-substition-issues",
        "title": "xargs and command substition issues"
    },
    {
        "tags": [
            "bash",
            "shell",
            "automation",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1603110089,
                "last_edit_date": 1603110089,
                "creation_date": 1603066573,
                "answer_id": 64419598,
                "question_id": 64419432,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can process your JSON directly with a stand-alone `jq` script as follow:\r\n\r\n`json2php`\r\n```jq\r\n#!/usr/bin/env -S jq -sjf\r\n\r\n.[] |\r\n(\r\n  # JSON string literal\r\n  &quot;if($link == &quot;\r\n\r\n  # Concat with num JSON object member converted to JSON string\r\n  + ( .num | tostring )\r\n\r\n  # Concat with JSON string literal\r\n  + &quot;) { $linkURL = \\&quot;&quot;\r\n\r\n  # Concat with filename JSON object member filtered %coded to URI\r\n  + ( .filename | @uri )\r\n\r\n  # Concat with JSON string literal including newline\r\n  + &quot;\\&quot;;}\\nif($link == &quot;\r\n\r\n  # Concat with num JSON object member converted to JSON string\r\n  + ( .num | tostring )\r\n\r\n  # Concat with JSON string literal\r\n  + &quot;) { $altText = \\&quot;&quot;\r\n\r\n  # Concat with name JSON object member filtered to HTML entities if needed\r\n  + ( .name | @html ) + &quot;\\&quot;;}\\n&quot;\r\n)\r\n```\r\n\r\nSave file as `json2php` and make it executable:\r\n```sh\r\nchmod +x json2php\r\n```\r\n\r\nUse it as:\r\n```sh\r\n./json2php input.json &gt;test.php\r\n```\r\n\r\nHow it works:\r\n\r\nThe shebang `#!/usr/bin/env -S jq -sjf` tells to execute the `jq` interpreter with `-sjf` arguments:\r\n\r\n`jq` arguments:\r\n- `-s`: Handle the input as a stream of JSON objects rather than as a single JSON object.\r\n- `-j`: Produces a raw output without newlines.\r\n- `-f`: Load this as a script (appropriate for a shebang).\r\n\r\nNow the `jq` script itself:\r\n\r\n - `.[] |`: Pipe each Object from the input stream array for processing\r\n - `( ... )`: Group instructions.\r\n - `&quot;if($link == &quot;`: Is just a JSON string literal to be printed as-is ( without the double quotes `&quot;` since `jq` has been instructed to produce a raw output with the `-j` option switch.\r\n - `+ ( .num | tostring )`: Concatenates with the `num` member converted to a string, so it can be added to the previous string.\r\n - `+ &quot;) { $linkURL = \\&quot;&quot;`: Concatenates with another JSON string literal.\r\n - `+ ( .filename | @uri )`: Concatenates with the `filename` member filtered as an URI, so special characters like spaces `+`  `&amp;` ... will be % encoded.\r\n - `+ &quot;\\&quot;;}\\n&quot;`: Concatenates with another JSON string literal including a newline character escaped as `\\n` to be printed as a raw newline\r\n- …\r\n\r\nExample `input.json` (notice the spaces and quotes to probe test the filter works as intended):\r\n```json\r\n{\r\n   &quot;num&quot;: 1,\r\n   &quot;filename&quot;: &quot;trees-in-nature.jpg&quot;,\r\n   &quot;name&quot;: &quot;Trees In Nature&quot;\r\n}\r\n{\r\n   &quot;num&quot;: 2,\r\n   &quot;filename&quot;: &quot;running dogs.jpg&quot;,\r\n   &quot;name&quot;: &quot;Running \\&quot;Dogs\\&quot;&quot;\r\n}\r\n{\r\n   &quot;num&quot;: 3,\r\n   &quot;filename&quot;: &quot;beautiful-lake.jpg&quot;,\r\n   &quot;name&quot;: &quot;Beautiful&#39; Lake&quot;\r\n}\r\n```\r\n\r\nGenerated php code from the above input:\r\n```php\r\nif($link == 1) { $linkURL = &quot;trees-in-nature.jpg&quot;;}\r\nif($link == 1) { $altText = &quot;Trees In Nature&quot;;}\r\nif($link == 2) { $linkURL = &quot;running%20dogs.jpg&quot;;}\r\nif($link == 2) { $altText = &quot;Running &amp;quot;Dogs&amp;quot;&quot;;}\r\nif($link == 3) { $linkURL = &quot;beautiful-lake.jpg&quot;;}\r\nif($link == 3) { $altText = &quot;Beautiful&amp;apos; Lake&quot;;}\r\n```\r\n\r\nAn alternative to produce a PHP `switch` statement instead:\r\n\r\n```sh\r\n#!/usr/bin/env -S jq -srf\r\n\r\n# JSON string literal\r\n&quot;switch ($link) {&quot;,\r\n(\r\n  .[] |\r\n  (\r\n    # JSON string literal\r\n    &quot;    case &quot;\r\n\r\n    # Concat with num JSON object member converted to JSON string\r\n    + ( .num | tostring )\r\n\r\n    # Concat with JSON string literal\r\n    + &quot;:&quot;,\r\n\r\n    # New JSON string litteral\r\n    &quot;        $linkURL = \\&quot;&quot;\r\n\r\n    # Concat with filename JSON object member filtered %coded to URI\r\n    + ( .filename | @uri )\r\n\r\n    # Concat with JSON string literal\r\n    + &quot;\\&quot;;&quot;,\r\n\r\n    # New JSON string litteral\r\n    &quot;        $altText = \\&quot;&quot;\r\n\r\n    # Concat with name JSON object member filtered to HTML entities if needed\r\n    + ( .name | @html )\r\n\r\n    # Concat with JSON string literal\r\n    + &quot;\\&quot;;&quot;,\r\n\r\n    # New JSON string litteral\r\n    &quot;        break;&quot;\r\n  )\r\n),\r\n# JSON string literal\r\n&quot;}&quot;\r\n```\r\n\r\nResult from same `input.json`:\r\n```php\r\nswitch ($link) {\r\n    case 1:\r\n        $linkURL = &quot;trees-in-nature.jpg&quot;;\r\n        $altText = &quot;Trees In Nature&quot;;\r\n        break;\r\n    case 2:\r\n        $linkURL = &quot;running%20dogs.jpg&quot;;\r\n        $altText = &quot;Running &amp;quot;Dogs&amp;quot;&quot;;\r\n        break;\r\n    case 3:\r\n        $linkURL = &quot;beautiful-lake.jpg&quot;;\r\n        $altText = &quot;Beautiful&amp;apos; Lake&quot;;\r\n        break;\r\n}\r\n```",
                "title": "How to make a bash shell script parse a JSON file with jq and then print results to a PHP file?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1603110089,
        "creation_date": 1603064999,
        "last_edit_date": 1603065988,
        "question_id": 64419432,
        "body_markdown": "I am brand new to bash shell scripting and automation. I am trying to create a relatively simple script which parses a JSON file and prints some PHP from the data that was parsed.\r\n\r\nTo parse the JSON I would like to use jq. This is the code in my bash shell script that does that:\r\n\r\n    jq . test.json\r\n\r\nThe objects in my JSON have properties about images. The properties I will be using from the JSON are:\r\n\r\n    num = each image is assigned a number, 1 to infinity\r\n    filename = the name of the image file\r\n    name = the title of the image\r\n\r\nThe example JSON file:\r\n\r\n    {\r\n       &quot;num&quot;: 1,\r\n       &quot;filename&quot;: &quot;trees-in-nature.jpg&quot;,\r\n       &quot;name&quot;: &quot;Trees In Nature&quot;\r\n    }\r\n    {\r\n       &quot;num&quot;: 2,\r\n       &quot;filename&quot;: &quot;running-dogs.jpg&quot;,\r\n       &quot;name&quot;: &quot;Running Dogs&quot;\r\n    }\r\n    {\r\n       &quot;num&quot;: 3,\r\n       &quot;filename&quot;: &quot;beautiful-lake.jpg&quot;,\r\n       &quot;name&quot;: &quot;Beautiful Lake&quot;\r\n    }\r\n\r\nI want to take the parsed JSON properties and output it to some PHP code. Each image in the JSON code will output two lines of PHP that look like this (JSON values are shown between asterisks):\r\n\r\n    if($link == *num*) { $linkURL = &quot;*filename*&quot;;}\r\n    if($link == *num*) { $altText = &quot;*name*&quot;;}\r\n\r\nFor example, the final result I want outputted would look like this:\r\n\r\n    if($link == 1) { $linkURL = &quot;trees-in-nature.jpg&quot;;}\r\n    if($link == 1) { $altText = &quot;Trees In Nature&quot;;}\r\n    if($link == 2) { $linkURL = &quot;running-dogs.jpg&quot;;}\r\n    if($link == 2) { $altText = &quot;Running Dogs&quot;;}\r\n    ...\r\n\r\nThe part I am stuck on is using `printf` to print the PHP code above.\r\n\r\nOnce I figure out that and finalize the shell script and make it executable, I would like to use this command to print the result to a PHP file.\r\n\r\n    ./parser.sh &gt; test.php\r\n\r\nHow can I use `printf` to print out the PHP and insert the values from the JSON?\r\n\r\n\r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/64419432/how-to-make-a-bash-shell-script-parse-a-json-file-with-jq-and-then-print-results",
        "title": "How to make a bash shell script parse a JSON file with jq and then print results to a PHP file?"
    },
    {
        "tags": [
            "jq",
            "docker-api"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 958495,
                    "reputation": 305,
                    "user_id": 983325,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d0722d889abf8575c32444bd640dc38b?s=256&d=identicon&r=PG",
                    "display_name": "F&#225;bio Almeida",
                    "link": "https://stackoverflow.com/users/983325/f%c3%a1bio-almeida"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1603100451,
                "post_id": 64423634,
                "comment_id": 113919353,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1603098779,
                "last_edit_date": 1603098779,
                "creation_date": 1603097656,
                "answer_id": 64424077,
                "question_id": 64423634,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The problem is not because of `/` in the `.Names` field, but in your expression. For filters like `@csv` or `@tsv` to work, the values need to be in a scalar format and in an array. But your expression `.Name` in of type `array`.\r\n\r\nSo basically you are passing this result to the `@tsv` function\r\n\r\n    [\r\n      [\r\n        &quot;/boring_feynman&quot;\r\n      ],\r\n      &quot;ubuntu:latest&quot;\r\n    ]\r\n\r\ninstead of \r\n\r\n    [\r\n      &quot;/boring_feynman&quot;,\r\n      &quot;ubuntu:latest&quot;\r\n    ]\r\n\r\nSo modifying your filter, you can do below for the JSON in question.\r\n\r\n    jq -r &#39;([&quot;Names&quot;,&quot;Image&quot;] | (., map(length*&quot;-&quot;))), ([.Names[], .Image]) | @tsv&#39;\r\n\r\nor if you still want to remove the `/`, use `gsub()` function\r\n\r\n    jq -r &#39;([&quot;Names&quot;,&quot;Image&quot;] | (., map(length*&quot;-&quot;))), ([ (.Names[] | gsub(&quot;^/&quot;;&quot;&quot;)), .Image]) | @tsv&#39;\r\n",
                "title": "Remove slash character in JSON response using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1603098779,
        "creation_date": 1603095855,
        "last_edit_date": 1603096820,
        "question_id": 64423634,
        "body_markdown": "Docker Engine API returns container name with / appended \r\n\r\n    {\r\n    \t&quot;Id&quot;: &quot;8dfafdbc3a40&quot;,\r\n    \t&quot;Names&quot;: [\r\n    \t\t&quot;/boring_feynman&quot;\r\n    \t],\r\n    \t&quot;Image&quot;: &quot;ubuntu:latest&quot;,\r\n    \t&quot;ImageID&quot;: &quot;d74508fb6632491cea586a1fd7d748dfc5274cd6fdfedee309ecdcbc2bf5cb82&quot;,\r\n    \t&quot;Command&quot;: &quot;echo 1&quot;,\r\n    \t&quot;Created&quot;: 1367854155,\r\n    \t&quot;State&quot;: &quot;Exited&quot;,\r\n    \t&quot;Status&quot;: &quot;Exit 0&quot;,\r\n    \t&quot;Ports&quot;: [{\r\n    \t\t&quot;PrivatePort&quot;: 2222,\r\n    \t\t&quot;PublicPort&quot;: 3333,\r\n    \t\t&quot;Type&quot;: &quot;tcp&quot;\r\n    \t}],\r\n    \t&quot;Labels&quot;: {\r\n    \t\t&quot;com.example.vendor&quot;: &quot;Acme&quot;,\r\n    \t\t&quot;com.example.license&quot;: &quot;GPL&quot;,\r\n    \t\t&quot;com.example.version&quot;: &quot;1.0&quot;\r\n    \t},\r\n    \t&quot;SizeRw&quot;: 12288,\r\n    \t&quot;SizeRootFs&quot;: 0,\r\n    \t&quot;HostConfig&quot;: {\r\n    \t\t&quot;NetworkMode&quot;: &quot;default&quot;\r\n    \t},\r\n    \t&quot;NetworkSettings&quot;: {\r\n    \t\t&quot;Networks&quot;: {}\r\n    \t},\r\n    \t&quot;Mounts&quot;: [{\r\n    \t\t&quot;Name&quot;: &quot;fac362...80535&quot;,\r\n    \t\t&quot;Source&quot;: &quot;/data&quot;,\r\n    \t\t&quot;Destination&quot;: &quot;/data&quot;,\r\n    \t\t&quot;Driver&quot;: &quot;local&quot;,\r\n    \t\t&quot;Mode&quot;: &quot;ro,Z&quot;,\r\n    \t\t&quot;RW&quot;: false,\r\n    \t\t&quot;Propagation&quot;: &quot;&quot;\r\n    \t}]\r\n    }\r\n\r\nI want to remove the slash so the response can be used as a table in JQ: \r\n\r\n    jq -r &#39;([&quot;Names&quot;,&quot;Image&quot;] | (., map(length*&quot;-&quot;))), (.[] | [.Names, .Image]) | @tsv&#39;\r\n\r\nCurrently, when I run the above,  I get:\r\n\r\n    jq: error (at &lt;stdin&gt;:1): array ([&quot;/boring_feynman&quot;]) is not valid in a csv row",
        "link": "https://stackoverflow.com/questions/64423634/remove-slash-character-in-json-response-using-jq",
        "title": "Remove slash character in JSON response using jq"
    },
    {
        "tags": [
            "json",
            "merge",
            "filenames",
            "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": 1603098040,
                "post_id": 64424113,
                "comment_id": 113918285,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6515831,
                    "reputation": 119,
                    "user_id": 5041701,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/4d0ec5fac1785fbb042272a428bd873b?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Jonas",
                    "link": "https://stackoverflow.com/users/5041701/jonas"
                },
                "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": 1603098156,
                "post_id": 64424113,
                "comment_id": 113918347,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1603098976,
                "last_edit_date": 1603098976,
                "creation_date": 1603098471,
                "answer_id": 64424283,
                "question_id": 64424113,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You&#39;re looking for [`input_filename`](https://stedolan.github.io/jq/manual/#input_filename).\r\n```\r\njq -n &#39;[ inputs | .CaseId = input_filename ]&#39; *.json\r\n```",
                "title": "Merge multiple JSON files and include filename of each file in the resulting object"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1603105606,
                "last_edit_date": 1603105606,
                "creation_date": 1603098531,
                "answer_id": 64424301,
                "question_id": 64424113,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use `reduce` adding on one input object at a time. Use `input_filename` to get the UTF-8 encoded filename and form the record with `CaseId`\r\n\r\n```\r\njq -n &#39;reduce inputs as $d (null; . + [ $d + { CaseId: input_filename } ] )&#39; *.json\r\n```",
                "title": "Merge multiple JSON files and include filename of each file in the resulting object"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1603185234,
        "creation_date": 1603097781,
        "last_edit_date": 1603185234,
        "question_id": 64424113,
        "body_markdown": "I have hundreds of files being named as [guid].json where structure of them all looks similar to this:\r\n\r\n```\r\n{\r\n  &quot;Active&quot;: true,\r\n  &quot;CaseType&quot;: &quot;CaseType&quot;,\r\n  &quot;CustomerGroup&quot;: [&quot;Core&quot;, &quot;Extended&quot;]\r\n}\r\n```\r\n\r\nFirst I need to append a new key-value pair to all files with `&quot;CaseId&quot;: &quot;[filename]&quot;` and then merge them all into one big array and save it as a new json manifest file.\r\n\r\nI would like one file with the following structure from a jq command:\r\n\r\n```\r\n[\r\n  {\r\n    &quot;Active&quot;: true,\r\n    &quot;CaseType&quot;: &quot;CaseType&quot;,\r\n    &quot;CustomerGroup&quot;: [&quot;Core&quot;, &quot;Extended&quot;],\r\n    &quot;CaseId&quot;: &quot;43d47f66-5a0a-4b86-88d6-1f1f893098d2&quot;\r\n  },\r\n  {\r\n    &quot;Active&quot;: true,\r\n    &quot;CaseType&quot;: &quot;CaseType&quot;,\r\n    &quot;CustomerGroup&quot;: [&quot;Core&quot;, &quot;Extended&quot;],\r\n    &quot;CaseId&quot;: &quot;e3x47f66-5a0a-4b86-88d6-1f1f893098d2&quot;\r\n  }\r\n]\r\n```\r\n\r\n",
        "link": "https://stackoverflow.com/questions/64424113/merge-multiple-json-files-and-include-filename-of-each-file-in-the-resulting-obj",
        "title": "Merge multiple JSON files and include filename of each file in the resulting object"
    },
    {
        "tags": [
            "json",
            "shell",
            "loops",
            "elasticsearch",
            "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": 1603125448,
                "post_id": 64431085,
                "comment_id": 113931200,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 13374846,
                    "reputation": 3,
                    "user_id": 9651994,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/aedc3d19be5a0d6061ce99a67627594f?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Elastock",
                    "link": "https://stackoverflow.com/users/9651994/elastock"
                },
                "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": 1603179606,
                "post_id": 64431085,
                "comment_id": 113946856,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1603125980,
                "creation_date": 1603125980,
                "answer_id": 64431768,
                "question_id": 64431085,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Calling `jq` just once, and having it write a NUL-delimited list of template-name / modified-template-content pairs (which a bash `while read` loop can then iterate over):\r\n\r\n```\r\nwhile IFS= read -r -d &#39;&#39; template_name &amp;&amp; IFS= read -r -d &#39;&#39; template_content; do\r\n  echo &quot;We want to do PUT the following to _template/$template_name&quot;\r\n  printf &#39;%s\\n&#39; &quot;$template_content&quot;\r\ndone &lt; &lt;(\r\n  jq -j &#39;\r\n    to_entries[] |\r\n    .key as $template_name |\r\n    .value as $template_content |\r\n    ($template_name, &quot;\\u0000&quot;,\r\n     ($template_content | (.mappings = .mappings._doc) | tojson), &quot;\\u0000&quot;)\r\n  &#39; &lt;infile.json\r\n)\r\n```",
                "title": "Generate multiple JQ output documents from a single input, modifying each result"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1603195681,
                "last_edit_date": 1603195681,
                "creation_date": 1603187521,
                "answer_id": 64442658,
                "question_id": 64431085,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I had some trouble with the `done &lt; &lt;(` that caused syntax error in my shell (don&#39;t know why ) .\r\nSo I modified your script like this :\r\n\r\n    jq -j &#39;to_entries[] | .key as $template_name | .value as $template_content | ($template_name, &quot;\\u0000&quot;, ($template_content | (.mappings = .mappings._doc) | tojson), &quot;\\u0000&quot;)&#39; &lt; infile.json |\r\n    while IFS= read -r -d &#39;&#39; template_name &amp;&amp; IFS= read -r -d &#39;&#39; template_content; do\r\n      echo &quot;PUT _template/$template_name&quot;\r\n      printf &#39;%s\\n&#39; &quot;$template_content&quot;\r\n    done\r\n\r\nWhich perfectly does the job !\r\nThanks Charles",
                "title": "Generate multiple JQ output documents from a single input, modifying each result"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1603195681,
        "creation_date": 1603123347,
        "last_edit_date": 1603128475,
        "question_id": 64431085,
        "body_markdown": "I want to do 2 operations in my JSON file . I tried to do it with JQ and SHELL .\r\n \r\nFirst one : I want to tranform the parents elements to an pure text value\r\n\r\nSecond one : I want to remove one specific level in the JSON tree\r\n\r\nInput :\r\n\r\n        {\r\n      &quot;template_first&quot;: {\r\n        &quot;order&quot;: 0,\r\n        &quot;index_patterns&quot;: [\r\n          &quot;first&quot;\r\n        ],\r\n        &quot;settings&quot;: {\r\n          &quot;index&quot;: {\r\n            &quot;codec&quot;: &quot;best_compression&quot;,\r\n            &quot;refresh_interval&quot;: &quot;30s&quot;,\r\n            &quot;analysis&quot;: {\r\n              &quot;normalizer&quot;: {\r\n                &quot;norm_case_insensitive&quot;: {\r\n                  &quot;filter&quot;: &quot;lowercase&quot;,\r\n                  &quot;type&quot;: &quot;custom&quot;\r\n                }\r\n              }\r\n            },\r\n            &quot;number_of_shards&quot;: &quot;1&quot;,\r\n            &quot;number_of_replicas&quot;: &quot;1&quot;\r\n          }\r\n        },\r\n        &quot;mappings&quot;: {\r\n          &quot;_doc&quot;: {\r\n            &quot;dynamic&quot;: true,\r\n            &quot;dynamic_templates&quot;: [\r\n              {\r\n                &quot;strings&quot;: {\r\n                  &quot;mapping&quot;: {\r\n                    &quot;type&quot;: &quot;keyword&quot;\r\n                  },\r\n                  &quot;match_mapping_type&quot;: &quot;string&quot;\r\n                }\r\n              }\r\n            ],\r\n            &quot;properties&quot;: {\r\n              &quot;log.id&quot;: {\r\n                &quot;type&quot;: &quot;keyword&quot;\r\n              },\r\n              &quot;host.indexer.hostname&quot;: {\r\n                &quot;type&quot;: &quot;keyword&quot;\r\n              },\r\n              &quot;ts_indexer&quot;: {\r\n                &quot;format&quot;: &quot;strict_date_optional_time||epoch_millis&quot;,\r\n                &quot;type&quot;: &quot;date&quot;\r\n              }\r\n            }\r\n          }\r\n        }\r\n      },\r\n      &quot;template_second&quot;: {\r\n        &quot;order&quot;: 0,\r\n        &quot;index_patterns&quot;: [\r\n          &quot;second&quot;\r\n        ],\r\n        &quot;settings&quot;: {\r\n          &quot;index&quot;: {\r\n            &quot;codec&quot;: &quot;best_compression&quot;,\r\n            &quot;refresh_interval&quot;: &quot;30s&quot;,\r\n            &quot;analysis&quot;: {\r\n              &quot;normalizer&quot;: {\r\n                &quot;norm_case_insensitive&quot;: {\r\n                  &quot;filter&quot;: &quot;lowercase&quot;,\r\n                  &quot;type&quot;: &quot;custom&quot;\r\n                }\r\n              }\r\n            },\r\n            &quot;number_of_shards&quot;: &quot;1&quot;,\r\n            &quot;number_of_replicas&quot;: &quot;1&quot;\r\n          }\r\n        },\r\n        &quot;mappings&quot;: {\r\n          &quot;_doc&quot;: {\r\n            &quot;dynamic&quot;: true,\r\n            &quot;dynamic_templates&quot;: [\r\n              {\r\n                &quot;strings&quot;: {\r\n                  &quot;mapping&quot;: {\r\n                    &quot;type&quot;: &quot;keyword&quot;\r\n                  },\r\n                  &quot;match_mapping_type&quot;: &quot;string&quot;\r\n                }\r\n              }\r\n            ],\r\n            &quot;properties&quot;: {\r\n              &quot;log.id&quot;: {\r\n                &quot;type&quot;: &quot;keyword&quot;\r\n              },\r\n              &quot;host.indexer.hostname&quot;: {\r\n                &quot;type&quot;: &quot;keyword&quot;\r\n              },\r\n              &quot;ts_indexer&quot;: {\r\n                &quot;format&quot;: &quot;strict_date_optional_time||epoch_millis&quot;,\r\n                &quot;type&quot;: &quot;date&quot;\r\n              }\r\n            }\r\n          }\r\n        }\r\n      }\r\n    }\r\n\r\nYou see  there two JSON object in the file \r\n\r\n        {\r\n        &quot;template_first&quot; : { ...},\r\n        &quot;template_second&quot; : { ... }\r\n         }\r\n\r\n**The first** modification comes from the appearance of this command \r\n\r\n&gt; PUT _template/template_number\r\n\r\n instead of the key of the first JSON object.\r\n\r\n\r\nSo the expected result\r\n\r\n    PUT _template/template_first\r\n      {...}\r\n    PUT _template/template_second\r\n      {...}\r\n\r\n**The second change** comes with the removal of _doc level\r\n\r\nBefore : \r\n\r\n      &quot;mappings&quot;: {\r\n        &quot;_doc&quot;: {\r\n          &quot;dynamic&quot;: true,\r\n          &quot;dynamic_templates&quot;: [\r\n            {\r\n              &quot;strings&quot;: {\r\n                &quot;mapping&quot;: {\r\n                  &quot;type&quot;: &quot;keyword&quot;\r\n                },\r\n                &quot;match_mapping_type&quot;: &quot;string&quot;\r\n              }\r\n            }\r\n          ],\r\n          &quot;properties&quot;: {\r\n            &quot;log.id&quot;: {\r\n              &quot;type&quot;: &quot;keyword&quot;\r\n            },\r\n            &quot;host.indexer.hostname&quot;: {\r\n              &quot;type&quot;: &quot;keyword&quot;\r\n            },\r\n            &quot;ts_indexer&quot;: {\r\n              &quot;format&quot;: &quot;strict_date_optional_time||epoch_millis&quot;,\r\n              &quot;type&quot;: &quot;date&quot;\r\n            }\r\n          }\r\n        }\r\n      }\r\n\r\n\r\nExpected result\r\n\r\n      &quot;mappings&quot;: {\r\n        &quot;dynamic&quot;: true,\r\n        &quot;dynamic_templates&quot;: [\r\n          {\r\n            &quot;strings&quot;: {\r\n              &quot;mapping&quot;: {\r\n                &quot;type&quot;: &quot;keyword&quot;\r\n              },\r\n              &quot;match_mapping_type&quot;: &quot;string&quot;\r\n            }\r\n          }\r\n        ],\r\n        &quot;properties&quot;: {\r\n          &quot;log.id&quot;: {\r\n            &quot;type&quot;: &quot;keyword&quot;\r\n          },\r\n          &quot;host.indexer.hostname&quot;: {\r\n            &quot;type&quot;: &quot;keyword&quot;\r\n          },\r\n          &quot;ts_indexer&quot;: {\r\n            &quot;format&quot;: &quot;strict_date_optional_time||epoch_millis&quot;,\r\n            &quot;type&quot;: &quot;date&quot;\r\n          }\r\n        }\r\n      }\r\n\r\nSo the actual result look like this\r\n\r\n    PUT _template/template_first\r\n      {\r\n      &quot;order&quot;: 0,\r\n      &quot;index_patterns&quot;: [\r\n        &quot;first&quot;\r\n      ],\r\n      &quot;settings&quot;: {\r\n        &quot;index&quot;: {\r\n          &quot;codec&quot;: &quot;best_compression&quot;,\r\n          &quot;refresh_interval&quot;: &quot;30s&quot;,\r\n          &quot;analysis&quot;: {\r\n            &quot;normalizer&quot;: {\r\n              &quot;norm_case_insensitive&quot;: {\r\n                &quot;filter&quot;: &quot;lowercase&quot;,\r\n                &quot;type&quot;: &quot;custom&quot;\r\n              }\r\n            }\r\n          },\r\n          &quot;number_of_shards&quot;: &quot;1&quot;,\r\n          &quot;number_of_replicas&quot;: &quot;1&quot;\r\n        }\r\n      },\r\n      &quot;mappings&quot;: {\r\n        &quot;dynamic&quot;: true,\r\n        &quot;dynamic_templates&quot;: [\r\n          {\r\n            &quot;strings&quot;: {\r\n              &quot;mapping&quot;: {\r\n                &quot;type&quot;: &quot;keyword&quot;\r\n              },\r\n              &quot;match_mapping_type&quot;: &quot;string&quot;\r\n            }\r\n          }\r\n        ],\r\n        &quot;properties&quot;: {\r\n          &quot;log.id&quot;: {\r\n            &quot;type&quot;: &quot;keyword&quot;\r\n          },\r\n          &quot;host.indexer.hostname&quot;: {\r\n            &quot;type&quot;: &quot;keyword&quot;\r\n          },\r\n          &quot;ts_indexer&quot;: {\r\n            &quot;format&quot;: &quot;strict_date_optional_time||epoch_millis&quot;,\r\n            &quot;type&quot;: &quot;date&quot;\r\n          }\r\n        }\r\n      }\r\n    }\r\n    PUT _template/template_second\r\n      {\r\n      &quot;order&quot;: 0,\r\n      &quot;index_patterns&quot;: [\r\n        &quot;second&quot;\r\n      ],\r\n      &quot;settings&quot;: {\r\n        &quot;index&quot;: {\r\n          &quot;codec&quot;: &quot;best_compression&quot;,\r\n          &quot;refresh_interval&quot;: &quot;30s&quot;,\r\n          &quot;analysis&quot;: {\r\n            &quot;normalizer&quot;: {\r\n              &quot;norm_case_insensitive&quot;: {\r\n                &quot;filter&quot;: &quot;lowercase&quot;,\r\n                &quot;type&quot;: &quot;custom&quot;\r\n              }\r\n            }\r\n          },\r\n          &quot;number_of_shards&quot;: &quot;1&quot;,\r\n          &quot;number_of_replicas&quot;: &quot;1&quot;\r\n        }\r\n      },\r\n      &quot;mappings&quot;: {\r\n        &quot;dynamic&quot;: true,\r\n        &quot;dynamic_templates&quot;: [\r\n          {\r\n            &quot;strings&quot;: {\r\n              &quot;mapping&quot;: {\r\n                &quot;type&quot;: &quot;keyword&quot;\r\n              },\r\n              &quot;match_mapping_type&quot;: &quot;string&quot;\r\n            }\r\n          }\r\n        ],\r\n        &quot;properties&quot;: {\r\n          &quot;log.id&quot;: {\r\n            &quot;type&quot;: &quot;keyword&quot;\r\n          },\r\n          &quot;host.indexer.hostname&quot;: {\r\n            &quot;type&quot;: &quot;keyword&quot;\r\n          },\r\n          &quot;ts_indexer&quot;: {\r\n            &quot;format&quot;: &quot;strict_date_optional_time||epoch_millis&quot;,\r\n            &quot;type&quot;: &quot;date&quot;\r\n          }\r\n        }\r\n      }\r\n    }\r\n\r\nI achieved to do the second change : delete one level of the JSON array  by using the command\r\n\r\n    jq  &#39;keys[] as $k | map( .mappings =.mappings._doc   )&#39; template.json\r\n\r\nBut i don&#39;t know how to do the first change and the 2nd change in the same time .\r\n\r\nI tried  to loop into the array like this , without success\r\n\r\n    for row in $(jq &#39;keys[] as $k | &quot;\\($k)&quot;&#39; template.json); do\r\n        _jq() {\r\n         echo ${row} \r\n        }\r\n       echo $(_jq &#39;.name&#39;)\r\n    done\r\n\r\n",
        "link": "https://stackoverflow.com/questions/64431085/generate-multiple-jq-output-documents-from-a-single-input-modifying-each-result",
        "title": "Generate multiple JQ output documents from a single input, modifying each result"
    },
    {
        "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": 1603244663,
                "post_id": 64454740,
                "comment_id": 113973748,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4412853,
                    "reputation": 765,
                    "user_id": 3595231,
                    "user_type": "registered",
                    "accept_rate": 0,
                    "profile_image": "https://www.gravatar.com/avatar/696098c5643657e2de534c56bf80b2a1?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "user3595231",
                    "link": "https://stackoverflow.com/users/3595231/user3595231"
                },
                "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": 1603246399,
                "post_id": 64454740,
                "comment_id": 113974055,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1603248813,
                "last_edit_date": 1603248813,
                "creation_date": 1603248200,
                "answer_id": 64455919,
                "question_id": 64454740,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; let&#39;s say I want to update the status where the name is &quot;lan&quot;\r\n\r\nOne way to update all such objects would be:\r\n\r\n    .interface_settings |= map( if .name == &quot;lan&quot; then .status = &quot;up&quot; else . end)\r\n\r\n## Just the first such\r\n\r\n    .interface_settings |= (reduce .[] as $x (null;\r\n\t  if .done\r\n\t  then .ans += [$x]\r\n      elif $x.name == &quot;lan&quot;\r\n      then .ans += [$x | .status = &quot;up&quot;] | .done = true\r\n      else .ans += [$x]\r\n      end) | .ans)\r\n",
                "title": "how to replace only one key/value pair by using jq in json file?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1603248813,
        "creation_date": 1603237538,
        "question_id": 64454740,
        "body_markdown": "My json template is as of this: \r\n\r\n    { \r\n      &quot;interface_settings&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;lan&quot;, \r\n          &quot;status&quot;: &quot;$status&quot;, \r\n          ...\r\n        },\r\n        {\r\n         &quot;name&quot;: &quot;lte1&quot;,\r\n         &quot;status&quot;: &quot;$status&quot;, \r\n         ...\r\n        },\r\n        { \r\n          ...\r\n        }\r\n      ],\r\n      ...\r\n    }\r\n\r\nAnd my jq command: \r\n\r\n    jq &#39;.interface_settings[].status=&quot;up&quot;&#39; &lt;my_json_template file&gt; \r\n\r\nwill update both status values within the interface_settings section. How may I just have one changed ? \r\n\r\n",
        "link": "https://stackoverflow.com/questions/64454740/how-to-replace-only-one-key-value-pair-by-using-jq-in-json-file",
        "title": "how to replace only one key/value pair by using jq in json file?"
    },
    {
        "tags": [
            "json",
            "jq",
            "transpose"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1603251631,
                "last_edit_date": 1603251631,
                "creation_date": 1603250266,
                "answer_id": 64456168,
                "question_id": 64455986,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This is a bit hairy, but it works:\r\n\r\n    . as $data | \r\n    reduce paths(scalars) as $p (\r\n      [];\r\n      setpath(\r\n        [ $p[1] | tonumber, $p[0] ];\r\n        ( $data | getpath($p) ) \r\n      ) \r\n    )\r\n\r\nFirst, capture the top level as `$data` because `.` is about to get a new value in the `reduce` block.\r\n\r\nThen, call `paths(scalars)` which gives a key path to all of the leaf nodes in the input. e.g. for your sample it would give `[&quot;name&quot;, &quot;0&quot;]` then `[&quot;name&quot;, &quot;1&quot;]`, then `[&quot;loudness&quot;, &quot;0&quot;]`, then `[&quot;loudness&quot;, &quot;1&quot;]`.\r\n\r\nRun a `reduce` on each of those paths, starting the reduction with an empty array.\r\n\r\nFor each path, construct a new path, in the opposite order, with numbers-in-strings turned into real numbers that can be used as array indices, e.g. `[&quot;name&quot;, &quot;0&quot;]` becomes `[0, &quot;name&quot;]`.\r\n\r\nThen use `getpath` to get the value at the old path in `$data` and `setpath` to set a value at the new path in `.` and return it as the next `.` for the `reduce`.\r\n\r\nAt the end, the result will be\r\n\r\n    [\r\n      {\r\n        &quot;name&quot;: &quot;fred&quot;,\r\n        &quot;loudness&quot;: &quot;extreme&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;barney&quot;,\r\n        &quot;loudness&quot;: &quot;not so loud&quot;\r\n      }\r\n    ]\r\n\r\nIf your real data structure might be two levels deep then you would need to replace `[ $p[1] | tonumber, $p[0] ]` with a more appropriate expression to transform the path. Or maybe some of your &quot;values&quot; are objects/arrays that you want to leave alone, in which case you probably need to replace `paths(scalars)` with something like `paths | select(length == 2)`.",
                "title": "&quot;Transpose&quot;/&quot;Rotate&quot;/&quot;Flip&quot; JSON elements"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1603264214,
                "last_edit_date": 1603264214,
                "creation_date": 1603251604,
                "answer_id": 64456342,
                "question_id": 64455986,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Yes, `transpose` is an appropriate word, as the following makes explicit.\r\n\r\nThe following generic helper function makes for a simple solution that is completely agnostic about the key names, both of the enclosing object and the inner objects:\r\n\r\n    # Input: an array of values\r\n    def objectify($keys):\r\n      . as $in | reduce range(0;length) as $i ({}; .[$keys[$i]] = $in[$i]);\r\n\r\n## Assuming consistency of the ordering of the inner keys\r\nAssuming the key names in the inner objects are given in a consistent order, a solution can now obtained as follows:\r\n\r\n    keys_unsorted as $keys\r\n    | [.[] | [.[]]] | transpose\r\n    | map(objectify($keys))\r\n\r\n## Without assuming consistency of the ordering of the inner keys\r\nIf the ordering of the inner keys cannot be assumed to be consistent, then one approach would be to order them, e.g. using this generic helper function:\r\n\r\n    def reorder($keys):\r\n      . as $in | reduce $keys[] as $k ({}; .[$k] = $in[$k]);\r\n\r\nor if you prefer a reduce-free def:\r\n\r\n    def reorder($keys): [$keys[] as $k | {($k): .[$k]}] | add;\r\n\r\nThe &quot;main&quot; program above can then be modified as follows:\r\n```\r\nkeys_unsorted as $keys\r\n| (.[$keys[0]]|keys_unsorted) as $inner\r\n| map_values(reorder($inner))\r\n| [.[] | [.[]]] | transpose\r\n| map(objectify($keys))\r\n```\r\n\r\n#### Caveat\r\nThe preceding solution only considers the key names in the first inner object.\r\n\r\n",
                "title": "&quot;Transpose&quot;/&quot;Rotate&quot;/&quot;Flip&quot; JSON elements"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1603376767,
                "last_edit_date": 1603376767,
                "creation_date": 1603290559,
                "answer_id": 64465807,
                "question_id": 64455986,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&lt;!-- language-all: lang-none --&gt;\r\nBuilding upon [Peak&#39;s solution](https://stackoverflow.com/questions/64455986/transpose-rotate-flip-json-elements/64456342#64456342), here is an alternative based on `group_by` to deal with arbitrary orders of inner keys.\r\n\r\n    keys_unsorted as $keys\r\n    | map(to_entries[])\r\n    | group_by(.key)\r\n    | map(with_entries(.key = $keys[.key] | .value |= .value))\r\n\r\nUsing paths is a good idea [as pointed out by Hobbs](https://stackoverflow.com/questions/64455986/transpose-rotate-flip-json-elements/64456168#64456168). You could also do something like this :\r\n\r\n    [ path(.[][]) as $p | { key: $p[0], value: getpath($p), id: $p[1] } ]\r\n    | group_by(.id)\r\n    | map(from_entries)\r\n",
                "title": "&quot;Transpose&quot;/&quot;Rotate&quot;/&quot;Flip&quot; JSON elements"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 3,
        "last_activity_date": 1603376767,
        "creation_date": 1603248836,
        "last_edit_date": 1603253240,
        "question_id": 64455986,
        "body_markdown": "I would like to &quot;transpose&quot; (not sure that&#39;s the right word) JSON elements.\r\n\r\nFor example, I have a JSON file like this:\r\n```json\r\n{\r\n  &quot;name&quot;: {\r\n    &quot;0&quot;: &quot;fred&quot;,\r\n    &quot;1&quot;: &quot;barney&quot;\r\n  },\r\n  &quot;loudness&quot;: {\r\n    &quot;0&quot;: &quot;extreme&quot;,\r\n    &quot;1&quot;: &quot;not so loud&quot;\r\n  }\r\n}\r\n```\r\n... and I would like to generate a JSON array like this:\r\n```json\r\n[\r\n  {\r\n    &quot;name&quot;: &quot;fred&quot;,\r\n    &quot;loudness&quot;: &quot;extreme&quot;\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;barney&quot;,\r\n    &quot;loudness&quot;: &quot;not so loud&quot;\r\n  }\r\n]\r\n```\r\nMy original JSON has many more first level elements than just &quot;name&quot; and &quot;loudness&quot;, and many more names, features, etc.\r\n\r\nFor this simple example I could fully specify the transformation like this:\r\n```\r\n$ echo &#39;{&quot;name&quot;:{&quot;0&quot;:&quot;fred&quot;,&quot;1&quot;:&quot;barney&quot;},&quot;loudness&quot;:{&quot;0&quot;:&quot;extreme&quot;,&quot;1&quot;:&quot;not so loud&quot;}}&#39;| \\\r\n&gt; jq &#39;[{&quot;name&quot;:.name.&quot;0&quot;, &quot;loudness&quot;:.loudness.&quot;0&quot;},{&quot;name&quot;:.name.&quot;1&quot;, &quot;loudness&quot;:.loudness.&quot;1&quot;}]&#39;\r\n\r\n[\r\n  {\r\n    &quot;name&quot;: &quot;fred&quot;,\r\n    &quot;loudness&quot;: &quot;extreme&quot;\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;barney&quot;,\r\n    &quot;loudness&quot;: &quot;not so loud&quot;\r\n  }\r\n]\r\n```\r\n... but this isn&#39;t feasible for the original JSON.\r\n\r\nHow can jq create the desired output while being key-agnostic for my much larger JSON file?",
        "link": "https://stackoverflow.com/questions/64455986/transpose-rotate-flip-json-elements",
        "title": "&quot;Transpose&quot;/&quot;Rotate&quot;/&quot;Flip&quot; JSON elements"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 10491815,
                    "reputation": 26833,
                    "user_id": 7733418,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b08876b87c096cd006f66820ffc67f27?s=256&d=identicon&r=PG",
                    "display_name": "Yunnosch",
                    "link": "https://stackoverflow.com/users/7733418/yunnosch"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1603261316,
                "post_id": 64457685,
                "comment_id": 113977136,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 15245419,
                    "reputation": 1940,
                    "user_id": 11000412,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Lyxuc.jpg?s=256",
                    "display_name": "Oliver Gaida",
                    "link": "https://stackoverflow.com/users/11000412/oliver-gaida"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1603261528,
                "post_id": 64457685,
                "comment_id": 113977201,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 19769044,
                    "reputation": 93,
                    "user_id": 14476392,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d1f318d11293275eec59fef817fb11af?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Sai",
                    "link": "https://stackoverflow.com/users/14476392/sai"
                },
                "reply_to_user": {
                    "account_id": 15245419,
                    "reputation": 1940,
                    "user_id": 11000412,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Lyxuc.jpg?s=256",
                    "display_name": "Oliver Gaida",
                    "link": "https://stackoverflow.com/users/11000412/oliver-gaida"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1603263723,
                "post_id": 64457685,
                "comment_id": 113977936,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 19769044,
                    "reputation": 93,
                    "user_id": 14476392,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d1f318d11293275eec59fef817fb11af?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Sai",
                    "link": "https://stackoverflow.com/users/14476392/sai"
                },
                "reply_to_user": {
                    "account_id": 10491815,
                    "reputation": 26833,
                    "user_id": 7733418,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b08876b87c096cd006f66820ffc67f27?s=256&d=identicon&r=PG",
                    "display_name": "Yunnosch",
                    "link": "https://stackoverflow.com/users/7733418/yunnosch"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1603263854,
                "post_id": 64457685,
                "comment_id": 113977993,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 10491815,
                    "reputation": 26833,
                    "user_id": 7733418,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b08876b87c096cd006f66820ffc67f27?s=256&d=identicon&r=PG",
                    "display_name": "Yunnosch",
                    "link": "https://stackoverflow.com/users/7733418/yunnosch"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1603264099,
                "post_id": 64457685,
                "comment_id": 113978090,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 19769044,
                    "reputation": 93,
                    "user_id": 14476392,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d1f318d11293275eec59fef817fb11af?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Sai",
                    "link": "https://stackoverflow.com/users/14476392/sai"
                },
                "reply_to_user": {
                    "account_id": 10491815,
                    "reputation": 26833,
                    "user_id": 7733418,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b08876b87c096cd006f66820ffc67f27?s=256&d=identicon&r=PG",
                    "display_name": "Yunnosch",
                    "link": "https://stackoverflow.com/users/7733418/yunnosch"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1603264318,
                "post_id": 64457685,
                "comment_id": 113978193,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 10491815,
                    "reputation": 26833,
                    "user_id": 7733418,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b08876b87c096cd006f66820ffc67f27?s=256&d=identicon&r=PG",
                    "display_name": "Yunnosch",
                    "link": "https://stackoverflow.com/users/7733418/yunnosch"
                },
                "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": 1603264421,
                "post_id": 64457685,
                "comment_id": 113978242,
                "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": 1603264552,
                "post_id": 64457685,
                "comment_id": 113978307,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1603270626,
                "creation_date": 1603270626,
                "answer_id": 64460121,
                "question_id": 64457685,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Since config1.json is a stream of JSON entities, you could use the --slurpfile option:\r\n```\r\njq --slurpfile config1 config1.json &#39;.config += $config1&#39; config.json\r\n```",
                "title": "parse error: Expected value before &#39;,&#39; at line 71, column 2"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1604334260,
        "creation_date": 1603261049,
        "last_edit_date": 1604334260,
        "question_id": 64457685,
        "body_markdown": "I have two `json` files. If I am trying to add them into a single one, it is showing a parse error.\r\n\r\nCan anyone explain how to rectify this?\r\n\r\nThe two files are: `config.json`\r\n\r\n    \r\n```\r\n{   &quot;config&quot; :\r\n    [\r\n    {\r\n    &quot;IP&quot;: &quot;10.97.05.212&quot;,\r\n    &quot;PORT&quot;: 80,\r\n    &quot;USERNAME&quot;: &quot;admin&quot;,\r\n    &quot;ENABLE&quot; : &quot;False&quot;,\r\n   \r\n},\r\n{\r\n    &quot;IP&quot;: &quot;10.27.19.178&quot;,\r\n    &quot;PORT&quot;: 80,\r\n    &quot;USERNAME&quot;: &quot;admin&quot;,\r\n\r\n},\r\n{\r\n    &quot;IP&quot;: &quot;10.26.16.198&quot;,\r\n    &quot;PORT&quot;: 80,\r\n    &quot;USERNAME&quot;: &quot;admin&quot;,\r\n\r\n},\r\n{\r\n    &quot;IP&quot;: &quot;10.47.45.196&quot;,\r\n    &quot;PORT&quot;: 80,\r\n    &quot;USERNAME&quot;: &quot;admin&quot;,\r\n \r\n},\r\n\r\n{\r\n    &quot;IP&quot;: &quot;10.37.67.160&quot;,\r\n    &quot;PORT&quot;: 80,\r\n    &quot;USERNAME&quot;: &quot;admin&quot;,\r\n\r\n\r\n}\r\n\r\n]}\r\n```\r\n\r\n`config1.json`\r\n\r\n    \r\n```\r\n{\r\n  &quot;IP&quot;: &quot;10.27.21.79&quot;,\r\n  &quot;PORT&quot;: 14564,\r\n  &quot;USERNAME&quot;: &quot;admin&quot;,\r\n}\r\n{\r\n  &quot;IP&quot;: &quot;10.27.21.79&quot;,\r\n  &quot;PORT&quot;: 14563,\r\n  &quot;USERNAME&quot;: &quot;admin&quot;,\r\n}\r\n{\r\n  &quot;IP&quot;: &quot;10.27.21.79&quot;,\r\n  &quot;PORT&quot;: 14566,\r\n  &quot;USERNAME&quot;: &quot;admin&quot;,\r\n}\r\n\r\n\r\n```\r\n\r\n`jq -n &#39;input | .config += [inputs]&#39; config.json config1.json`\r\n\r\n`jq  &#39; .[] += [ input ]&#39; config.json config1.json`\r\n\r\n`jq -s add config.json database.db`\r\n\r\n`jq --slurp . config.json config1.json`\r\n\r\n\r\nI have used above `jq` commands to do the task. But getting the same parse error: \r\n\r\n`Expected value before &#39;,&#39;` \r\n\r\nCan anyone explain how to do rectify this error?\r\n",
        "link": "https://stackoverflow.com/questions/64457685/parse-error-expected-value-before-at-line-71-column-2",
        "title": "parse error: Expected value before &#39;,&#39; at line 71, column 2"
    },
    {
        "tags": [
            "bash",
            "amazon-web-services",
            "shell",
            "jq",
            "aws-codebuild"
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1603265194,
                "creation_date": 1603265194,
                "answer_id": 64458618,
                "question_id": 64458304,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can try the following in your `build`:\r\n\r\n```\r\n  build:\r\n    commands:\r\n      - aws ecr list-images --repository-name mytestecrrepo &gt; ecr.json\r\n      - cat ecr.json\r\n      - |\r\n        for imageTag in $(jq -r &#39;.imageIds[].imageTag&#39; &lt; ecr.json); do \r\n        if [ $imageTag = &quot;1.0&quot; ]; then \r\n        echo &quot;value exists&quot; \r\n        else \r\n        echo &quot;value doesntexists&quot; \r\n        fi \r\n        done\r\n```",
                "title": "Error in in codebuild while executing if else condition inside for loop"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1603265194,
        "creation_date": 1603263903,
        "question_id": 64458304,
        "body_markdown": "Below is my buildspec.yaml file to list the images inside ecr and I&#39;m using to for loop and if elese condition to find a particular imageId exists or not\r\n```\r\nversion: 0.2\r\n\r\nphases:\r\n\r\n  install:\r\n    runtime-versions:\r\n      nodejs: 12\r\n    commands:\r\n      - echo test\r\n  pre_build:\r\n    commands:\r\n      - echo Logging in to Amazon ECR...\r\n      - aws --version\r\n      - $(aws ecr get-login --region $AWS_DEFAULT_REGION --no-include-email)\r\n\r\n  build:\r\n    commands:\r\n      - aws ecr list-images --repository-name mytestecrrepo &gt; ecr.json\r\n      - cat ecr.json\r\n      - for imageTag in $(jq -r &#39;.imageIds[].imageTag&#39; &lt; ecr.json); do \r\n        if [ $imageTag = &quot;1.0&quot; ]; then \r\n        echo &quot;value exists&quot; \r\n        else \r\n        echo &quot;value doesntexists&quot; \r\n        fi \r\n        done\r\n  post_build:\r\n    commands:\r\n      - echo Build completed on `date`\r\n```\r\nFor some reason, code build is throwing the below error\r\n\r\n**/codebuild/output/tmp/script.sh: line 9: syntax error: unexpected end of file**\r\n\r\nI&#39;m doing something wrong within the shell script?",
        "link": "https://stackoverflow.com/questions/64458304/error-in-in-codebuild-while-executing-if-else-condition-inside-for-loop",
        "title": "Error in in codebuild while executing if else condition inside for loop"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1603310473,
                "last_edit_date": 1603310473,
                "creation_date": 1603309522,
                "answer_id": 64470694,
                "question_id": 64469597,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is a `test.jq` file which may help\r\n    \r\n    # utility to create lookup table from array of objects\r\n    # k is the name to use as the key\r\n    # f is a function to compute the value\r\n    #\r\n    def obj(k;f): reduce .[] as $o ({}; .[$o[k]] = ($o | f));\r\n    \r\n    # create map from county to count\r\n      ( $file2 | obj(&quot;County&quot;;.Count) ) as $count\r\n    \r\n    # add .properties.Count to each feature\r\n    | .features |= map( .properties.Count = $count[.properties.NAME] )\r\n\r\n\r\nExample use assuming suitable `file1.json` and `file2.json`:\r\n\r\n    $ jq -M --argfile file2 file2.json -f test.jq file1.json\r\n    {\r\n      &quot;type&quot;: &quot;FeatureCollection&quot;,\r\n      &quot;features&quot;: [\r\n        {\r\n          &quot;type&quot;: &quot;Feature&quot;,\r\n          &quot;properties&quot;: {\r\n            &quot;GEO_ID&quot;: &quot;0500000US06001&quot;,\r\n            &quot;STATE&quot;: &quot;06&quot;,\r\n            &quot;COUNTY&quot;: &quot;001&quot;,\r\n            &quot;NAME&quot;: &quot;Alameda&quot;,\r\n            &quot;LSAD&quot;: &quot;County&quot;,\r\n            &quot;CENSUSAREA&quot;: 739.017,\r\n            &quot;Count&quot;: 25\r\n          },\r\n          &quot;geometry&quot;: {\r\n            &quot;type&quot;: &quot;Polygon&quot;,\r\n            &quot;coordinates&quot;: [\r\n              [\r\n                [\r\n                  -122.30936,\r\n                  37.77615\r\n                ],\r\n                [\r\n                  -122.317215,\r\n                  37.778527\r\n                ]\r\n              ]\r\n            ]\r\n          }\r\n        }\r\n      ]\r\n    }\r\n\r\n[Try it online!](https://tio.run/##jVLbjpswEH33V4zIPgQpRUCU0N0oDzRNq0pttmqShypClRfMLhvA1JhKaJNvT8cGdnOrVEug8cyZc@bi59@HHpRJVqVUMoiTlLnWc8lzsiEAL/gBGDNe5bI27sDwU5qxiBqDowD63RHe94OrGRmNuDhPcP6J/1BJyS74FZwEQEu40SWSHVZdySRNZA2SQyiYKj/lfFsVIOlDir0IngEVgtbAY@APzyyUJenBFpIS5BODHHtRyVXJFLNybVmNiFghKMRVHsqE51qAZ0WFCgr0h6YVIz0SMU3b305i8w4Ei6qQgbVpyuTQf9lP8HrDN9sggCn00beD2DQnBDXaijNaNIWGegKNFFrYcL/tFZOUSjejiaUNE0yt06CRkEYRWIXgBRMyYWWDUnyMhk8Qo1olGNmB1Zol7KZKvn8la9rybo5DC//bPACTHA5qaYasC6YW9qmhm/E0ZXpcenlGp4KQjV5ms@nLxHbXGHjTwnAHR//n@f2vLx9Vij2y1Vkv7bFtO6@ZiFmu/NVcQ8bH7tn9erH6qf2neNXM5YPWoa9LX4u18z5mmy@W66X/Y@5j3BveWrbjtdH9axePjGdMivq0h67p7zytH9sZtaGQcxElOb6Gt2E159g@vwG8c1zXGtq3w/HgLDL0LM8bO6MTdzD4DzbHc53RVbr3I9c75SPX7M7ak@4fkP1f &quot;jq – Try It Online&quot;)\r\n\r\nI notice that &quot;Count&quot; is a string in your example output but it&#39;s a number in the sample file2.  If you need to convert that to a string you can include a call to `tostring`.  e.g.\r\n```\r\n.features |= map( .properties.Count = ( $count[.properties.NAME] | tostring ) )\r\n```\r\n\r\nor you could perform the conversion when the lookup table is created, e.g.\r\n```\r\n  ( $file2 | obj(&quot;County&quot;; .Count | tostring ) ) as $count\r\n```",
                "title": "Appending Geojson with json field using JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1603312287,
        "creation_date": 1603304915,
        "last_edit_date": 1603312287,
        "question_id": 64469597,
        "body_markdown": "I have a project I&#39;m working on that creates a choropleth map with all US county borders loaded from `file1.json` and filled with a color gradient based on values in `file2.json`. In previous iterations, I just enter values manually into `file1.json`, but now I want to expand my map and make it more user-friendly. \r\n\r\n`file1.json` is structured like this:\r\n\r\n```json\r\n{\r\n  &quot;type&quot;: &quot;FeatureCollection&quot;,\r\n  &quot;features&quot;: [\r\n    {\r\n      &quot;type&quot;: &quot;Feature&quot;,\r\n      &quot;properties&quot;: {\r\n        &quot;GEO_ID&quot;: &quot;0500000US06001&quot;,\r\n        &quot;STATE&quot;: &quot;06&quot;,\r\n        &quot;COUNTY&quot;: &quot;001&quot;,\r\n        &quot;NAME&quot;: &quot;Alameda&quot;,\r\n        &quot;LSAD&quot;: &quot;County&quot;,\r\n        &quot;CENSUSAREA&quot;: 739.017\r\n      },\r\n      &quot;geometry&quot;: {\r\n        &quot;type&quot;: &quot;Polygon&quot;,\r\n        &quot;coordinates&quot;: [\r\n          [\r\n            [\r\n              -122.30936,\r\n              37.77615\r\n            ],\r\n            [\r\n              -122.317215,\r\n              37.778527\r\n            ]\r\n          ]\r\n        ]\r\n      }\r\n    },\r\n    ...\r\n  ]\r\n}\r\n```\r\n\r\n`file2.json` is structued like this:\r\n\r\n```json\r\n[\r\n  {\r\n    &quot;County&quot;: &quot;Alameda&quot;,\r\n    &quot;Count&quot;: 25\r\n  },\r\n  {\r\n    &quot;County&quot;: &quot;Amador&quot;,\r\n    &quot;Count&quot;: 1\r\n  },\r\n  {\r\n    &quot;County&quot;: &quot;Butte&quot;,\r\n    &quot;Count&quot;: 2\r\n  },\r\n  ...\r\n]\r\n```\r\n\r\nI want to create a new file that includes everything from `file1.json`, but append it to include the relevent Count field based on the County field.\r\n\r\nThe result would look like this:\r\n\r\n```json\r\n[\r\n{\r\n  &quot;type&quot;: &quot;Feature&quot;,\r\n  &quot;properties&quot;: {\r\n    &quot;GEO_ID&quot;: &quot;0500000US06001&quot;,\r\n    &quot;STATE&quot;: &quot;06&quot;,\r\n    &quot;COUNTY&quot;: &quot;001&quot;,\r\n    &quot;NAME&quot;: &quot;Alameda&quot;,\r\n    &quot;Count&quot;: &quot;25&quot;,\r\n    &quot;LSAD&quot;: &quot;County&quot;,\r\n    &quot;CENSUSAREA&quot;: 739.017\r\n  },\r\n  &quot;geometry&quot;: {\r\n    &quot;type&quot;: &quot;Polygon&quot;,\r\n    &quot;coordinates&quot;: [\r\n      [\r\n        [\r\n          -122.30936,\r\n          37.77615\r\n        ],\r\n        [\r\n          -122.317215,\r\n          37.778527\r\n        ]\r\n      ]\r\n    ]\r\n  }\r\n},\r\n...\r\n]\r\n```\r\n\r\nI&#39;m new to using `jq`, but I&#39;ve played around with it enough to get it running in PowerShell.\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/64469597/appending-geojson-with-json-field-using-jq",
        "title": "Appending Geojson with json field using JQ"
    },
    {
        "tags": [
            "bash",
            "jq",
            "aws-cli"
        ],
        "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": 1603345191,
                "post_id": 64475175,
                "comment_id": 114008775,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6929182,
                    "reputation": 1051,
                    "user_id": 5319217,
                    "user_type": "registered",
                    "accept_rate": 48,
                    "profile_image": "https://www.gravatar.com/avatar/426d5e922fc8bc507a9658cbadd58825?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "fledgling",
                    "link": "https://stackoverflow.com/users/5319217/fledgling"
                },
                "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": 1603345486,
                "post_id": 64475175,
                "comment_id": 114008854,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1603375367,
                "last_edit_date": 1603375367,
                "creation_date": 1603354554,
                "answer_id": 64478024,
                "question_id": 64475175,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Assuming that you are looking to look for the next entry in the output after latest, since you already have the output at text you can pipe the output through to sed and so:\r\n\r\n    aws ecr .... | sed -n &#39;/latest/{n;p}&#39;\r\n\r\nSearch the output of the aws cli command and search for the string latest. When finding this string, skip to the next line of output and print\r\n\r\nWith awk, taking account of multiple latest tags one after the other\r\n\r\n    aws ecr .... | awk &#39;/latest/ { getline;while ($0==&quot;latest&quot;) { getline } print $0 }&#39;\r\n\r\nPattern match lines in the output against latest and then run a while loop that moves to the next line if another instance of the string latest is encountered.\r\n\r\n    aws ecr .... | awk &#39;/latest/&amp;&amp;cnt&lt;1 { getline;while ($0==&quot;latest&quot;) { getline } print $0;cnt++ } { arr[NR]=$0 } END { if (cnt==&quot;&quot;) { print arr[1] } }&#39;\r\n\r\nAnother variation of awk using cnt to ensure that only the first instance found is printed (in case there are multiple latest tags with one not after the other)\r\nAn array arr is also created containing each line. If no latest tags are found, the first tag is printed.\r\n    ",
                "title": "Pick the latest ECR image which is not tagged latest"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1603375367,
        "creation_date": 1603339700,
        "question_id": 64475175,
        "body_markdown": "I need to be able to pick the latest tagged image in a ECR repository which does not have the tag latest.\r\n\r\nI am trying to achieve this through aws cli and bash/jq\r\n\r\n    aws ecr describe-images --repository-name &lt;repo-name&gt; --region us-east-1 --output text --query &#39;sort_by(imageDetails,&amp; imagePushedAt)[*].imageTags[*]&#39; | tr &#39;\\t&#39; &#39;\\n&#39; | tail -2\r\n\r\nThe `imageTag` output here is \r\n\r\n    ajohn-feature-123\r\n    bgates-feature-345\r\n\r\nThe list may contain `latest` as one of the entries. I want to skip that entry and pick the first imageTag here which is not latest.\r\n\r\nAppreciate any help in achieving this.\r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/64475175/pick-the-latest-ecr-image-which-is-not-tagged-latest",
        "title": "Pick the latest ECR image which is not tagged latest"
    },
    {
        "tags": [
            "json",
            "bash",
            "zsh",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6313442,
                    "reputation": 45115,
                    "user_id": 5625547,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/oqCND.jpg?s=256",
                    "display_name": "0stone0",
                    "link": "https://stackoverflow.com/users/5625547/0stone0"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1603373957,
                "post_id": 64483462,
                "comment_id": 114021639,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1974896,
                    "reputation": 14280,
                    "user_id": 1772898,
                    "user_type": "registered",
                    "accept_rate": 65,
                    "profile_image": "https://www.gravatar.com/avatar/f768b6e41490b85bcfa9823404519fa8?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Ahmad Ismail",
                    "link": "https://stackoverflow.com/users/1772898/ahmad-ismail"
                },
                "reply_to_user": {
                    "account_id": 6313442,
                    "reputation": 45115,
                    "user_id": 5625547,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/oqCND.jpg?s=256",
                    "display_name": "0stone0",
                    "link": "https://stackoverflow.com/users/5625547/0stone0"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1603374037,
                "post_id": 64483462,
                "comment_id": 114021688,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1603376320,
                "last_edit_date": 1603376320,
                "creation_date": 1603374041,
                "answer_id": 64483536,
                "question_id": 64483462,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use [tag:jq]&#39;s `-r` option ([docs](https://stedolan.github.io/jq/manual/#Invokingjq)):\r\n```\r\njq -r &#39;.tree[]|.path&#39; &lt; &lt;(curl -H &quot;Accept: application/vnd.github.full+json&quot; -H &quot;Authorization: &lt;MY-KEY&gt;&quot; &quot;https://api.github.com/repos/zsh-users/zsh-syntax-highlighting/git/trees/master?recursive=1&quot;)\r\n```\r\n\r\nThis uses a bash [Process Substitution](https://www.gnu.org/software/bash/manual/bash.html#Process-Substitution) so the interesting part of the answer shows up first. You could write `curl ... | jq ...`\r\n\r\nResult:\r\n```\r\neditorconfig\r\n.gitattributes\r\n.gitignore\r\n.revision-hash\r\n.travis.yml\r\n.version\r\nCOPYING.md\r\nHACKING.md\r\n...\r\n```\r\n",
                "title": "convert simple json array to plain text"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1603376320,
        "creation_date": 1603373812,
        "question_id": 64483462,
        "body_markdown": "The current command I am using is:\r\n\r\n    curl -H &quot;Accept: application/vnd.github.full+json&quot; -H &quot;Authorization: 7c258a9869f33c1e1e1f74fbb32f07c86cb5a75b&quot; &quot;https://api.github.com/repos/zsh-users/zsh-syntax-highlighting/git/trees/master?recursive=1&quot; | jq &#39;.tree[]|.path&#39;\r\n\r\nI have a return value like\r\n\r\n    [\r\n      &quot;.editorconfig&quot;,\r\n      &quot;.gitattributes&quot;,\r\n      &quot;.gitignore&quot;,\r\n      &quot;.revision-hash&quot;,\r\n      &quot;.travis.yml&quot;,\r\n      &quot;.version&quot;,\r\n      &quot;COPYING.md&quot;,\r\n      &quot;HACKING.md&quot;,\r\n      &quot;INSTALL.md&quot;,\r\n      &quot;Makefile&quot;,\r\n      &quot;README.md&quot;,\r\n      &quot;changelog.md&quot;,\r\n      &quot;docs&quot;,\r\n      &quot;docs/highlighters.md&quot;,\r\n      &quot;docs/highlighters&quot;,\r\n      &quot;docs/highlighters/brackets.md&quot;,\r\n      &quot;docs/highlighters/cursor.md&quot;,\r\n      &quot;docs/highlighters/line.md&quot;,\r\n      .....\r\n    ]\r\n\r\nI want the return value to be like\r\n\r\n    .editorconfig\r\n    .gitattributes\r\n    .gitignore\r\n    .revision-hash\r\n    .travis.yml\r\n    .version\r\n    COPYING.md\r\n    HACKING.md\r\n    INSTALL.md\r\n    Makefile\r\n    README.md\r\n    changelog.md\r\n    docs\r\n    docs/highlighters.md\r\n    docs/highlighters\r\n    docs/highlighters/brackets.md\r\n    docs/highlighters/cursor.md\r\n    docs/highlighters/line.md\r\n    ....",
        "link": "https://stackoverflow.com/questions/64483462/convert-simple-json-array-to-plain-text",
        "title": "convert simple json array to plain text"
    },
    {
        "tags": [
            "arrays",
            "json",
            "key",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1293198,
                    "reputation": 19192,
                    "user_id": 1244884,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/79435cc2571ffa23dfcef703f8d762e0?s=256&d=identicon&r=PG",
                    "display_name": "customcommander",
                    "link": "https://stackoverflow.com/users/1244884/customcommander"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1603401637,
                "post_id": 64490635,
                "comment_id": 114034675,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1603402603,
                "post_id": 64490635,
                "comment_id": 114035005,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2670850,
                    "reputation": 3194,
                    "user_id": 2308300,
                    "user_type": "registered",
                    "accept_rate": 75,
                    "profile_image": "https://i.sstatic.net/zs5xn.jpg?s=256",
                    "display_name": "Locane",
                    "link": "https://stackoverflow.com/users/2308300/locane"
                },
                "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": 1603821235,
                "post_id": 64490635,
                "comment_id": 114156332,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1603402564,
                "creation_date": 1603402564,
                "answer_id": 64490880,
                "question_id": 64490635,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Assuming you want each key with its length on the same line, you could go with something like:\r\n\r\n    jq -r &#39;keys_unsorted[] as $k | [$k, (.[$k]|length)] | join(&quot; &quot;)&#39; \r\n\r\nIf you want the key name to be quoted, use the filter:\r\n\r\n    keys_unsorted[] as $k | &quot;\\&quot;\\($k)\\&quot; \\(.[$k]|length)&quot;\r\n",
                "title": "jq display key names and their child element lengths together"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1603821265,
        "creation_date": 1603401295,
        "last_edit_date": 1603821265,
        "question_id": 64490635,
        "body_markdown": "I would like to display an arbitrary object&#39;s key names and the lengths of their constituent parts.  I think that my trouble appears to be with &#39;length&#39; requiring a filter, which mutes other output.\r\n\r\nGiven foo.json contains:\r\n\r\n\r\n    {\r\n        &quot;lol&quot;: 1, \r\n        &quot;wtf&quot;: [1, 2, 3, 4], \r\n        &quot;bbq&quot;: {\r\n            &quot;omg&quot;: &quot;yes&quot;, \r\n            &quot;afk&quot;: &quot;always&quot;\r\n        }\r\n    }\r\n\r\nI can:\r\n    \r\n    cat foo.json |jq &#39;keys&#39;\r\n    [\r\n      &quot;bbq&quot;,\r\n      &quot;lol&quot;,\r\n      &quot;wtf&quot;\r\n    ]\r\n    \r\nAnd I can:\r\n\r\n    cat foo.json |jq &#39;.[] |length&#39;\r\n    1\r\n    4\r\n    2\r\n\r\nBut how do I get both on the same (or I would even accept alternating) line?\r\n\r\n    &quot;bbq&quot; 2\r\n    &quot;lol&quot; 1\r\n    &quot;wtf&quot; 4",
        "link": "https://stackoverflow.com/questions/64490635/jq-display-key-names-and-their-child-element-lengths-together",
        "title": "jq display key names and their child element lengths together"
    },
    {
        "tags": [
            "json",
            "formatting",
            "jq",
            "aws-cli",
            "amazon-ecr"
        ],
        "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": 1603438994,
                "post_id": 64495891,
                "comment_id": 114043163,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 958495,
                    "reputation": 305,
                    "user_id": 983325,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d0722d889abf8575c32444bd640dc38b?s=256&d=identicon&r=PG",
                    "display_name": "F&#225;bio Almeida",
                    "link": "https://stackoverflow.com/users/983325/f%c3%a1bio-almeida"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1603447585,
                "post_id": 64495891,
                "comment_id": 114046763,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1450087,
                    "reputation": 12022,
                    "user_id": 1409374,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/97d424fe924f2139812a4a6de1ef6b79?s=256&d=identicon&r=PG",
                    "display_name": "rickhg12hs",
                    "link": "https://stackoverflow.com/users/1409374/rickhg12hs"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1603561521,
                "post_id": 64495891,
                "comment_id": 114078994,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1603609419,
                "creation_date": 1603609419,
                "answer_id": 64521182,
                "question_id": 64495891,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The following produces a table with nested subtables in accorance with my\r\nunderstanding of the basic requirements.\r\n\r\n## Example\r\nTo clarify what the main function `json2tree` does, here is an example:\r\n\r\n### Input:\r\n\r\n```json\r\n[\r\n  {&quot;a&quot;: 1,&quot;b&quot;: 2,&quot;ary&quot;:[{&quot;c&quot;:0,&quot;d&quot;:1},{&quot;c&quot;:10,&quot;d&quot;:11}],&quot;another&quot;:[{&quot;a&quot;:1,&quot;b&quot;:2}]},\r\n  {&quot;a&quot;:10,&quot;b&quot;:20,&quot;c&quot;:30,&quot;ary&quot;:[{&quot;e&quot;:0,&quot;f&quot;:1},{&quot;g&quot;:10,&quot;h&quot;:11}],&quot;xyzzy&quot;:&quot;x&quot;}\r\n ] \r\n```\r\n### Output (untabified):\r\n```\r\na       b       ary                             another         c       xyzzy\r\n1       2       c       d                       a       b       null    null\r\n                0       1                       1       2               \r\n                10      11                                              \r\n10      20      e       f       g       h                       30      x\r\n                0       1       null    null                            \r\n                null    null    10      11                              \r\n\t\t\t\r\n```\r\n\r\n## Assumptions\r\n\r\nBugs aside, the only assumptions regarding the input data are as follows:\r\n1. The input is an array of JSON objects, $a;\r\n2. If $a[$i][$k] is an array of JSON objects for some $i and some key $k,\r\n    then $a[$j][$k] is an array of JSON objects for all $j \r\n\r\n## Robustness\r\n\r\nThe complexity (or at least length) of the implementation is the result of its being fairly robust with respect to the input data.  For example, there is no requirement that the top-level objects have the same keys, or that they be specified in a consistent order.\r\n\r\nThis robustness, however, is achieved at the cost that `tostring` is called whenever a non-scalar\r\nJSON entity is found in a context that is not envisioned by (2) above.\r\n\r\n## Helper Functions\r\n```\r\n# determine if the input is an array of JSON objects\r\ndef is_array_of_objects: type==&quot;array&quot; and all(.[]; type==&quot;object&quot;);\r\n\r\n# input: a JSON object\r\ndef reorder_keys($object): . as $in | $object | with_entries(.value = $in[.key]);\r\n\r\n# input: an array of one or more objects\r\n# output: an array of similar objects but altered by adding null values so that they all have the same keys,\r\n#         and so that the keys are in the same order\r\ndef synthesize:\r\n  (add|map_values(null)) as $a\r\n  | map($a + .)\r\n  | .[0] as $template\r\n  | map(reorder_keys($template));\r\n\r\n# Input: an array of conformal objects, i.e., with the same keys,\r\n#        and such that if .[$i][$k] is an array of objects for any $i or $i, then .[$j][$k] is \r\n#        also an array of objects for all $j\r\n# Output: an object with the same keys but with the value replaced by the max `length` for an array of objects,\r\n#        and -1 otherwise.\r\ndef object_of_widths:\r\n  def w: map_values(if is_array_of_objects then .[0]|length else -1 end);\r\n  def keywise_maximum($x; $y): reduce ($y|keys_unsorted)[] as $k ({}; .[$k] = ([$x[$k],$y[$k]]|max));\r\n  reduce (.[]|w) as $w ({}; keywise_maximum(.; $w));\r\n\r\n```\r\n## Main program\r\n```\r\n# Input: an array of objects\r\n# Output: a table that treats top-level arrays of JSON objects specially\r\ndef json2tree:\r\n\r\n  # input: an array\r\n  # output: an array of length at least $n\r\n  def rpad($n): . + [range(0;$n-length)|null];\r\n  \r\n  # input: an object\r\n  def print_first_line($keys; $widths):\r\n    [$keys[] as $k | $k, (if $widths[$k] == -1 then empty else range(1;$widths[$k]) | null end)];\r\n    \r\n  # input: an object\r\n  def print_second_line($keys; $widths):\r\n    [$keys[] as $k\r\n    | if $widths[$k] == -1\r\n      then .[$k]|tostring\r\n      elif .[$k] then .[$k][0]|keys_unsorted|rpad($widths[$k])[]\r\n      else range(0; $widths[$k]) | null\r\n      end];\r\n\r\n  # input: an object\r\n  # $i - the $i-th object in the array\r\n  def print_nth_line($i; $keys; $widths):\r\n    [$keys[] as $k\r\n    | if $widths[$k] == -1\r\n      then null\r\n      elif $i &lt; (.[$k]|length)\r\n      then (.[$k][$i] | map(tostring) | rpad($widths[$k]))[]\r\n      else (range(0;$widths[$k])|null)\r\n      end] ;\r\n\r\n  synthesize\r\n  | map(map_values(if is_array_of_objects then synthesize else . end))\r\n  | (.[0] | keys_unsorted) as $keys\r\n  | object_of_widths as $widths\r\n  | (.[0] | print_first_line($keys; $widths)),\r\n    (range(0; length) as $ix\r\n     | (.[$ix] | print_second_line($keys; $widths)),\r\n       (.[$ix]\r\n        | ([.[] | if is_array_of_objects then length else 0 end] | max) as $mx\r\n        | range(0; $mx) as $i | print_nth_line($i; $keys; $widths) ) ) ;\r\n\r\njson2tree | @tsv\r\n```",
                "title": "JSON to table formatting (got it from - http://json2table.com)"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1603609419,
        "creation_date": 1603438898,
        "last_edit_date": 1603440300,
        "question_id": 64495891,
        "body_markdown": "I am currently trying to integrate AWS ECR Scanning to our CI/CD pipeline and pass the results to our engineers in a human readable form.\r\n\r\nThe command - `aws ecr describe-image-scan-findings --repository-name ${REPNAME} --image-id imageTag=latest --profile ${PROFILE} --region ${REGION}` \r\n\r\nReturns something like the following [redacted] output - \r\n\r\n```{\r\n    &quot;imageScanFindings&quot;: {\r\n        &quot;findings&quot;: [\r\n            {\r\n                &quot;name&quot;: &quot;CVE-2018-12886&quot;,\r\n                &quot;description&quot;: &quot;stack_protect_prologue in cfgexpand.c and stack_protect_epilogue in function.c in GNU Compiler Collection (GCC) 4.1 through 8 (under certain circumstances) generate instruction sequences when targeting ARM targets that spill the address of the stack protector guard, which allows an attacker to bypass the protection of -fstack-protector, -fstack-protector-all, -fstack-protector-strong, and -fstack-protector-explicit against stack overflow by controlling what the stack canary is compared against.&quot;,\r\n                &quot;uri&quot;: &quot;https://security-tracker.debian.org/tracker/CVE-2018-12886&quot;,\r\n                &quot;severity&quot;: &quot;MEDIUM&quot;,\r\n                &quot;attributes&quot;: [\r\n                    {\r\n                        &quot;key&quot;: &quot;package_version&quot;,\r\n                        &quot;value&quot;: &quot;8.3.0-6&quot;\r\n                    },\r\n                    {\r\n                        &quot;key&quot;: &quot;package_name&quot;,\r\n                        &quot;value&quot;: &quot;gcc-8&quot;\r\n                    },\r\n                    {\r\n                        &quot;key&quot;: &quot;CVSS2_VECTOR&quot;,\r\n                        &quot;value&quot;: &quot;AV:N/AC:M/Au:N/C:P/I:P/A:P&quot;\r\n                    },\r\n                    {\r\n                        &quot;key&quot;: &quot;CVSS2_SCORE&quot;,\r\n                        &quot;value&quot;: &quot;6.8&quot;\r\n                    }\r\n                ]\r\n            },\r\n            {\r\n                &quot;name&quot;: &quot;CVE-2020-1751&quot;,\r\n                &quot;description&quot;: &quot;An out-of-bounds write vulnerability was found in glibc before 2.31 when handling signal trampolines on PowerPC. Specifically, the backtrace function did not properly check the array bounds when storing the frame address, resulting in a denial of service or potential code execution. The highest threat from this vulnerability is to system availability.&quot;,\r\n                &quot;uri&quot;: &quot;https://security-tracker.debian.org/tracker/CVE-2020-1751&quot;,\r\n                &quot;severity&quot;: &quot;MEDIUM&quot;,\r\n                &quot;attributes&quot;: [\r\n                    {\r\n                        &quot;key&quot;: &quot;package_version&quot;,\r\n                        &quot;value&quot;: &quot;2.28-10&quot;\r\n                    },\r\n                    {\r\n                        &quot;key&quot;: &quot;package_name&quot;,\r\n                        &quot;value&quot;: &quot;glibc&quot;\r\n                    },\r\n                    {\r\n                        &quot;key&quot;: &quot;CVSS2_VECTOR&quot;,\r\n                        &quot;value&quot;: &quot;AV:L/AC:M/Au:N/C:P/I:P/A:C&quot;\r\n                    },\r\n                    {\r\n                        &quot;key&quot;: &quot;CVSS2_SCORE&quot;,\r\n                        &quot;value&quot;: &quot;5.9&quot;\r\n                    }\r\n                ]\r\n            },\r\n            {\r\n                &quot;name&quot;: &quot;CVE-2019-20367&quot;,\r\n                &quot;description&quot;: &quot;nlist.c in libbsd before 0.10.0 has an out-of-bounds read during a comparison for a symbol name from the string table (strtab).&quot;,\r\n                &quot;uri&quot;: &quot;https://security-tracker.debian.org/tracker/CVE-2019-20367&quot;,\r\n                &quot;severity&quot;: &quot;MEDIUM&quot;,\r\n                &quot;attributes&quot;: [\r\n                    {\r\n                        &quot;key&quot;: &quot;package_version&quot;,\r\n                        &quot;value&quot;: &quot;0.9.1-2&quot;\r\n                    },\r\n                    {\r\n                        &quot;key&quot;: &quot;package_name&quot;,\r\n                        &quot;value&quot;: &quot;libbsd&quot;\r\n                    },\r\n                    {\r\n                        &quot;key&quot;: &quot;CVSS2_VECTOR&quot;,\r\n                        &quot;value&quot;: &quot;AV:N/AC:L/Au:N/C:P/I:N/A:P&quot;\r\n                    },\r\n                    {\r\n                        &quot;key&quot;: &quot;CVSS2_SCORE&quot;,\r\n                        &quot;value&quot;: &quot;6.4&quot;\r\n                    }\r\n                ]\r\n            },\r\n            {\r\n                &quot;name&quot;: &quot;CVE-2019-12904&quot;,\r\n                &quot;description&quot;: &quot;In Libgcrypt 1.8.4, the C implementation of AES is vulnerable to a flush-and-reload side-channel attack because physical addresses are available to other processes. (The C implementation is used on platforms where an assembly-language implementation is unavailable.)&quot;,\r\n                &quot;uri&quot;: &quot;https://security-tracker.debian.org/tracker/CVE-2019-12904&quot;,\r\n                &quot;severity&quot;: &quot;MEDIUM&quot;,\r\n                &quot;attributes&quot;: [\r\n                    {\r\n                        &quot;key&quot;: &quot;package_version&quot;,\r\n                        &quot;value&quot;: &quot;1.8.4-5&quot;\r\n                    },\r\n                    {\r\n                        &quot;key&quot;: &quot;package_name&quot;,\r\n                        &quot;value&quot;: &quot;libgcrypt20&quot;\r\n                    },\r\n                    {\r\n                        &quot;key&quot;: &quot;CVSS2_VECTOR&quot;,\r\n                        &quot;value&quot;: &quot;AV:N/AC:M/Au:N/C:P/I:N/A:N&quot;\r\n                    },\r\n                    {\r\n                        &quot;key&quot;: &quot;CVSS2_SCORE&quot;,\r\n                        &quot;value&quot;: &quot;4.3&quot;\r\n                    }\r\n                ]\r\n            }\r\n        ],\r\n        &quot;imageScanCompletedAt&quot;: &quot;2020-10-23T00:03:10+05:30&quot;,\r\n        &quot;vulnerabilitySourceUpdatedAt&quot;: &quot;2020-10-22T16:21:44+05:30&quot;,\r\n        &quot;findingSeverityCounts&quot;: {\r\n            &quot;MEDIUM&quot;: 14,\r\n            &quot;INFORMATIONAL&quot;: 72,\r\n            &quot;LOW&quot;: 18,\r\n            &quot;UNDEFINED&quot;: 3\r\n        }\r\n    },\r\n    &quot;registryId&quot;: &quot;12345678911&quot;,\r\n    &quot;repositoryName&quot;: &quot;name-of-repo&quot;,\r\n    &quot;imageId&quot;: {\r\n        &quot;imageDigest&quot;: &quot;sha256:1213412412412451241414214141412412&quot;,\r\n        &quot;imageTag&quot;: &quot;latest&quot;\r\n    },\r\n    &quot;imageScanStatus&quot;: {\r\n        &quot;status&quot;: &quot;COMPLETE&quot;,\r\n        &quot;description&quot;: &quot;The scan was completed successfully.&quot;\r\n    }\r\n}\r\n```\r\n\r\nThe above is not human friendly to read, especially if there are a lot of findings and the JSON output runs into hundreds of lines.\r\n\r\nI want to convert the above output in a more &quot;human&quot; readable form without omitting any of the returned info. I tried using the `--output table` option for `AWS CLI` but it is including a lot of spaces in between the columns and rows.\r\n\r\nI tried using `jq` to convert it into a table or .tsv of some sort using `map`, but with no luck as I am a total beginner in JQ. If someone has any ideas on how to approach this - any help would be appreciated.\r\n\r\nAiming to get something along the following lines which I got from http://json2table.com/ - \r\n\r\n[Expected Formatted Output][1]\r\n\r\n\r\n  [1]: https://i.sstatic.net/mk36c.png",
        "link": "https://stackoverflow.com/questions/64495891/json-to-table-formatting-got-it-from-http-json2table-com",
        "title": "JSON to table formatting (got it from - http://json2table.com)"
    },
    {
        "tags": [
            "arrays",
            "json",
            "addition",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1603533532,
                "last_edit_date": 1603533532,
                "creation_date": 1603517750,
                "answer_id": 64510337,
                "question_id": 64510180,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You need to use an [update operator](https://stedolan.github.io/jq/manual/#Arithmeticupdate-assignment:+=,-=,*=,/=,%=,//=) there to retain the original structure and contents. For example:\r\n```\r\n.[0] += { newkey: &quot;newvalue&quot; }\r\n```",
                "title": "Add field into an array element and keep the original structure"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1603565174,
        "creation_date": 1603515902,
        "last_edit_date": 1603565174,
        "question_id": 64510180,
        "body_markdown": "Hi I have an array of objects as input like\r\n```\r\n[{&quot;keyA&quot;: &quot;value&quot;}, {&quot;keyA&quot;: &quot;otherValue&quot;}...]\r\n```\r\nstored in bash environment variable. I want to keep the whole array but add/update the first element having the result like\r\n```\r\n[{&quot;keyA&quot;: &quot;value&quot;, &quot;newkey&quot;: &quot;newvalue&quot;}, {&quot;keyA&quot;: &quot;otherValue&quot;}...]\r\n```\r\n\r\nI&#39;ve tried\r\n```\r\necho $a | jq &#39;.[0]+{&quot;newkey&quot;: &quot;value&quot;}&#39;\r\n```\r\nbut the result is a single element of \r\n```\r\n{&quot;keyA&quot;: &quot;value&quot;, &quot;newkey&quot;: &quot;newvalue&quot;}\r\n```\r\n\r\n```\r\necho $a | jq &#39;.,.[0]+{&quot;newkey&quot;: &quot;newvalue&quot;}&#39;\r\n```\r\nbut the result is\r\n```\r\n[{&quot;keyA&quot;: &quot;value&quot;}, {&quot;keyA&quot;: &quot;otherValue&quot;}...] {&quot;keyA&quot;: &quot;value&quot;, &quot;newkey&quot;: &quot;newvalue&quot;}\r\n```\r\n\r\nHow do I get the full array input set and with the first element updated?",
        "link": "https://stackoverflow.com/questions/64510180/add-field-into-an-array-element-and-keep-the-original-structure",
        "title": "Add field into an array element and keep the original structure"
    },
    {
        "tags": [
            "json",
            "mongodb",
            "awk",
            "jq",
            "datetime-format"
        ],
        "comments": [
            {
                "owner": {
                    "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": 2,
                "creation_date": 1603521876,
                "post_id": 64510632,
                "comment_id": 114069295,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9716691,
                    "reputation": 4077,
                    "user_id": 7206830,
                    "user_type": "registered",
                    "accept_rate": 80,
                    "profile_image": "https://graph.facebook.com/10153894558462257/picture?type=large",
                    "display_name": "Divyang Shah",
                    "link": "https://stackoverflow.com/users/7206830/divyang-shah"
                },
                "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": 1603521914,
                "post_id": 64510632,
                "comment_id": 114069304,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "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": 2,
                "creation_date": 1603522079,
                "post_id": 64510632,
                "comment_id": 114069335,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1938048,
                    "reputation": 207858,
                    "user_id": 1745001,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/99a3ebae89496eb16afe453aae97f5be?s=256&d=identicon&r=PG",
                    "display_name": "Ed Morton",
                    "link": "https://stackoverflow.com/users/1745001/ed-morton"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1603541523,
                "post_id": 64510632,
                "comment_id": 114073379,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "reply_to_user": {
                    "account_id": 1938048,
                    "reputation": 207858,
                    "user_id": 1745001,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/99a3ebae89496eb16afe453aae97f5be?s=256&d=identicon&r=PG",
                    "display_name": "Ed Morton",
                    "link": "https://stackoverflow.com/users/1745001/ed-morton"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1603611141,
                "post_id": 64510632,
                "comment_id": 114087411,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1938048,
                    "reputation": 207858,
                    "user_id": 1745001,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/99a3ebae89496eb16afe453aae97f5be?s=256&d=identicon&r=PG",
                    "display_name": "Ed Morton",
                    "link": "https://stackoverflow.com/users/1745001/ed-morton"
                },
                "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": 1603634532,
                "post_id": 64510632,
                "comment_id": 114092668,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "reply_to_user": {
                    "account_id": 1938048,
                    "reputation": 207858,
                    "user_id": 1745001,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/99a3ebae89496eb16afe453aae97f5be?s=256&d=identicon&r=PG",
                    "display_name": "Ed Morton",
                    "link": "https://stackoverflow.com/users/1745001/ed-morton"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1603643158,
                "post_id": 64510632,
                "comment_id": 114095176,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9716691,
                    "reputation": 4077,
                    "user_id": 7206830,
                    "user_type": "registered",
                    "accept_rate": 80,
                    "profile_image": "https://graph.facebook.com/10153894558462257/picture?type=large",
                    "display_name": "Divyang Shah",
                    "link": "https://stackoverflow.com/users/7206830/divyang-shah"
                },
                "reply_to_user": {
                    "account_id": 1938048,
                    "reputation": 207858,
                    "user_id": 1745001,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/99a3ebae89496eb16afe453aae97f5be?s=256&d=identicon&r=PG",
                    "display_name": "Ed Morton",
                    "link": "https://stackoverflow.com/users/1745001/ed-morton"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1603695437,
                "post_id": 64510632,
                "comment_id": 114106723,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1603528753,
                "last_edit_date": 1603528753,
                "creation_date": 1603524584,
                "answer_id": 64511026,
                "question_id": 64510632,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Consider:\r\n\r\n    walk( if type == &quot;object&quot; and has(&quot;$date&quot;)\r\n          then .[&quot;$date&quot;] else . end )\r\n\r\nThis risks losing data, so you might want to consider similar alternatives, e.g. a stronger precondition, or a precondition using the expected key name. Or you might want to raise an error if the &quot;date&quot; object is not as expected.",
                "title": "Converting timestamp object in json to timestamp as a string"
            },
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": -2,
                "last_activity_date": 1603527574,
                "last_edit_date": 1603527574,
                "creation_date": 1603527430,
                "answer_id": 64511347,
                "question_id": 64510632,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I got it worked out . This answer is for those who are looking for a similar solution .\r\n\r\n```cat test.json | jq &#39; .location.timestamp = .location.timestamp.&quot;$date&quot;&#39; | sponge test.json ```\r\n\r\nI didn&#39;t know how to use sponge, sponge is great!\r\n\r\n\r\n",
                "title": "Converting timestamp object in json to timestamp as a string"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1603528753,
        "creation_date": 1603520960,
        "last_edit_date": 1603524803,
        "question_id": 64510632,
        "body_markdown": "I have a json exported from Mongodb . It shows timestamp in a different format\r\n `&quot;timestamp&quot;:{&quot;$date&quot;:&quot;2020-08-01T00:00:00Z&quot;}}` . I want to convert this timestamp object to a string like `&quot;timestamp&quot;:&quot;2020-08-01T00:00:00Z&quot;` .\r\n\r\nI have done this using sed like `s/\\{\\&quot;[$]date\\&quot;:\\&quot;(\\S{20})\\&quot;}/&quot;\\1&quot;/g;`. However , the length of the timestamp may vary if milliseconds are added to the time .Eg : `&quot;timestamp&quot;:{&quot;$date&quot;:&quot;2020-08-01T00:00:00.123Z&quot;}}` would be transformed with  `s/\\{\\&quot;[$]date\\&quot;:\\&quot;(\\S{23})\\&quot;}/&quot;\\1&quot;/g;` , since the length of timestamp string is 23 characters. I want to convert this into a single transformation step where any length for the string would be good.\r\n\r\nI can do this with jq too but that will need to read every line , store the value in a variable and use awk to change the value . This would be time consuming as compared to sed . So looking for a different solution.\r\n\r\nA good answer would be really appreciated. Thanks\r\n",
        "link": "https://stackoverflow.com/questions/64510632/converting-timestamp-object-in-json-to-timestamp-as-a-string",
        "title": "Converting timestamp object in json to timestamp as a string"
    },
    {
        "tags": [
            "json",
            "jq",
            "jupyter-lab",
            "csv"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1603524026,
                "creation_date": 1603524026,
                "answer_id": 64510963,
                "question_id": 64510755,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You might be able to get away with using `join(&quot;;&quot;)`, but it would almost certainly be better to use `gsub(&quot;;&quot;;&quot;\\\\;&quot;)` on strings first, but it depends on how you want to handle semicolons in JSON strings. Depending on your requirements or expectations, you might also want to consider using `@tsv` and then postprocessing the tabs, e.g. using\r\n\r\n    sed $&#39;s/\\t/;/g&#39;\r\n\r\nor \r\n\r\n    tr &#39;\\t&#39; &#39;;&#39;",
                "title": "Custom define Delimiter for -jq while exporting parsed JSON to a CSV file"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1603537149,
        "creation_date": 1603522193,
        "last_edit_date": 1603537149,
        "question_id": 64510755,
        "body_markdown": "I have a simple query for most of the times it is simple to export the parsed JSON file to various formats including the CSV format. See for reference https://stackoverflow.com/questions/47715234/convert-a-json-into-csv-using-jq\r\n\r\nI want to define `;` as a delimiter for export to `csv` file in the following command in the jupyter-lab magic cell\r\n\r\n    for file in filelist:\r\n        ! echo $file\r\n        ! jq -r &#39;[.user.screen_name, .user.followers_count, .retweeted_status.user.screen_name,\\\r\n        .full_text, .display_text_range[1], .created_at, .id, .in_reply_to_user_id, \\\r\n        .in_reply_to_status_id, .user.location, .place.name,\\\r\n        .user.verified, .retweet_count, .favorite_count, .entities.media[].type, \r\n        .entities.hashtags[].text] | @csv&#39; &lt; $file &gt;&gt; $store_file\r\n\r\ntks!",
        "link": "https://stackoverflow.com/questions/64510755/custom-define-delimiter-for-jq-while-exporting-parsed-json-to-a-csv-file",
        "title": "Custom define Delimiter for -jq while exporting parsed JSON to a CSV file"
    },
    {
        "tags": [
            "json",
            "sed",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1603754470,
                "last_edit_date": 1603754470,
                "creation_date": 1603752676,
                "answer_id": 64546066,
                "question_id": 64545318,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The pattern you observed might be spurious, but here&#39;s a jq filter that solves the problem in accordance with my understanding of the criterion you defined:\r\n```\r\n.odds.data |= map(if keys_unsorted[0:2] - [&quot;label&quot;,&quot;value&quot;] == [] \r\n                  then empty else . end)\r\n```\r\n\r\nOr, if the ordering of the keys is relevant:\r\n```\r\n.odds.data |= map(select(keys_unsorted[0:2] != [&quot;label&quot;,&quot;value&quot;]))\r\n```",
                "title": "How can i delete a section of Json when a pattern occurs"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1603754470,
        "creation_date": 1603748218,
        "question_id": 64545318,
        "body_markdown": "I am using an API to retrieve some football data, i have noticed that when a certain pattern occurs, the data is corrupt.\r\n\r\nHere is an example of the correct data format:\r\n\r\n \r\n\r\n     {\r\n        &quot;id&quot;: 150,\r\n        &quot;name&quot;: &quot;bwin&quot;,\r\n        &quot;odds&quot;: {\r\n          &quot;data&quot;: [\r\n            {\r\n              &quot;value&quot;: &quot;15.50&quot;,\r\n              &quot;handicap&quot;: null,\r\n              &quot;total&quot;: null,\r\n              &quot;label&quot;: &quot;1&quot;,\r\n              &quot;probability&quot;: &quot;6.45%&quot;,\r\n              &quot;dp3&quot;: &quot;15.500&quot;,\r\n              &quot;american&quot;: 1450,\r\n              &quot;factional&quot;: null,\r\n              &quot;winning&quot;: false,\r\n              &quot;stop&quot;: false,\r\n              &quot;bookmaker_event_id&quot;: null,\r\n              &quot;last_update&quot;: {\r\n                &quot;date&quot;: &quot;2019-11-29 16:02:57.421588&quot;,\r\n                &quot;timezone_type&quot;: 3,\r\n                &quot;timezone&quot;: &quot;UTC&quot;\r\n              }\r\n            },\r\n            {\r\n              &quot;value&quot;: &quot;7.50&quot;,\r\n              &quot;handicap&quot;: null,\r\n              &quot;total&quot;: null,\r\n              &quot;label&quot;: &quot;X&quot;,\r\n              &quot;probability&quot;: &quot;13.33%&quot;,\r\n              &quot;dp3&quot;: &quot;7.500&quot;,\r\n              &quot;american&quot;: 650,\r\n              &quot;factional&quot;: null,\r\n              &quot;winning&quot;: false,\r\n              &quot;stop&quot;: false,\r\n              &quot;bookmaker_event_id&quot;: null,\r\n              &quot;last_update&quot;: {\r\n                &quot;date&quot;: &quot;2019-11-29 16:02:57.421630&quot;,\r\n                &quot;timezone_type&quot;: 3,\r\n                &quot;timezone&quot;: &quot;UTC&quot;\r\n              }\r\n            },\r\n            {\r\n              &quot;value&quot;: &quot;1.10&quot;,\r\n              &quot;handicap&quot;: null,\r\n              &quot;total&quot;: null,\r\n              &quot;label&quot;: &quot;2&quot;,\r\n              &quot;probability&quot;: &quot;90.91%&quot;,\r\n              &quot;dp3&quot;: &quot;1.100&quot;,\r\n              &quot;american&quot;: -1000,\r\n              &quot;factional&quot;: null,\r\n              &quot;winning&quot;: true,\r\n              &quot;stop&quot;: false,\r\n              &quot;bookmaker_event_id&quot;: null,\r\n              &quot;last_update&quot;: {\r\n                &quot;date&quot;: &quot;2019-11-29 16:02:57.421656&quot;,\r\n                &quot;timezone_type&quot;: 3,\r\n                &quot;timezone&quot;: &quot;UTC&quot;\r\n              }\r\n            }\r\n          ]\r\n        }\r\n      },\r\n\r\nAs you can see each block starts with this order:\r\nvalue, handicap, total, label.\r\n\r\nHowever, sometimes the data is corrupt, i have found a pattern in the responses that i can use to know the data is corrupt, each little section always begins with label and value:\r\n\r\n     {\r\n            &quot;id&quot;: 3,\r\n            &quot;name&quot;: &quot;188Bet&quot;,\r\n            &quot;odds&quot;: {\r\n              &quot;data&quot;: [\r\n                {\r\n                  &quot;label&quot;: &quot;1&quot;,\r\n                  &quot;value&quot;: &quot;1.04&quot;,\r\n                  &quot;probability&quot;: &quot;96.15%&quot;,\r\n                  &quot;dp3&quot;: &quot;1.040&quot;,\r\n                  &quot;american&quot;: -2500,\r\n                  &quot;factional&quot;: null,\r\n                  &quot;winning&quot;: false,\r\n                  &quot;handicap&quot;: null,\r\n                  &quot;total&quot;: null,\r\n                  &quot;bookmaker_event_id&quot;: null,\r\n                  &quot;last_update&quot;: {\r\n                    &quot;date&quot;: &quot;2019-11-29 16:35:31.000000&quot;,\r\n                    &quot;timezone_type&quot;: 3,\r\n                    &quot;timezone&quot;: &quot;UTC&quot;\r\n                  }\r\n                },\r\n                {\r\n                  &quot;label&quot;: &quot;X&quot;,\r\n                  &quot;value&quot;: &quot;9.50&quot;,\r\n                  &quot;probability&quot;: &quot;10.53%&quot;,\r\n                  &quot;dp3&quot;: &quot;9.500&quot;,\r\n                  &quot;american&quot;: 850,\r\n                  &quot;factional&quot;: null,\r\n                  &quot;winning&quot;: false,\r\n                  &quot;handicap&quot;: null,\r\n                  &quot;total&quot;: null,\r\n                  &quot;bookmaker_event_id&quot;: null,\r\n                  &quot;last_update&quot;: {\r\n                    &quot;date&quot;: &quot;2019-11-29 16:35:31.000000&quot;,\r\n                    &quot;timezone_type&quot;: 3,\r\n                    &quot;timezone&quot;: &quot;UTC&quot;\r\n                  }\r\n                },\r\n                {\r\n                  &quot;label&quot;: &quot;2&quot;,\r\n                  &quot;value&quot;: &quot;18.00&quot;,\r\n                  &quot;probability&quot;: &quot;5.56%&quot;,\r\n                  &quot;dp3&quot;: &quot;18.000&quot;,\r\n                  &quot;american&quot;: 1700,\r\n                  &quot;factional&quot;: null,\r\n                  &quot;winning&quot;: true,\r\n                  &quot;handicap&quot;: null,\r\n                  &quot;total&quot;: null,\r\n                  &quot;bookmaker_event_id&quot;: null,\r\n                  &quot;last_update&quot;: {\r\n                    &quot;date&quot;: &quot;2019-11-29 16:35:31.000000&quot;,\r\n                    &quot;timezone_type&quot;: 3,\r\n                    &quot;timezone&quot;: &quot;UTC&quot;\r\n                  }\r\n                }\r\n              ]\r\n            }\r\n          },\r\n\r\nthe problem is my API response contains 100&#39;s of the above segments at once, is it possible to use JQ / sed or any other shell tool to remove the segments of json that contain the corrupt pattern? if so how can i achieve this?\r\n\r\nI have been trying to to remove the corrupt data however the only way i can achieve it is by splitting the data in to one segment per file and then deleting the files that contain the corrupt pattern, but i am wondering if there is a quicker way.\r\n\r\n\r\nThanks\r\n\r\n",
        "link": "https://stackoverflow.com/questions/64545318/how-can-i-delete-a-section-of-json-when-a-pattern-occurs",
        "title": "How can i delete a section of Json when a pattern occurs"
    },
    {
        "tags": [
            "command-line",
            "jq",
            "quoting"
        ],
        "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": 1603760949,
                "post_id": 64546963,
                "comment_id": 114132994,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 19831029,
                    "reputation": 23,
                    "user_id": 14525599,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/75a27c051251569040009ad2bb36a1ee?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Win2Nx",
                    "link": "https://stackoverflow.com/users/14525599/win2nx"
                },
                "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": 1603761177,
                "post_id": 64546963,
                "comment_id": 114133040,
                "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": 1603761249,
                "post_id": 64546963,
                "comment_id": 114133052,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 19831029,
                    "reputation": 23,
                    "user_id": 14525599,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/75a27c051251569040009ad2bb36a1ee?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Win2Nx",
                    "link": "https://stackoverflow.com/users/14525599/win2nx"
                },
                "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": 1603761623,
                "post_id": 64546963,
                "comment_id": 114133127,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1603762021,
                "creation_date": 1603762021,
                "answer_id": 64547141,
                "question_id": 64546963,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you want the filter to be read from a file, do not enclose it in the quotation marks that are needed if the filter is specified on the command line.\r\n\r\nSo the contents of your `filter.jq` file could look like this:\r\n\r\n    .security = {hideVersionStringsWhenNotLogged: true}\r\n\r\n",
                "title": "jq reading filter from a file results in Invalid Syntax Error"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1603762270,
        "creation_date": 1603760345,
        "last_edit_date": 1603762270,
        "question_id": 64546963,
        "body_markdown": "filter.jq \r\n&quot;.security = {hideVersionStringsWhenNotLogged: true}&quot;\r\n\r\n\r\n\r\nWhen trying to apply the filter, \r\njq --from-file filter.jq a.json\r\n\r\nencountering the following error\r\njq: error: syntax error, unexpected INVALID_CHARACTER, expecting $end (Unix shell quoting issues?) at &lt;top-level&gt;, line 1\r\n\r\ntried all combinations of single and double quotes to no avail.\r\nAny suggestions?\r\nThx\r\n\r\n",
        "link": "https://stackoverflow.com/questions/64546963/jq-reading-filter-from-a-file-results-in-invalid-syntax-error",
        "title": "jq reading filter from a file results in Invalid Syntax Error"
    },
    {
        "tags": [
            "json",
            "export-to-csv",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1603861105,
                "last_edit_date": 1603861105,
                "creation_date": 1603797489,
                "answer_id": 64553298,
                "question_id": 64553171,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Your path-expression is not right, you have a `hits` array inside an object named `hits` and the fields you trying to put in CSV is present under `__source` object. \r\n\r\nSo your expression should have been below. Use it along with `-r` flag to put the output in raw output format\r\n\r\n```jq\r\n.hits.hits[]._source | [ .alertID, .alertCategory, .description, .logId ] | @csv\r\n```\r\n\r\nIf your fields are `null`, the string representation of your null field value results in just `&quot;&quot;`. If you want an explicit `&quot;null&quot;` string representation, use the alternate operator along with the field you expect to be null, e.g. instead of `.logId`, you can do `(.logId // &quot;null&quot;)`\r\n\r\nTo add the column name as the header in the output CSV format, you could use the `@csv` or the `join(&quot;,&quot;)` function in raw output format `-r`\r\n\r\n\r\n```jq\r\n[ &quot;alertId&quot; , &quot;alertCategory&quot; , &quot;description&quot;, &quot;logId&quot; ], \r\n( .hits.hits[]._source |  [ .alertID, .alertCategory, .description, .logId // &quot;null&quot; ]) | @csv\r\n```\r\nor\r\n\r\n```jq\r\n[ &quot;alertId&quot; , &quot;alertCategory&quot; , &quot;description&quot;, &quot;logId&quot; ], \r\n( .hits.hits[]._source |  [ .alertID, .alertCategory, .description, .logId // &quot;null&quot; ]) | join(&quot;,&quot;)\r\n```\r\n\r\n\r\n",
                "title": "JSON file to CSV file conversion using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1603861105,
        "creation_date": 1603796998,
        "last_edit_date": 1603828519,
        "question_id": 64553171,
        "body_markdown": "I am trying to convert my json file to a csv file using jq. Below is the sample input events.json file.\r\n\r\n```\r\n{\r\n  &quot;took&quot; : 111,\r\n  &quot;timed_out&quot; : false,\r\n  &quot;_shards&quot; : {\r\n    &quot;total&quot; : 1,\r\n    &quot;successful&quot; : 1,\r\n    &quot;skipped&quot; : 0,\r\n    &quot;failed&quot; : 0\r\n  },\r\n  &quot;hits&quot; : {\r\n    &quot;total&quot; : {\r\n      &quot;value&quot; : 2,\r\n      &quot;relation&quot; : &quot;eq&quot;\r\n    },\r\n    &quot;max_score&quot; : 1.0,\r\n    &quot;hits&quot; : [\r\n      {\r\n        &quot;_index&quot; : &quot;alerts&quot;,\r\n        &quot;_type&quot; : &quot;_doc&quot;,\r\n        &quot;_id&quot; : &quot;1&quot;,\r\n        &quot;_score&quot; : 1.0,\r\n        &quot;_source&quot; : {\r\n          &quot;alertID&quot; : &quot;639387c3-0fbe-4c2b-9387-c30fbe7c2bc6&quot;,\r\n          &quot;alertCategory&quot; : &quot;Server Alert&quot;,\r\n          &quot;description&quot; : &quot;Successfully started.&quot;,\r\n          &quot;logId&quot; : null\r\n          }\r\n       },\r\n       {\r\n        &quot;_index&quot; : &quot;alerts&quot;,\r\n        &quot;_type&quot; : &quot;_doc&quot;,\r\n        &quot;_id&quot; : &quot;2&quot;,\r\n        &quot;_score&quot; : 1.0,\r\n        &quot;_source&quot; : {\r\n          &quot;alertID&quot; : &quot;2&quot;,\r\n          &quot;alertCategory&quot; : &quot;Server Alert&quot;,\r\n          &quot;description&quot; : &quot;Successfully stoped.&quot;,\r\n          &quot;logId&quot; : null\r\n          }\r\n       }\r\n   ]\r\n  }\r\n}\r\n```\r\n\r\nMy rows in csv should have the data inside each ```_source``` tag. So my columns would be ```alertId``` , ```alertCategory``` , ```description``` and ```logId``` with its respective data.\r\n\r\nI tried the below command :\r\n ```jq --raw-output &#39;.hits[] | [.&quot;alertId&quot;,.&quot;alertCategory&quot;,.&quot;description&quot;,.&quot;logId&quot;] | @csv&#39; &lt; /root/events.json```\r\nand its not working.\r\n\r\nCan anyone help me with this?",
        "link": "https://stackoverflow.com/questions/64553171/json-file-to-csv-file-conversion-using-jq",
        "title": "JSON file to CSV file conversion using jq"
    },
    {
        "tags": [
            "shell",
            "gitlab",
            "devops",
            "gitlab-ci",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 10156110,
                    "reputation": 466,
                    "user_id": 7501158,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/0724d53f92cb4268c034c1ac863b865b?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "kalou.net",
                    "link": "https://stackoverflow.com/users/7501158/kalou-net"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1603830706,
                "post_id": 64561584,
                "comment_id": 114160267,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 11090186,
                    "reputation": 87,
                    "user_id": 8142371,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f6e2f320f9fbc039e0031b988bd522cb?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "SaurabhVS",
                    "link": "https://stackoverflow.com/users/8142371/saurabhvs"
                },
                "reply_to_user": {
                    "account_id": 10156110,
                    "reputation": 466,
                    "user_id": 7501158,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/0724d53f92cb4268c034c1ac863b865b?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "kalou.net",
                    "link": "https://stackoverflow.com/users/7501158/kalou-net"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1603833318,
                "post_id": 64561584,
                "comment_id": 114161297,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1603834714,
                "last_edit_date": 1603834714,
                "creation_date": 1603831785,
                "answer_id": 64562705,
                "question_id": 64561584,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "### If $add_on_modules is `[&quot;a&quot;,&quot;b&quot;]`\r\nIf you can set add_on_modules to the textual representation of a JSON array, then you would use `--argjson`, like so:\r\n\r\n    add_on_modules=&#39;[&quot;a&quot;,&quot;b&quot;]&#39;\r\n    jq -r --argjson add_on_modules &quot;$add_on_modules&quot; &#39;\r\n     .AddOnModules.value  += $add_on_modules\r\n    &#39; sample.json\r\n\r\n\r\n### If $add_on_modules is the string `&quot;a&quot;,&quot;b&quot;`\r\n```\r\nadd_on_modules=&#39;&quot;a&quot;,&quot;b&quot;&#39;\r\njq -r --arg add_on_modules &quot;$add_on_modules&quot; &#39;\r\n  .AddOnModules.value  += ($add_on_modules|split(&quot;,&quot;)|map(fromjson)) \r\n  &#39; sample.json\r\n```",
                "title": "Using jq in Gitlab CI yaml"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1603834714,
        "creation_date": 1603826836,
        "last_edit_date": 1603833179,
        "question_id": 64561584,
        "body_markdown": "I&#39;m having a json file sample.json. Below is the snippet from the sample.json - \r\n\r\n    {\r\n    &quot;AddOnModules&quot;: {\r\n            &quot;Description&quot;: &quot;add on modules&quot;,\r\n            &quot;Type&quot;: &quot;Array&quot;,\r\n            &quot;AllowedValues&quot;: [\r\n                &quot;a&quot;,\r\n                &quot;b&quot;,\r\n                &quot;c&quot;\r\n            ],\r\n            &quot;value&quot;: []\r\n        }\r\n    }\r\n\r\nI&#39;m trying to provide value to AddOnModules through git ci variable (parameter-value) at runtime while running the pipeline. The following is the snippet of the pipeline - \r\n\r\n    stages: \r\n      - deploy\r\n      \r\n    # Job to deploy for development  \r\n    dev-deploy:\r\n    \r\n      variables:\r\n    \r\n      before_script:\r\n        - apk add jq\r\n        \r\n      image: python:3.7.4-alpine3.9\r\n      script:\r\n        - tmp=$(mktemp)\r\n        - jq -r --arg add_on_modules &quot;$add_on_modules&quot; &#39;.AddOnModules.value  |= .+ [$add_on_modules] &#39; sample.json &gt; &quot;$tmp&quot; &amp;&amp; mv &quot;$tmp&quot; sample.json\r\n        - cat sample.json\r\n      stage: deploy\r\n      tags: \r\n        - docker\r\n        - linux\r\n      only:\r\n        variables:\r\n            - $stage =~ /^deploy$/ &amp;&amp; $deployment_mode =~ /^dev$/\r\n\r\nI&#39;m giving the value of variable add_on_modules as &quot;a&quot;,&quot;b&quot; through git ci while running the pipeline. On performing cat sample.json, it&#39;s observed to be -\r\n\r\n    {\r\n        &quot;AddOnModules&quot;: {\r\n                &quot;Description&quot;: &quot;add on modules&quot;,\r\n                &quot;Type&quot;: &quot;Array&quot;,\r\n                &quot;AllowedValues&quot;: [\r\n                    &quot;a&quot;,\r\n                    &quot;b&quot;,\r\n                    &quot;c&quot;\r\n                ],\r\n                &quot;value&quot;: [ &quot;\\&quot;a\\&quot;,\\&quot;b\\&quot;&quot;]\r\n            }\r\n     }\r\n\r\nThe extra double quotes are getting the prepended and appended while the existing ones are escaped.\r\nI want output something like -\r\n\r\n\r\n    {\r\n            &quot;AddOnModules&quot;: {\r\n                    &quot;Description&quot;: &quot;add on modules&quot;,\r\n                    &quot;Type&quot;: &quot;Array&quot;,\r\n                    &quot;AllowedValues&quot;: [\r\n                        &quot;a&quot;,\r\n                        &quot;b&quot;,\r\n                        &quot;c&quot;\r\n                    ],\r\n                    &quot;value&quot;: [&quot;a&quot;,&quot;b&quot;]\r\n                }\r\n    }\r\n\r\nLooks like I&#39;m missing something with jq - \r\n\r\n    - jq -r --arg add_on_modules &quot;$add_on_modules&quot; &#39;.AddOnModules.value  |= .+ [$add_on_modules] &#39; sample.json &gt; &quot;$tmp&quot; &amp;&amp; mv &quot;$tmp&quot; sample.json\r\n\r\nTried with -r/--raw-output flag with jq but no success. Any suggestions on how to solve this?\r\n\r\nThis is how I&#39;m running the pipeline - \r\n\r\n[Pipeline run][1]\r\n\r\n\r\n  [1]: https://i.sstatic.net/EGL6d.png",
        "link": "https://stackoverflow.com/questions/64561584/using-jq-in-gitlab-ci-yaml",
        "title": "Using jq in Gitlab CI yaml"
    },
    {
        "tags": [
            "bash",
            "curl",
            "jq",
            "watch"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1326012,
                    "reputation": 15108,
                    "user_id": 1270789,
                    "user_type": "registered",
                    "accept_rate": 81,
                    "profile_image": "https://i.sstatic.net/FXwoB.png?s=256",
                    "display_name": "Ken Y-N",
                    "link": "https://stackoverflow.com/users/1270789/ken-y-n"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1603848075,
                "post_id": 64565122,
                "comment_id": 114165029,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 67187,
                    "reputation": 7129,
                    "user_id": 196732,
                    "user_type": "registered",
                    "accept_rate": 67,
                    "profile_image": "https://www.gravatar.com/avatar/c58f46d4ddf8d480ac42718db0c2bb12?s=256&d=identicon&r=PG",
                    "display_name": "CpILL",
                    "link": "https://stackoverflow.com/users/196732/cpill"
                },
                "reply_to_user": {
                    "account_id": 1326012,
                    "reputation": 15108,
                    "user_id": 1270789,
                    "user_type": "registered",
                    "accept_rate": 81,
                    "profile_image": "https://i.sstatic.net/FXwoB.png?s=256",
                    "display_name": "Ken Y-N",
                    "link": "https://stackoverflow.com/users/1270789/ken-y-n"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1603850030,
                "post_id": 64565122,
                "comment_id": 114165384,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1603850963,
                "post_id": 64565122,
                "comment_id": 114165572,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1603851879,
                "post_id": 64565122,
                "comment_id": 114165750,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 67187,
                    "reputation": 7129,
                    "user_id": 196732,
                    "user_type": "registered",
                    "accept_rate": 67,
                    "profile_image": "https://www.gravatar.com/avatar/c58f46d4ddf8d480ac42718db0c2bb12?s=256&d=identicon&r=PG",
                    "display_name": "CpILL",
                    "link": "https://stackoverflow.com/users/196732/cpill"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1603852943,
                "post_id": 64565122,
                "comment_id": 114165952,
                "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": 1603853058,
                "post_id": 64565122,
                "comment_id": 114165976,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 6,
                "is_accepted": true,
                "score": 6,
                "last_activity_date": 1603853090,
                "creation_date": 1603853090,
                "answer_id": 64565787,
                "question_id": 64565122,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This did it:\r\n\r\n    watch &#39;curl localhost:8000/something | jq .&#39; ",
                "title": "Problem getting `jq` and `watch` to play together nicely?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1603853090,
        "creation_date": 1603847769,
        "question_id": 64565122,
        "body_markdown": "I&#39;m hitting an endpoint for status info which returns JSON \r\n\r\n    watch &#39;curl localhost:8000/something | jq&#39; \r\n\r\nwhich just returns &quot;(23) Failed writing body&quot; which is from `jq`. What does `jq` want here?\r\n\r\nNote this works without the `watch` part?",
        "link": "https://stackoverflow.com/questions/64565122/problem-getting-jq-and-watch-to-play-together-nicely",
        "title": "Problem getting `jq` and `watch` to play together nicely?"
    },
    {
        "tags": [
            "bash",
            "shell",
            "jq",
            "command-substitution"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 8148221,
                    "reputation": 8514,
                    "user_id": 6136214,
                    "user_type": "registered",
                    "accept_rate": 75,
                    "profile_image": "https://www.gravatar.com/avatar/f12e30845d0c23b2e12991ccf0e9e9bc?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "agc",
                    "link": "https://stackoverflow.com/users/6136214/agc"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1603875545,
                "post_id": 64565972,
                "comment_id": 114171724,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 7,
                "is_accepted": false,
                "score": 6,
                "last_activity_date": 1603856544,
                "creation_date": 1603856544,
                "answer_id": 64566154,
                "question_id": 64565972,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can certainly use `\\` to escape end-of-lines inside a `$(...)` expression. Also note that you **don&#39;t** need those `\\`&#39;s in the `jq` expression inside the single quotes.\r\n\r\nI would probably write it something like this:\r\n\r\n```\r\nAllCardsInDTL=$(\r\ncurl -s &quot;https://api.trello.com/1/lists/$DailyTasksListID/cards\\\r\n?$WhoMe\\\r\n&amp;fields=name,id,pos&quot; |\r\njq  &#39;.[] |\r\n    if .name | test (&quot;Tasks here are copied.*&quot;)\r\n    then empty\r\n    else .id, .name\r\n    end\r\n    &#39;\r\n)\r\n```\r\n\r\nI can&#39;t test this, since I don&#39;t have a useful value for `$DailyTasksListID` nor am I equipped to authenticate to trello at the moment.",
                "title": "Can I use the $( ... ) syntax with multiline commands?"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1603875163,
                "creation_date": 1603875163,
                "answer_id": 64569374,
                "question_id": 64565972,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Yes.  Demo:\r\n\r\n    echo $(echo foo\r\n    echo bar\r\n    echo baz\r\n    )\r\n\r\nOutput:\r\n\r\n    foo bar baz\r\n\r\n",
                "title": "Can I use the $( ... ) syntax with multiline commands?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 7,
        "last_activity_date": 1603875163,
        "creation_date": 1603854885,
        "last_edit_date": 1603855304,
        "question_id": 64565972,
        "body_markdown": "I often use backticks in with long commands that I break up with backslash-newlines for readability. When I replace the backticks with the `$( ... )` syntax, I get errors.\r\n\r\nFor instance, I set a variable using `curl` and `jq` inside backquotes (reading from my Trello daily to-do list and returning card.id and card.name for everything but a specific card):\r\n```\r\nAllCardsInDTL=\\\r\n`\\\r\ncurl -s &quot;https://api.trello.com/1/lists/$DailyTasksListID/cards\\\r\n?$WhoMe\\\r\n&amp;fields=name,id,pos\\\r\n&quot;\\\r\n| jq  &#39;\\\r\n    .[] | \\\r\n    if .name | test (&quot;Tasks here are copied.*&quot;) \\\r\n    then empty \\\r\n    else .id, .name \\\r\n    end \\\r\n    &#39;\\\r\n`  # End of AllCardsInDTL=\r\n```\r\n\r\nThat has no problems and the shell variable consists of alternating lines of ID and Name values.\r\n\r\nBut if I replace the backquoteswith `$( ... )`, I get an error from `jq`:\r\n```\r\njq: error: syntax error, unexpected INVALID_CHARACTER, expecting $end (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n\\\r\njq: 1 compile error\r\n(23) Failed writing body\r\n```\r\nIt&#39;s not clear to me from the error, whether the `)` is not actually terminating the command started by `$(` or whether inside the `$( ... )` the backslash is not being interpreted as I expect.\r\n\r\nI would like to be able to use the `$( ... )` syntax because there are times when I want to nest one subshell inside another and that&#39;s very difficult to do with backquotes.",
        "link": "https://stackoverflow.com/questions/64565972/can-i-use-the-syntax-with-multiline-commands",
        "title": "Can I use the $( ... ) syntax with multiline commands?"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq",
            "positional-parameter"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 4663062,
                    "reputation": 89888,
                    "user_id": 3776858,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Cagbk.jpg?s=256",
                    "display_name": "Cyrus",
                    "link": "https://stackoverflow.com/users/3776858/cyrus"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1603870809,
                "post_id": 64568269,
                "comment_id": 114169759,
                "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": 1603870887,
                "post_id": 64568269,
                "comment_id": 114169781,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1603875818,
                "last_edit_date": 1603875818,
                "creation_date": 1603871220,
                "answer_id": 64568456,
                "question_id": 64568269,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "## 1. String construction under [tag:bash]\r\n\r\nI use `printf` and *octal* representation for nesting quotes and double quotes:\r\n\r\n    printf -v JSON &#39;Some &quot;double quoted: \\047%s\\047&quot;&#39; &quot;Any string&quot;\r\n    echo &quot;$JSON&quot;\r\n    Some &quot;double quoted: &#39;Any string&#39;&quot;\r\n\r\n## 2. Using `jq`, strictly answer to edited question:\r\n\r\n    myFunc() {\r\n        local file=&quot;$1&quot; site=&quot;$2&quot; JSON\r\n        printf -v JSON &#39;. + {\r\n            &quot;ssl_certificate&quot;: &quot;/etc/letsencrypt/live/%s/fullchain.pem&quot;,\r\n            &quot;ssl_certificate_key&quot;: &quot;/etc/letsencrypt/live/%s/fullchain.pem&quot;\r\n        }&#39; &quot;$site&quot; &quot;$site&quot;\r\n        jq &quot;$JSON&quot; &lt;&quot;$file&quot;\r\n    }\r\n\r\nThen run:\r\n\r\n    myFunc site_config.json test.com\r\n    {\r\n      &quot;key1&quot;: &quot;value1&quot;,\r\n      &quot;key2&quot;: &quot;value2&quot;,\r\n      &quot;ssl_certificate&quot;: &quot;/etc/letsencrypt/live/test.com/fullchain.pem&quot;,\r\n      &quot;ssl_certificate_key&quot;: &quot;/etc/letsencrypt/live/test.com/fullchain.pem&quot;\r\n    }\r\n\r\n    myFunc site_config.json test.com &gt;site_config.temp &amp;&amp; mv site_config.{temp,conf}\r\n\r\n\r\nOr even:\r\n\r\n    myFunc &lt;(\r\n        printf &#39;{ &quot;key1&quot;:&quot;value1&quot;,&quot;key2&quot;:&quot;value2&quot;,&quot;comment&quot;:&quot;Let\\047s doit\\041&quot;  }&#39;\r\n        ) test.com\r\n\r\nWill render:\r\n\r\n    {\r\n      &quot;key1&quot;: &quot;value1&quot;,\r\n      &quot;key2&quot;: &quot;value2&quot;,\r\n      &quot;comment&quot;: &quot;Let&#39;s doit!&quot;,\r\n      &quot;ssl_certificate&quot;: &quot;/etc/letsencrypt/live/test.com/fullchain.pem&quot;,\r\n      &quot;ssl_certificate_key&quot;: &quot;/etc/letsencrypt/live/test.com/fullchain.pem&quot;\r\n    }\r\n\r\n### 2b. Better written with `jq`&#39;s `--arg` option:\r\n\r\nThanks to [peak&#39;s detailed answer][1]!\r\n\r\nI use [tag:bash] arrays to store strings with quotes, spaces and other special characters. This is more readable as there is no need to escape end-of-line (backslashes) and permit comments:\r\n\r\n    myFunc() {\r\n        local file=&quot;$1&quot; site=&quot;$2&quot;\r\n        local JSON=(\r\n            --arg ssl_certificate &quot;/etc/letsencrypt/live/$site/fullchain.pem&quot;\r\n            --arg ssl_certificate_key &quot;/etc/letsencrypt/live/$site/fullchain.pem&quot;\r\n            &#39;. + {$ssl_certificate, $ssl_certificate_key}&#39; # this syntax\r\n            # do offer two advantages: 1: no backslashes and 2: permit comments.\r\n        )\r\n        jq &quot;${JSON[@]}&quot; &lt;&quot;$file&quot;\r\n    }\r\n\r\n## 3. Inline edit function\r\n\r\nFor editing a small script. I prefer to use `cp -a` in order to preserve\r\nattributes and ensure a valid operation before replacement.\r\n\r\nIf you plan to use this, mostly for replacing, you could add replacement in your function:\r\n\r\n    myFunc() {\r\n        local REPLACE=false\r\n        [ &quot;$1&quot; = &quot;-r&quot; ] &amp;&amp; REPLACE=true &amp;&amp; shift\r\n        local file=&quot;$1&quot; site=&quot;$2&quot;\r\n        local JSON=( --arg ssl_certificate &quot;/etc/letsencrypt/live/$site/fullchain.pem&quot;\r\n            --arg ssl_certificate_key &quot;/etc/letsencrypt/live/$site/fullchain.pem&quot;\r\n            &#39;. + {$ssl_certificate, $ssl_certificate_key}&#39; )\r\n        if $REPLACE;then\r\n            cp -a &quot;$file&quot; &quot;${file}.temp&quot;\r\n            exec {out}&gt;&quot;${file}.temp&quot;\r\n        else\r\n            exec {out}&gt;&amp;1\r\n        fi\r\n        jq &quot;${JSON[@]}&quot; &lt;&quot;$file&quot; &gt;&amp;$out &amp;&amp;\r\n            $REPLACE &amp;&amp; mv &quot;${file}.temp&quot; &quot;$file&quot;\r\n        exec {out}&gt;&amp;-\r\n    }\r\n\r\nThen to modify file instead of dumping result to terminal, you have to add `-r` option:\r\n\r\n    myFunc -r site_config.json test.org\r\n\r\n\r\n  [1]: https://stackoverflow.com/a/64569181/1765658",
                "title": "How to use positional argument with embed quotes in bash?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1603875981,
                "last_edit_date": 1603875981,
                "creation_date": 1603874416,
                "answer_id": 64569181,
                "question_id": 64568269,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; I cannot get the positional argument passed into the json text. \r\n\r\nIn general, by far the best way to do that is to use jq&#39;s --arg and/or --argjson command-line options.  This is safe, and in the present case means that you would only have to call jq once.  E.g.:\r\n```\r\n&lt; site_config.json \\\r\njq --arg sslc &quot;/etc/letsencrypt/live/$2/fullchain.pem&quot; \\\r\n   --arg sslck &quot;/etc/letsencrypt/live/$2/fullchain.pem&quot; &#39;\r\n   . + {ssl_certificate: $sslc, ssl_certificate_key: $sslck }&#39;\r\n```\r\n\r\nOnce you&#39;re sure things are working properly, feel free to use moreutils&#39;s `sponge` :-)\r\n\r\n\r\n## A DRY-er solution\r\nThanks to a neat convenience feature of jq, one can write more DRY-ly:\r\n\r\n```\r\n&lt; site_config.json \\\r\njq --arg ssl_certificate &quot;/etc/letsencrypt/live/$2/fullchain.pem&quot; \\\r\n   --arg ssl_certificate_key &quot;/etc/letsencrypt/live/$2/fullchain.pem&quot; &#39;\r\n   . + {$ssl_certificate, $ssl_certificate_key }&#39;\r\n``\r\n\r\n\r\n",
                "title": "How to use positional argument with embed quotes in bash?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1603877788,
        "creation_date": 1603870347,
        "last_edit_date": 1603877788,
        "question_id": 64568269,
        "body_markdown": "I&#39;m trying to create a bash script that automates configuration of some letsencrypt related stuff.\r\n\r\nThe file that I have to edit is json so I would just use `jq` to edit it and pass the site name to it from the positional arguments of the script, but I can&#39;t get the positional argument passed into the json text.\r\n\r\nI&#39;m trying to do domething like the following:\r\n\r\n    JSON=`jq &#39;. + { &quot;ssl_certificate&quot;: &quot;/etc/letsencrypt/live/$2/fullchain.pem&quot; }&#39; &lt;&lt;&lt; echo site_config.json`\r\n    JSON=`jq &#39;. + { &quot;ssl_certificate_key&quot;: &quot;/etc/letsencrypt/live/$2/fullchain.pem&quot; }&#39; &lt;&lt;&lt; ${JSON}`\r\n    echo -e &quot;$JSON&quot; &gt; site_config.json\r\n\r\nWhere the second positional argument (`$2`) contain the domain name required to be set in the json file.\r\n\r\nHow this can be done?\r\n\r\nOriginal json:\r\n\r\n    {\r\n      &quot;key1&quot;:&quot;value1&quot;,\r\n      &quot;key2&quot;:&quot;value2&quot;\r\n    }\r\n\r\nWanted json:\r\n\r\n    {\r\n      &quot;key1&quot;:&quot;value1&quot;,\r\n      &quot;key2&quot;:&quot;value2&quot;,\r\n      &quot;ssl_certificate&quot;: &quot;/etc/letsencrypt/live/somesite.com/fullchain.pem&quot;,\r\n      &quot;ssl_certificate_key&quot;: &quot;/etc/letsencrypt/live/somesite.com/fullchain.pem&quot;\r\n    }",
        "link": "https://stackoverflow.com/questions/64568269/how-to-use-positional-argument-with-embed-quotes-in-bash",
        "title": "How to use positional argument with embed quotes in bash?"
    },
    {
        "tags": [
            "json",
            "shell",
            "csv",
            "export-to-csv",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1603904381,
                "creation_date": 1603904381,
                "answer_id": 64577760,
                "question_id": 64576887,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Simply use `keys_unsorted` (or `keys` if you want them sorted). See e.g. https://stackoverflow.com/questions/47730946/convert-json-array-into-csv-using-jq or https://stackoverflow.com/questions/32960857/how-to-convert-arbitrary-simple-json-to-csv-using-jq for two SO examples. There are many others too.",
                "title": "JSON file to CSV file conversion when my JSON columns are dynamic"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1603904381,
        "creation_date": 1603901554,
        "question_id": 64576887,
        "body_markdown": "I found the solution for json to csv conversion. Below is the sample json and solution.\r\n```\r\n{\r\n  &quot;took&quot; : 111,\r\n  &quot;timed_out&quot; : false,\r\n  &quot;_shards&quot; : {\r\n    &quot;total&quot; : 1,\r\n    &quot;successful&quot; : 1,\r\n    &quot;skipped&quot; : 0,\r\n    &quot;failed&quot; : 0\r\n  },\r\n  &quot;hits&quot; : {\r\n    &quot;total&quot; : {\r\n      &quot;value&quot; : 2,\r\n      &quot;relation&quot; : &quot;eq&quot;\r\n    },\r\n    &quot;max_score&quot; : 1.0,\r\n    &quot;hits&quot; : [\r\n      {\r\n        &quot;_index&quot; : &quot;alerts&quot;,\r\n        &quot;_type&quot; : &quot;_doc&quot;,\r\n        &quot;_id&quot; : &quot;1&quot;,\r\n        &quot;_score&quot; : 1.0,\r\n        &quot;_source&quot; : {\r\n          &quot;alertID&quot; : &quot;639387c3-0fbe-4c2b-9387-c30fbe7c2bc6&quot;,\r\n          &quot;alertCategory&quot; : &quot;Server Alert&quot;,\r\n          &quot;description&quot; : &quot;Successfully started.&quot;,\r\n          &quot;logId&quot; : null\r\n          }\r\n       },\r\n       {\r\n        &quot;_index&quot; : &quot;alerts&quot;,\r\n        &quot;_type&quot; : &quot;_doc&quot;,\r\n        &quot;_id&quot; : &quot;2&quot;,\r\n        &quot;_score&quot; : 1.0,\r\n        &quot;_source&quot; : {\r\n          &quot;alertID&quot; : &quot;2&quot;,\r\n          &quot;alertCategory&quot; : &quot;Server Alert&quot;,\r\n          &quot;description&quot; : &quot;Successfully stoped.&quot;,\r\n          &quot;logId&quot; : null\r\n          }\r\n       }\r\n   ]\r\n  }\r\n}\r\n```\r\nThe solution : \r\n```\r\njq -r &#39;.hits.hits[]._source | [ &quot;alertID&quot; , &quot;alertCategory&quot; , &quot;description&quot;, &quot;logId&quot; ], ([.&quot;alertID&quot;,.&quot;alertCategory&quot;,.&quot;description&quot;,.&quot;logId&quot; // &quot;null&quot;]) | @csv&#39; &lt; /root/events.json\r\n```\r\n\r\nThe problem with this solution is that I have to hard code the column names. What If my json gets a few additions under ```_source``` tag later? I need a solution which can handle the dynamic data under ```_source```. I am open to any other tool or command in shell.\r\n",
        "link": "https://stackoverflow.com/questions/64576887/json-file-to-csv-file-conversion-when-my-json-columns-are-dynamic",
        "title": "JSON file to CSV file conversion when my JSON columns are dynamic"
    },
    {
        "tags": [
            "json",
            "shell",
            "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": 1,
                "creation_date": 1603905033,
                "post_id": 64577842,
                "comment_id": 114186218,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1603974015,
                "last_edit_date": 1603974015,
                "creation_date": 1603905078,
                "answer_id": 64577958,
                "question_id": 64577842,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use the `all` function to reduce an array of Booleans* to `true` if all the Booleans are true. `jq` will output that value, which you can capture using command substitution.\r\n\r\n    result=$(jq &#39;map(.value) | all&#39; tmp.json)\r\n\r\nYou may not need the actual output, though. It may be sufficient to use the `--exit-status` option (short form `-e`) to test if `jq` *would* return `true` or not.\r\n\r\n\r\n    if jq -e &#39;map(.value) | all&#39; tmp.json &gt; /dev/null; then\r\n       echo &quot;All were true&quot;\r\n    else\r\n       echo &quot;At least one was false&quot;\r\n    fi\r\n\r\n---\r\n\r\n\\* Among other things; see @peak&#39;s comment below&lt;/small&gt;",
                "title": "Bash JSON processing - How to test if all objects in array have satisfied condition"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1603974015,
        "creation_date": 1603904667,
        "last_edit_date": 1603964927,
        "question_id": 64577842,
        "body_markdown": "I&#39;m trying to write a bash function that would parse a json response and assert if an array of objects all satisfy some condition, but I&#39;m getting nowhere with testing that state. \r\n\r\nExemplary JSON after initial transformations: \r\n\r\n```\r\n[\r\n  {\r\n    &quot;key&quot;: &quot;Org1&quot;,\r\n    &quot;value&quot;: true\r\n  },\r\n  {\r\n    &quot;key&quot;: &quot;Org2&quot;,\r\n    &quot;value&quot;: false\r\n  }\r\n]\r\n\r\n```\r\n\r\nThe condition is to have all elements (no matter the length of the array) to have value == true. \r\n\r\nI&#39;m doing the JSON transformations using jq, but I have no idea how to either store the result in a bash var so I could loop throw the elements or reduce the array to a single value that I could parse directly in an if statement. \r\n\r\n\r\nCould anyone help?",
        "link": "https://stackoverflow.com/questions/64577842/bash-json-processing-how-to-test-if-all-objects-in-array-have-satisfied-condit",
        "title": "Bash JSON processing - How to test if all objects in array have satisfied condition"
    },
    {
        "tags": [
            "json",
            "substring",
            "jq",
            "export-to-pdf",
            "pubmed"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1526413,
                    "reputation": 13993,
                    "user_id": 1424739,
                    "user_type": "registered",
                    "accept_rate": 17,
                    "profile_image": "https://www.gravatar.com/avatar/19d3c927744b5ad3b94afbf88e1c3844?s=256&d=identicon&r=PG",
                    "display_name": "user1424739",
                    "link": "https://stackoverflow.com/users/1424739/user1424739"
                },
                "reply_to_user": {
                    "account_id": 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": 1603927547,
                "post_id": 64582030,
                "comment_id": 114194636,
                "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": 1603927977,
                "post_id": 64582030,
                "comment_id": 114194739,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1603927790,
                "last_edit_date": 1603927790,
                "creation_date": 1603927107,
                "answer_id": 64582723,
                "question_id": 64582030,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Assuming the first column of the desired output is the &quot;sourceid&quot;, we can adapt your solution as follows:\r\n```\r\n.[]\r\n| .sourceid as $id\r\n| .text as $text\r\n| .denotations[]\r\n| select(.obj==&quot;drug&quot;)\r\n| .span\r\n| [$id, .begin, .end, $text[.begin : .end] ]\r\n| @tsv\r\n```\r\n",
                "title": "How to extract text from json with parent siblings and substrings?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1603936749,
        "creation_date": 1603923044,
        "last_edit_date": 1603936749,
        "question_id": 64582030,
        "body_markdown": "https://bern.korea.ac.kr/pubmed/32818866\r\n\r\n```\r\n$ jq -r &#39;.[] | .denotations | .[] | select(.obj==&quot;drug&quot;) | .span | [.begin, .end] | @tsv&#39;\r\n```\r\n\r\nI am able to extract the following info from the above URL using the above jq command.\r\n\r\n```\r\n377\t387\r\n562\t579\r\n584\t602\r\n659\t676\r\n681\t699\r\n919\t936\r\n941\t959\r\n1032\t1049\r\n1054\t1072\r\n```\r\n\r\nBut the output that I really need is the following.\r\n\r\nThe last column is just the substring of `text` starting from `begin+1` to `end` (suppose the string in `text` is indexed starting from 1.\r\n\r\nI don&#39;t know how to extract this info using just `jq` as it involves taking a parent sibling element and the substring of another parent sibling element. Could anybody show me how to extract the output in this format? Thanks.\r\n\r\n```\r\n32818866\t377\t387\tsilica gel\r\n32818866\t562\t579\t7-methoxycoumarin\r\n32818866\t584\t602\t8-prenylkaempferol\r\n32818866\t659\t676\t7-methoxycoumarin\r\n32818866\t681\t699\t8-prenylkaempferol\r\n32818866\t919\t936\t7-methoxycoumarin\r\n32818866\t941\t959\t8-prenylkaempferol\r\n32818866\t1032\t1049\t7-methoxycoumarin\r\n32818866\t1054\t1072\t8-prenylkaempferol\r\n```\r\n\r\nThe json txt is here for the completeness of this message.\r\n\r\n```\r\n[\r\n  {\r\n    &quot;project&quot;: &quot;BERN&quot;,\r\n    &quot;sourcedb&quot;: &quot;PubMed&quot;,\r\n    &quot;sourceid&quot;: &quot;32818866&quot;,\r\n    &quot;text&quot;: &quot;Identification of two bitter components in Zanthoxylum bungeanum Maxim. and exploration of their bitter taste mechanism through receptor hTAS2R14. Bitterness is an inherent organoleptic characteristic affecting the flavor of Zanthoxylum bungeanum Maxim. In this study, the vital bitter components of Z. bungeanum were concentrated through solvent extraction, sensory analysis, silica gel chromatography, and thin-layer chromatographic techniques and subsequently identified by UPLC-Q-TOF-MS. Two components with the highest bitterness intensities (BIs), such as 7-methoxycoumarin and 8-prenylkaempferol were selected. The bitter taste perceived thresholds of 7-methoxycoumarin and 8-prenylkaempferol were 0.062 mmol/L and 0.022 mmol/L, respectively. Moreover, the correlation between the contents of the two bitter components and the BIs of Z. bungeanum were proved. The results of siRNA and flow cytometry showed that 7-methoxycoumarin and 8-prenylkaempferol could activate the bitter receptor hTAS2R14. The results concluded that 7-methoxycoumarin and 8-prenylkaempferol contribute to the bitter taste of Z. bungeanum.&quot;,\r\n    &quot;denotations&quot;: [\r\n      {\r\n        &quot;id&quot;: [\r\n          &quot;NCBI:txid328401&quot;\r\n        ],\r\n        &quot;span&quot;: {\r\n          &quot;begin&quot;: 43,\r\n          &quot;end&quot;: 64\r\n        },\r\n        &quot;obj&quot;: &quot;species&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: [\r\n          &quot;CUI-less&quot;\r\n        ],\r\n        &quot;span&quot;: {\r\n          &quot;begin&quot;: 128,\r\n          &quot;end&quot;: 145\r\n        },\r\n        &quot;obj&quot;: &quot;gene&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: [\r\n          &quot;NCBI:txid328401&quot;\r\n        ],\r\n        &quot;span&quot;: {\r\n          &quot;begin&quot;: 225,\r\n          &quot;end&quot;: 246\r\n        },\r\n        &quot;obj&quot;: &quot;species&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: [\r\n          &quot;NCBI:txid328401&quot;\r\n        ],\r\n        &quot;span&quot;: {\r\n          &quot;begin&quot;: 300,\r\n          &quot;end&quot;: 312\r\n        },\r\n        &quot;obj&quot;: &quot;species&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: [\r\n          &quot;MESH:D058428&quot;,\r\n          &quot;BERN:315272203&quot;\r\n        ],\r\n        &quot;span&quot;: {\r\n          &quot;begin&quot;: 377,\r\n          &quot;end&quot;: 387\r\n        },\r\n        &quot;obj&quot;: &quot;drug&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: [\r\n          &quot;CHEBI:5679&quot;,\r\n          &quot;BERN:4597103&quot;\r\n        ],\r\n        &quot;span&quot;: {\r\n          &quot;begin&quot;: 562,\r\n          &quot;end&quot;: 579\r\n        },\r\n        &quot;obj&quot;: &quot;drug&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: [\r\n          &quot;MESH:C532177&quot;,\r\n          &quot;BERN:280529003&quot;\r\n        ],\r\n        &quot;span&quot;: {\r\n          &quot;begin&quot;: 584,\r\n          &quot;end&quot;: 602\r\n        },\r\n        &quot;obj&quot;: &quot;drug&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: [\r\n          &quot;CHEBI:5679&quot;,\r\n          &quot;BERN:4597103&quot;\r\n        ],\r\n        &quot;span&quot;: {\r\n          &quot;begin&quot;: 659,\r\n          &quot;end&quot;: 676\r\n        },\r\n        &quot;obj&quot;: &quot;drug&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: [\r\n          &quot;MESH:C532177&quot;,\r\n          &quot;BERN:280529003&quot;\r\n        ],\r\n        &quot;span&quot;: {\r\n          &quot;begin&quot;: 681,\r\n          &quot;end&quot;: 699\r\n        },\r\n        &quot;obj&quot;: &quot;drug&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: [\r\n          &quot;NCBI:txid328401&quot;\r\n        ],\r\n        &quot;span&quot;: {\r\n          &quot;begin&quot;: 841,\r\n          &quot;end&quot;: 853\r\n        },\r\n        &quot;obj&quot;: &quot;species&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: [\r\n          &quot;CHEBI:5679&quot;,\r\n          &quot;BERN:4597103&quot;\r\n        ],\r\n        &quot;span&quot;: {\r\n          &quot;begin&quot;: 919,\r\n          &quot;end&quot;: 936\r\n        },\r\n        &quot;obj&quot;: &quot;drug&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: [\r\n          &quot;MESH:C532177&quot;,\r\n          &quot;BERN:280529003&quot;\r\n        ],\r\n        &quot;span&quot;: {\r\n          &quot;begin&quot;: 941,\r\n          &quot;end&quot;: 959\r\n        },\r\n        &quot;obj&quot;: &quot;drug&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: [\r\n          &quot;CUI-less&quot;\r\n        ],\r\n        &quot;span&quot;: {\r\n          &quot;begin&quot;: 979,\r\n          &quot;end&quot;: 994\r\n        },\r\n        &quot;obj&quot;: &quot;gene&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: [\r\n          &quot;CUI-less&quot;\r\n        ],\r\n        &quot;span&quot;: {\r\n          &quot;begin&quot;: 995,\r\n          &quot;end&quot;: 1003\r\n        },\r\n        &quot;obj&quot;: &quot;gene&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: [\r\n          &quot;CHEBI:5679&quot;,\r\n          &quot;BERN:4597103&quot;\r\n        ],\r\n        &quot;span&quot;: {\r\n          &quot;begin&quot;: 1032,\r\n          &quot;end&quot;: 1049\r\n        },\r\n        &quot;obj&quot;: &quot;drug&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: [\r\n          &quot;MESH:C532177&quot;,\r\n          &quot;BERN:280529003&quot;\r\n        ],\r\n        &quot;span&quot;: {\r\n          &quot;begin&quot;: 1054,\r\n          &quot;end&quot;: 1072\r\n        },\r\n        &quot;obj&quot;: &quot;drug&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: [\r\n          &quot;NCBI:txid328401&quot;\r\n        ],\r\n        &quot;span&quot;: {\r\n          &quot;begin&quot;: 1107,\r\n          &quot;end&quot;: 1119\r\n        },\r\n        &quot;obj&quot;: &quot;species&quot;\r\n      }\r\n    ],\r\n    &quot;timestamp&quot;: &quot;Wed Oct 28 21:43:04 +0000 2020&quot;,\r\n    &quot;logits&quot;: {\r\n      &quot;disease&quot;: [],\r\n      &quot;gene&quot;: [\r\n        [\r\n          {\r\n            &quot;start&quot;: 128,\r\n            &quot;end&quot;: 145,\r\n            &quot;id&quot;: &quot;CUI-less&quot;\r\n          },\r\n          0.7066106796264648\r\n        ],\r\n        [\r\n          {\r\n            &quot;start&quot;: 979,\r\n            &quot;end&quot;: 994,\r\n            &quot;id&quot;: &quot;CUI-less&quot;\r\n          },\r\n          0.9999749660491943\r\n        ],\r\n        [\r\n          {\r\n            &quot;start&quot;: 995,\r\n            &quot;end&quot;: 1003,\r\n            &quot;id&quot;: &quot;CUI-less&quot;\r\n          },\r\n          0.9052715301513672\r\n        ]\r\n      ],\r\n      &quot;drug&quot;: [\r\n        [\r\n          {\r\n            &quot;start&quot;: 377,\r\n            &quot;end&quot;: 387,\r\n            &quot;id&quot;: &quot;MESH:D058428\\tBERN:315272203&quot;\r\n          },\r\n          0.999982476234436\r\n        ],\r\n        [\r\n          {\r\n            &quot;start&quot;: 562,\r\n            &quot;end&quot;: 579,\r\n            &quot;id&quot;: &quot;CHEBI:5679\\tBERN:4597103&quot;\r\n          },\r\n          0.9999980926513672\r\n        ],\r\n        [\r\n          {\r\n            &quot;start&quot;: 584,\r\n            &quot;end&quot;: 602,\r\n            &quot;id&quot;: &quot;MESH:C532177\\tBERN:280529003&quot;\r\n          },\r\n          0.9999980926513672\r\n        ],\r\n        [\r\n          {\r\n            &quot;start&quot;: 659,\r\n            &quot;end&quot;: 676,\r\n            &quot;id&quot;: &quot;CHEBI:5679\\tBERN:4597103&quot;\r\n          },\r\n          0.9999980926513672\r\n        ],\r\n        [\r\n          {\r\n            &quot;start&quot;: 681,\r\n            &quot;end&quot;: 699,\r\n            &quot;id&quot;: &quot;MESH:C532177\\tBERN:280529003&quot;\r\n          },\r\n          0.9999980330467224\r\n        ],\r\n        [\r\n          {\r\n            &quot;start&quot;: 919,\r\n            &quot;end&quot;: 936,\r\n            &quot;id&quot;: &quot;CHEBI:5679\\tBERN:4597103&quot;\r\n          },\r\n          0.9999980926513672\r\n        ],\r\n        [\r\n          {\r\n            &quot;start&quot;: 941,\r\n            &quot;end&quot;: 959,\r\n            &quot;id&quot;: &quot;MESH:C532177\\tBERN:280529003&quot;\r\n          },\r\n          0.9999980926513672\r\n        ],\r\n        [\r\n          {\r\n            &quot;start&quot;: 1032,\r\n            &quot;end&quot;: 1049,\r\n            &quot;id&quot;: &quot;CHEBI:5679\\tBERN:4597103&quot;\r\n          },\r\n          0.9999980926513672\r\n        ],\r\n        [\r\n          {\r\n            &quot;start&quot;: 1054,\r\n            &quot;end&quot;: 1072,\r\n            &quot;id&quot;: &quot;MESH:C532177\\tBERN:280529003&quot;\r\n          },\r\n          0.9999980926513672\r\n        ]\r\n      ],\r\n      &quot;species&quot;: [\r\n        [\r\n          {\r\n            &quot;start&quot;: 43,\r\n            &quot;end&quot;: 64,\r\n            &quot;id&quot;: &quot;NCBI:txid328401&quot;\r\n          },\r\n          0.9999997615814209\r\n        ],\r\n        [\r\n          {\r\n            &quot;start&quot;: 225,\r\n            &quot;end&quot;: 246,\r\n            &quot;id&quot;: &quot;NCBI:txid328401&quot;\r\n          },\r\n          0.9999998211860657\r\n        ],\r\n        [\r\n          {\r\n            &quot;start&quot;: 300,\r\n            &quot;end&quot;: 312,\r\n            &quot;id&quot;: &quot;NCBI:txid328401&quot;\r\n          },\r\n          0.9999998211860657\r\n        ],\r\n        [\r\n          {\r\n            &quot;start&quot;: 841,\r\n            &quot;end&quot;: 853,\r\n            &quot;id&quot;: &quot;NCBI:txid328401&quot;\r\n          },\r\n          0.9999998211860657\r\n        ],\r\n        [\r\n          {\r\n            &quot;start&quot;: 1107,\r\n            &quot;end&quot;: 1119,\r\n            &quot;id&quot;: &quot;NCBI:txid328401&quot;\r\n          },\r\n          0.9999998211860657\r\n        ]\r\n      ]\r\n    },\r\n    &quot;elapsed_time&quot;: {\r\n      &quot;tmtool&quot;: 0.991,\r\n      &quot;ner&quot;: 0.453,\r\n      &quot;normalization&quot;: 0.172,\r\n      &quot;total&quot;: 1.617\r\n    }\r\n  }\r\n]\r\n```",
        "link": "https://stackoverflow.com/questions/64582030/how-to-extract-text-from-json-with-parent-siblings-and-substrings",
        "title": "How to extract text from json with parent siblings and substrings?"
    },
    {
        "tags": [
            "linux",
            "bash",
            "datetime",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": -1,
                "last_activity_date": 1603971088,
                "creation_date": 1603971088,
                "answer_id": 64590265,
                "question_id": 64590034,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You would need to format the dates into &quot;seconds since 1970-01-01 00:00:00 UTC&quot; for this. So first format the date by only taking the first 19 characters and then running that through date with -d and formatting with %s\r\n\r\n    currentdate=$(curl -s &quot;http://worldtimeapi.org/api/timezone/Asia/Jerusalem&quot; | jq . | jq &#39;.utc_datetime&#39;)\r\n\r\n    if [[ &quot;$(date -d ${currentdate:1:19} +%s)&quot; -ge &quot;$(date -d &quot;2020-10-28T10:00:00&quot; +%s)&quot; &amp;&amp; &quot;$(date -d ${currentdate:1:19} +%s)&quot; -le &quot;$(date -d &quot;2020-10-28T10:00:00&quot; +%s)&quot; ]]\r\n    then \r\n         echo &quot;between 10 days range dates&quot;\r\n    else\r\n         echo &quot;not between 10 days range dates&quot;\r\n    fi",
                "title": "Compare date between 2 date ranges"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1603974241,
                "last_edit_date": 1603974241,
                "creation_date": 1603972827,
                "answer_id": 64590694,
                "question_id": 64590034,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Multiple ways to get current date to compare:\r\n\r\n```sh\r\n#!/usr/bin/env bash\r\n\r\n# The needlessly complex way\r\ncurdate=$(\r\n  date -d &quot;$(\r\n    curl -s &quot;http://worldtimeapi.org/api/timezone/Asia/Jerusalem&quot; |\r\n      jq -j .utc_datetime\r\n  )&quot; +%s\r\n)\r\n\r\n# The shorter, but still POSIX shell way\r\ncurdate=$(date +%s)\r\n\r\n# The most efficient Bash 4.2+ way\r\nprintf -v curdate &#39;%(%s)T&#39;\r\n\r\n#mindate=$(date -d &quot;2020-10-28T10:00:00&quot; +%s)\r\nmindate=1603875600\r\n\r\n#maxdate=$(date -d &quot;(@$mindate) + 10 days&quot; +%s)\r\nmaxdate=1603929600\r\n\r\n\r\nif [ $curdate -ge $mindate ] &amp;&amp; [ $curdate -le $maxdate ]\r\nthen \r\n     echo &quot;between 10 days range dates&quot;\r\nelse\r\n     echo &quot;not between 10 days range dates&quot;\r\nfi\r\n```",
                "title": "Compare date between 2 date ranges"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1603978574,
                "creation_date": 1603978574,
                "answer_id": 64592214,
                "question_id": 64590034,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`-ge` and `-le` are *numeric* comparison operators. Since you&#39;re using that ISO date format, you can compare the dates as strings: \r\n```bash\r\ndate1=&quot;2020-10-28T10:00:00:00&quot;\r\ndate2=&quot;2020-11-10T10:00:00:00&quot;\r\nif [[ &quot;$date1&quot; &lt;= &quot;$currentdate&quot; &amp;&amp; &quot;$currentdate&quot; &lt;= &quot;$date2&quot; ]]; ...\r\n```\r\n",
                "title": "Compare date between 2 date ranges"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1603996174,
                "last_edit_date": 1603996174,
                "creation_date": 1603993009,
                "answer_id": 64596430,
                "question_id": 64590034,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can do the whole thing in jq if you want.\r\n\r\n    begin_date=&quot;2020-10-28T10:00:00Z&quot;\r\n    end_date=&quot;2020-11-10T10:00:00Z&quot;\r\n    curl -s &quot;http://worldtimeapi.org/api/timezone/Asia/Jerusalem&quot; | \\\r\n    jq --arg bd $begin_date --arg ed $end_date &#39;.unixtime \r\n       | if . &gt;= ($bd | fromdate) and . &lt;= ($ed | fromdate) \r\n         then &quot;between 10 days range dates&quot;\r\n         else &quot;not between 10 days range dates&quot;\r\n         end&#39;\r\n\r\n`fromdate` converts the beginning and end dates into the number of seconds since the Unix epoch (1970-01-01T00:00:00Z). We can compare those numbers with the value of .unixtime.\r\n\r\nI altered the beginning and end dates to a format that jq could easily recognize.\r\n\r\nNote: in your original program, you only need to invoke jq once: `jq &#39;.utc_datetime&#39;` would work.\r\n",
                "title": "Compare date between 2 date ranges"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": 0,
        "last_activity_date": 1604062536,
        "creation_date": 1603970188,
        "last_edit_date": 1604062536,
        "question_id": 64590034,
        "body_markdown": "I&#39;m trying to compare date between 2 date ranges     \r\n\r\n\r\n    currentdate= curl -s &quot;http://worldtimeapi.org/api/timezone/Asia/Jerusalem&quot; | jq . | jq &#39;.utc_datetime&#39;\r\n    \r\n    if [ &quot;$currentdate&quot; -ge &quot;2020-10-28T10:00:00:00&quot; &amp;&amp; &quot;$currentdate&quot; -le &quot;2020-11-10T10:00:00:00&quot;]\r\n    then echo &quot;between 10 days range dates&quot;\r\n    \r\n    fi\r\n    echo &quot;not between 10 days range dates&quot;",
        "link": "https://stackoverflow.com/questions/64590034/compare-date-between-2-date-ranges",
        "title": "Compare date between 2 date ranges"
    },
    {
        "tags": [
            "sh",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1693,
                    "reputation": 18059,
                    "user_id": 2283,
                    "user_type": "registered",
                    "accept_rate": 79,
                    "profile_image": "https://www.gravatar.com/avatar/3ac5db3768c09788ed9fe03c5f4ff171?s=256&d=identicon&r=PG",
                    "display_name": "Weeble",
                    "link": "https://stackoverflow.com/users/2283/weeble"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1604065458,
                "post_id": 64594378,
                "comment_id": 114240917,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1693,
                    "reputation": 18059,
                    "user_id": 2283,
                    "user_type": "registered",
                    "accept_rate": 79,
                    "profile_image": "https://www.gravatar.com/avatar/3ac5db3768c09788ed9fe03c5f4ff171?s=256&d=identicon&r=PG",
                    "display_name": "Weeble",
                    "link": "https://stackoverflow.com/users/2283/weeble"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1604065510,
                "post_id": 64594378,
                "comment_id": 114240953,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1603987750,
                "creation_date": 1603987750,
                "answer_id": 64594968,
                "question_id": 64594378,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "as an alternative to ```jq```:\r\n```bash\r\n#!/bin/sh\r\ndeclare -A myarray\r\nmyarray[&quot;testkey&quot;]=&quot;testvalue&quot;\r\nmyarray[&quot;testkey1&quot;]=&quot;testvalue1&quot;\r\nmyarray[&quot;testkey2&quot;]=&quot;testvalue2&quot;\r\n\r\ncols=$(printf &quot;%s,&quot; &quot;${!myarray[@]}&quot;)\r\ncolumn -J --table-name &#39;myTable&#39; --table-columns &quot;${cols}&quot;  &lt;&lt;&lt;&quot;${myarray[@]}&quot;\r\n```",
                "title": "sh: How to write an array to a json file using jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1604065385,
                "creation_date": 1604065385,
                "answer_id": 64609535,
                "question_id": 64594378,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a way that doesn&#39;t need an extra step before to serialise the associative array:\r\n```\r\njq -n &#39;\r\n    $ARGS.positional|\r\n    . as $a|\r\n    (length/2) as $l|\r\n    [range($l)|{key:$a[.],value:$a[.+$l]}]|\r\n    from_entries&#39; --args &quot;${!myarray[@]}&quot; &quot;${myarray[@]}&quot;\r\n```\r\nIt should work even with newlines in the keys or values. The one caveat is that _technically_ bash doesn&#39;t guarantee that `${!myarray[@]}` will output the keys [in the same order][1] that `${myarray[@]}` will output the values. It _does_ do that in practice, and it&#39;s hard to imagine an implementation that _wouldn&#39;t,_ but if you _really_ want to be safe here&#39;s a variation on [Inian&#39;s answer][2] that should be safe to newlines. It also  assembles a single object.\r\n\r\n```\r\nfor key in &quot;${!myarray[@]}&quot;; do \r\n    printf &quot;%s\\0%s\\0&quot; &quot;$key&quot; &quot;${myarray[$key]}&quot;\r\ndone | \r\njq -sR &#39;\r\n    split(&quot;\\u0000&quot;)|\r\n    . as $elements|\r\n    [range(length/2)|{key:$elements[2*.],value:$elements[2*.+1]}]|\r\n    from_entries&#39;\r\n```\r\n\r\n  [1]: https://stackoverflow.com/questions/54306133/do-keys-a-and-values-a-of-associative-arrays-expand-in-the-same-ord\r\n  [2]: https://stackoverflow.com/a/64595305/2283",
                "title": "sh: How to write an array to a json file using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1604065385,
        "creation_date": 1603985702,
        "last_edit_date": 1604041442,
        "question_id": 64594378,
        "body_markdown": "How can I write the array to a json file?\r\n    \r\n    #!/bin/sh\r\n    declare -A myarray \r\n    myarray[&quot;testkey&quot;]=&quot;testvalue&quot;\r\n    myarray[&quot;testkey1&quot;]=&quot;testvalue1&quot;\r\n    myarray[&quot;testkey2&quot;]=&quot;testvalue2&quot;\r\n \r\n    jq -n --arg $myarray[@] &gt; file.json\r\n\r\nEDIT: \r\n\r\nThe json file should contain the following: \r\n\r\n    {\r\n      &quot;testkey&quot;: &quot;testvalue&quot;,\r\n      &quot;testkey1&quot;: &quot;testvalue1&quot;, \r\n      &quot;testkey2&quot;: &quot;testvalue2&quot;\r\n    }",
        "link": "https://stackoverflow.com/questions/64594378/sh-how-to-write-an-array-to-a-json-file-using-jq",
        "title": "sh: How to write an array to a json file using jq"
    },
    {
        "tags": [
            "json",
            "object",
            "key",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1603997163,
                "last_edit_date": 1603997163,
                "creation_date": 1603996236,
                "answer_id": 64597179,
                "question_id": 64596039,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "One way uses `reduce` and `setpath` to build up the new object from the keys of the original:\r\n\r\n```sh\r\n$ jq &#39;. as $orig | reduce keys[] as $key ({}; setpath($key | split(&quot;.&quot;); $orig[$key]))&#39; input.json\r\n{\r\n  &quot;bar&quot;: {\r\n    &quot;foo&quot;: &quot;dolor&quot;\r\n  },\r\n  &quot;foo&quot;: {\r\n    &quot;bar&quot;: &quot;lorem&quot;,\r\n    &quot;baz&quot;: &quot;ipsum&quot;\r\n  }\r\n}\r\n```\r\n\r\n---\r\n\r\nHow it works\r\n\r\n`reduce` calls the expression in its body once per key. The first time, `.` is set to an empty object, each other time it&#39;s what the body of the previous call returned. Each call splits the current key up into an array, and `setpath` uses that as a path to set in `.` using the corresponding value from the original object.\r\n\r\nSo the result is gradually built up one element at at time:\r\n\r\n`.` = `{}` and `$key` = `&quot;foo.bar&quot;` -&gt; `.` = `{&quot;foo&quot;:{&quot;bar&quot;:&quot;lorem&quot;}}` and `$key` = `&quot;foo.baz&quot;` and so on.",
                "title": "jq: Create JSON Object from flat keys"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1604002836,
        "creation_date": 1603991534,
        "last_edit_date": 1604002836,
        "question_id": 64596039,
        "body_markdown": "How can I create a nested JSON object from the flat keys in an object with jq?\r\n\r\nMy input is\r\n```json\r\n{\r\n    &quot;foo.bar&quot;: &quot;lorem&quot;,\r\n    &quot;foo.baz&quot;: &quot;ipsum&quot;,\r\n    &quot;bar.foo&quot;: &quot;dolor&quot;\r\n}\r\n```\r\n\r\nand the output should look like\r\n```json\r\n{\r\n    &quot;foo&quot;: {\r\n        &quot;bar&quot;: &quot;lorem&quot;,\r\n        &quot;baz&quot;: &quot;ipsum&quot;\r\n    },\r\n    &quot;bar&quot;: {\r\n        &quot;foo&quot;: &quot;dolor&quot;\r\n    }\r\n}\r\n```\r\n",
        "link": "https://stackoverflow.com/questions/64596039/jq-create-json-object-from-flat-keys",
        "title": "jq: Create JSON Object from flat keys"
    }
]